From 3fc58948ad020d42f89dea0f07c0d8137479c6da Mon Sep 17 00:00:00 2001 From: RyanZim Date: Thu, 20 Jul 2017 11:00:06 -0400 Subject: [PATCH] ensureFile & ensureFileSync should error when the path is a directory Fixes #465 --- lib/ensure/__tests__/ensure.test.js | 29 +++++++++++++++++++++++++++++ lib/ensure/file.js | 11 +++++++---- 2 files changed, 36 insertions(+), 4 deletions(-) diff --git a/lib/ensure/__tests__/ensure.test.js b/lib/ensure/__tests__/ensure.test.js index b7b519e5..0c065979 100644 --- a/lib/ensure/__tests__/ensure.test.js +++ b/lib/ensure/__tests__/ensure.test.js @@ -45,6 +45,19 @@ describe('fs-extra', () => { }) }) }) + + describe('> when there is a directory at that path', () => { + it('should error', done => { + const p = path.join(TEST_DIR, 'somedir') + fs.mkdirSync(p) + + fse.ensureFile(p, err => { + assert(err) + assert.equal(err.code, 'EISDIR') + done() + }) + }) + }) }) describe('+ ensureFileSync()', () => { @@ -68,6 +81,22 @@ describe('fs-extra', () => { assert(fs.existsSync(file)) }) }) + + describe('> when there is a directory at that path', () => { + it('should error', () => { + const p = path.join(TEST_DIR, 'somedir2') + fs.mkdirSync(p) + + assert.throws(() => { + try { + fse.ensureFileSync(p) + } catch (e) { + assert.equal(e.code, 'EISDIR') + throw e + } + }) + }) + }) }) describe('+ ensureDir()', () => { diff --git a/lib/ensure/file.js b/lib/ensure/file.js index 962c21cb..67eed301 100644 --- a/lib/ensure/file.js +++ b/lib/ensure/file.js @@ -14,9 +14,8 @@ function createFile (file, callback) { }) } - pathExists(file, (err, fileExists) => { - if (err) return callback(err) - if (fileExists) return callback() + fs.stat(file, (err, stats) => { // eslint-disable-line handle-callback-err + if (!err && stats.isFile()) return callback() const dir = path.dirname(file) pathExists(dir, (err, dirExists) => { if (err) return callback(err) @@ -30,7 +29,11 @@ function createFile (file, callback) { } function createFileSync (file) { - if (fs.existsSync(file)) return + let stats + try { + stats = fs.statSync(file) + } catch (e) {} + if (stats && stats.isFile()) return const dir = path.dirname(file) if (!fs.existsSync(dir)) {