From 1bc5c912a6f39dc5ebae86006fc90cc7f386affe Mon Sep 17 00:00:00 2001 From: Andrey Kupreychik Date: Thu, 3 Jul 2014 11:45:25 +0700 Subject: [PATCH 1/2] Added removeCallback passing --- .gitignore | 1 + lib/tmp.js | 36 +++++++++++++++++++++++++++++------- 2 files changed, 30 insertions(+), 7 deletions(-) diff --git a/.gitignore b/.gitignore index c2658d7..78f2710 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ node_modules/ +.idea/ diff --git a/lib/tmp.js b/lib/tmp.js index dcb5bbb..baaeabb 100644 --- a/lib/tmp.js +++ b/lib/tmp.js @@ -167,9 +167,21 @@ function _createTmpFile(options, callback) { fs.open(name, _c.O_CREAT | _c.O_EXCL | _c.O_RDWR, opts.mode || 0600, function _fileCreated(err, fd) { if (err) return cb(err); - if (!opts.keep) _removeObjects.unshift([ fs.unlinkSync, name ]); + var removed = false; + var removeCallback = function() { + if (removed) { + return; + } + + fs.unlinkSync(name); + removed = true; + }; + + if (!opts.keep) { + _removeObjects.unshift(removeCallback); + } - cb(null, name, fd); + cb(null, name, fd, removeCallback); }); }); } @@ -218,15 +230,25 @@ function _createTmpDir(options, callback) { fs.mkdir(name, opts.mode || 0700, function _dirCreated(err) { if (err) return cb(err); - if (!opts.keep) { + var removed = false; + var removeCallback = function() { + if (removed) { + return; + } + if (opts.unsafeCleanup) { - _removeObjects.unshift([ _rmdirRecursiveSync, name ]); + _rmdirRecursiveSync(name); } else { - _removeObjects.unshift([ fs.rmdirSync, name ]); + fs.rmdirSync(name); } + removed = true; + }; + + if (!opts.keep) { + _removeObjects.unshift(removeCallback); } - cb(null, name); + cb(null, name, removeCallback); }); }); } @@ -243,7 +265,7 @@ function _garbageCollector() { for (var i = 0, length = _removeObjects.length; i < length; i++) { try { - _removeObjects[i][0].call(null, _removeObjects[i][1]); + _removeObjects[i].call(null); } catch (e) { // already removed? } From 6433e68e80b501af3176fdeecf68fd760adec611 Mon Sep 17 00:00:00 2001 From: Andrey Kupreychik Date: Wed, 9 Jul 2014 16:21:57 +0700 Subject: [PATCH 2/2] Refactoring tests --- lib/tmp.js | 51 ++++++++++++++++++++++++++--------------------- test/dir-test.js | 13 ++++++++++++ test/file-test.js | 13 ++++++++++++ 3 files changed, 54 insertions(+), 23 deletions(-) diff --git a/lib/tmp.js b/lib/tmp.js index baaeabb..ea84faa 100644 --- a/lib/tmp.js +++ b/lib/tmp.js @@ -167,15 +167,7 @@ function _createTmpFile(options, callback) { fs.open(name, _c.O_CREAT | _c.O_EXCL | _c.O_RDWR, opts.mode || 0600, function _fileCreated(err, fd) { if (err) return cb(err); - var removed = false; - var removeCallback = function() { - if (removed) { - return; - } - - fs.unlinkSync(name); - removed = true; - }; + var removeCallback = _prepareRemoveCallback(fs.unlinkSync.bind(fs), name); if (!opts.keep) { _removeObjects.unshift(removeCallback); @@ -189,7 +181,7 @@ function _createTmpFile(options, callback) { /** * Removes files and folders in a directory recursively. * - * @param {String} path + * @param {String} dir */ function _rmdirRecursiveSync(dir) { var files = fs.readdirSync(dir); @@ -209,6 +201,26 @@ function _rmdirRecursiveSync(dir) { fs.rmdirSync(dir); } +/** + * + * @param {Function} removeFunction + * @param {String} path + * @returns {Function} + * @private + */ +function _prepareRemoveCallback(removeFunction, path) { + var called = false; + return function() { + if (called) { + return; + } + + removeFunction(path); + + called = true; + }; +} + /** * Creates a temporary directory. * @@ -230,19 +242,12 @@ function _createTmpDir(options, callback) { fs.mkdir(name, opts.mode || 0700, function _dirCreated(err) { if (err) return cb(err); - var removed = false; - var removeCallback = function() { - if (removed) { - return; - } - - if (opts.unsafeCleanup) { - _rmdirRecursiveSync(name); - } else { - fs.rmdirSync(name); - } - removed = true; - }; + var removeCallback = _prepareRemoveCallback( + opts.unsafeCleanup + ? _rmdirRecursiveSync + : fs.rmdirSync.bind(fs), + name + ); if (!opts.keep) { _removeObjects.unshift(removeCallback); diff --git a/test/dir-test.js b/test/dir-test.js index 9b89009..2e4e529 100644 --- a/test/dir-test.js +++ b/test/dir-test.js @@ -179,5 +179,18 @@ vows.describe('Directory creation').addBatch({ 'should not return with an error': assert.isNull, 'should return with a name': Test.assertName, 'should be a directory': _testDir(040700) + }, + + 'remove callback': { + topic: function () { + tmp.dir(this.callback); + }, + + 'should not return with an error': assert.isNull, + 'should return with a name': Test.assertName, + 'removeCallback should remove directory': function (_err, name, removeCallback) { + removeCallback(); + assert.ok(!existsSync(name), "Directory should be removed"); + } } }).exportTo(module); diff --git a/test/file-test.js b/test/file-test.js index 150ca11..0cde37c 100644 --- a/test/file-test.js +++ b/test/file-test.js @@ -160,6 +160,19 @@ vows.describe('File creation').addBatch({ 'should not exist': function (err, name) { assert.ok(!existsSync(name), "File should be removed"); } + }, + + 'remove callback': { + topic: function () { + tmp.file(this.callback); + }, + + 'should not return with an error': assert.isNull, + 'should return with a name': Test.assertName, + 'removeCallback should remove file': function (_err, name, _fd, removeCallback) { + removeCallback(); + assert.ok(!existsSync(name), "File should be removed"); + } } }).exportTo(module);