commit 1a455b2dd8b45fe197fcac7abb9816f5518f6ccd (tree)
parent 396bd51c4818752f6309ff10f2d316f41598d5cd
Author: xEgoist <egoist@egoistic.dev>
Date: Wed, 26 Apr 2023 00:53:19 -0500
test: Fix windows_spawn tmp directory cleanup
On Windows, a directory that's set as the current working directory is
not allowed to be removed. This can cause error on `deleteTree` if the
CWD is set to the file to be removed and will cause `error.FileBusy`.
However, due to `tmp.cleanup()` ignoring the errors, the folder removal error will
be ignored. The only test violating this is `windows_spawn`. As a
solution, setting the parent directory to be the CWD before deletion
will allow the cleanup to pass.
Diffstat:
2 files changed, 16 insertions(+), 0 deletions(-)
diff --git a/lib/std/fs/test.zig b/lib/std/fs/test.zig
@@ -1434,3 +1434,18 @@ test "delete a read-only file on windows" {
file.close();
try tmp.dir.deleteFile("test_file");
}
+
+test "delete a setAsCwd directory on Windows" {
+ if (builtin.os.tag != .windows) return error.SkipZigTest;
+
+ var tmp = tmpDir(.{});
+ // Set tmp dir as current working directory.
+ try tmp.dir.setAsCwd();
+ tmp.dir.close();
+ try testing.expectError(error.FileBusy, tmp.parent_dir.deleteTree(&tmp.sub_path));
+ // Now set the parent dir as the current working dir for clean up.
+ try tmp.parent_dir.setAsCwd();
+ try tmp.parent_dir.deleteTree(&tmp.sub_path);
+ // Close the parent "tmp" so we don't leak the HANDLE.
+ tmp.parent_dir.close();
+}
diff --git a/test/standalone/windows_spawn/main.zig b/test/standalone/windows_spawn/main.zig
@@ -116,6 +116,7 @@ pub fn main() anyerror!void {
// Now let's set the tmp dir as the cwd and set the path only include the "something" sub dir
try tmp.dir.setAsCwd();
+ defer tmp.parent_dir.setAsCwd() catch {};
const something_subdir_abs_path = try std.mem.concatWithSentinel(allocator, u16, &.{ tmp_absolute_path_w, utf16Literal("\\something") }, 0);
defer allocator.free(something_subdir_abs_path);