From 5bfcb64b21cd9e3463497cd3ecbfb90f3143c69c Mon Sep 17 00:00:00 2001 From: RyanZim Date: Tue, 2 May 2017 19:29:51 -0400 Subject: [PATCH] move() should error when src & dest are the same and src doesn't exist Fixes #414; bug introduced in #378 --- lib/move-sync/__tests__/move-sync.test.js | 7 +++++++ lib/move-sync/index.js | 2 +- lib/move/__tests__/move.test.js | 10 ++++++++++ lib/move/index.js | 2 +- 4 files changed, 19 insertions(+), 2 deletions(-) diff --git a/lib/move-sync/__tests__/move-sync.test.js b/lib/move-sync/__tests__/move-sync.test.js index 4b943d42..48da8f17 100644 --- a/lib/move-sync/__tests__/move-sync.test.js +++ b/lib/move-sync/__tests__/move-sync.test.js @@ -61,6 +61,13 @@ describe('moveSync()', () => { assert.ok(contents.match(expected), `${contents} match ${expected}`) }) + it('should error if src and dest are the same and src does not exist', () => { + const src = `${TEST_DIR}/non-existent` + const dest = src + + assert.throws(() => fse.moveSync(src, dest)) + }) + it('should rename a file on the same device', () => { const src = `${TEST_DIR}/a-file` const dest = `${TEST_DIR}/a-file-dest` diff --git a/lib/move-sync/index.js b/lib/move-sync/index.js index 6d510d05..a5e91146 100644 --- a/lib/move-sync/index.js +++ b/lib/move-sync/index.js @@ -14,7 +14,7 @@ function moveSync (src, dest, options) { src = path.resolve(src) dest = path.resolve(dest) - if (src === dest) return + if (src === dest) return fs.accessSync(src) if (isSrcSubdir(src, dest)) throw new Error(`Cannot move '${src}' into itself '${dest}'.`) diff --git a/lib/move/__tests__/move.test.js b/lib/move/__tests__/move.test.js index 429e79ce..988a75c8 100644 --- a/lib/move/__tests__/move.test.js +++ b/lib/move/__tests__/move.test.js @@ -79,6 +79,16 @@ describe('move', () => { }) }) + it('should error if source and destination are the same and source does not exist', done => { + const src = `${TEST_DIR}/non-existent` + const dest = src + + fse.move(src, dest, err => { + assert(err) + done() + }) + }) + it('should not move a directory if source and destination are the same', done => { const src = `${TEST_DIR}/a-folder` const dest = src diff --git a/lib/move/index.js b/lib/move/index.js index c44e66be..e5eb2c10 100644 --- a/lib/move/index.js +++ b/lib/move/index.js @@ -37,7 +37,7 @@ function move (source, dest, options, callback) { function doRename () { if (path.resolve(source) === path.resolve(dest)) { - setImmediate(callback) + fs.access(source, callback) } else if (overwrite) { fs.rename(source, dest, err => { if (!err) return callback()