diff --git a/doc/api/fs.markdown b/doc/api/fs.markdown index 643f9d9ea2c..0b5adab793a 100644 --- a/doc/api/fs.markdown +++ b/doc/api/fs.markdown @@ -363,6 +363,14 @@ descriptor. Change file timestamps of the file referenced by the supplied path. +Note: the arguments `atime` and `mtime` of the following related functions does +follow the below rules: + +- If the value is a numberable string like "123456789", the value would get + converted to corresponding number. +- If the value is `NaN` or `Infinity`, the value would get converted to + `Date.now()`. + ## fs.utimesSync(path, atime, mtime) Synchronous version of `fs.utimes()`. Returns `undefined`. diff --git a/lib/fs.js b/lib/fs.js index 10e5b63ee3a..eeb3806cdc8 100644 --- a/lib/fs.js +++ b/lib/fs.js @@ -1045,7 +1045,13 @@ fs.chownSync = function(path, uid, gid) { // converts Date or number to a fractional UNIX timestamp function toUnixTimestamp(time) { + if (typeof time === 'string' && +time == time) { + return +time; + } if (typeof time === 'number') { + if (!Number.isFinite(time) || time < 0) { + return Date.now() / 1000; + } return time; } if (util.isDate(time)) { diff --git a/test/parallel/test-fs-utimes.js b/test/parallel/test-fs-utimes.js index 292636b1b69..a5ec0b2c2e2 100644 --- a/test/parallel/test-fs-utimes.js +++ b/test/parallel/test-fs-utimes.js @@ -122,16 +122,22 @@ function runTest(atime, mtime, callback) { var stats = fs.statSync(__filename); +// run tests runTest(new Date('1982-09-10 13:37'), new Date('1982-09-10 13:37'), function() { runTest(new Date(), new Date(), function() { runTest(123456.789, 123456.789, function() { runTest(stats.mtime, stats.mtime, function() { - // done + runTest(NaN, Infinity, function() { + runTest('123456', -1, function() { + // done + }); + }); }); }); }); }); + process.on('exit', function() { console.log('Tests run / ok:', tests_run, '/', tests_ok); assert.equal(tests_ok, tests_run);