From d36699662f5e64d9741f13996dc3aea30912853f Mon Sep 17 00:00:00 2001 From: bcoe Date: Sun, 2 Feb 2020 13:48:41 -0800 Subject: [PATCH] fs: set path when mkdir recursive called on file PR-URL: https://github.com/nodejs/node/pull/31607 Fixes: https://github.com/nodejs/node/issues/28015 Reviewed-By: Anna Henningsen Reviewed-By: Rich Trott Reviewed-By: Luigi Pinca Reviewed-By: Richard Lau --- src/node_file.cc | 3 ++- test/parallel/test-fs-mkdir.js | 6 ++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/src/node_file.cc b/src/node_file.cc index 5af55a38d5f5a5..8fb59c8b6aaf71 100644 --- a/src/node_file.cc +++ b/src/node_file.cc @@ -1234,6 +1234,7 @@ int MKDirpSync(uv_loop_t* loop, } break; case UV_EACCES: + case UV_ENOTDIR: case UV_EPERM: { return err; } @@ -1309,6 +1310,7 @@ int MKDirpAsync(uv_loop_t* loop, break; } case UV_EACCES: + case UV_ENOTDIR: case UV_EPERM: { req_wrap->continuation_data()->Done(err); break; @@ -1351,7 +1353,6 @@ int MKDirpAsync(uv_loop_t* loop, } // verify that the path pointed to is actually a directory. if (err == 0 && !S_ISDIR(req->statbuf.st_mode)) err = UV_EEXIST; - uv_fs_req_cleanup(req); req_wrap->continuation_data()->Done(err); }}); if (err < 0) req_wrap->continuation_data()->Done(err); diff --git a/test/parallel/test-fs-mkdir.js b/test/parallel/test-fs-mkdir.js index 5e9a2bd75ea2a3..ea062f3cb17763 100644 --- a/test/parallel/test-fs-mkdir.js +++ b/test/parallel/test-fs-mkdir.js @@ -148,6 +148,7 @@ function nextdir() { message: /ENOTDIR: .*mkdir/, name: 'Error', syscall: 'mkdir', + path: pathname // See: https://github.com/nodejs/node/issues/28015 } ); } @@ -187,6 +188,11 @@ function nextdir() { assert.strictEqual(err.code, 'ENOTDIR'); assert.strictEqual(err.syscall, 'mkdir'); assert.strictEqual(fs.existsSync(pathname), false); + // See: https://github.com/nodejs/node/issues/28015 + // The path field varies slightly in Windows errors, vs., other platforms + // see: https://github.com/libuv/libuv/issues/2661, for this reason we + // use startsWith() rather than comparing to the full "pathname". + assert(err.path.startsWith(filename)); })); }