-
Notifications
You must be signed in to change notification settings - Fork 30.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test: fix test-fs-utimes on non-Y2K38 file systems
Move Y2K38-specific parts of test-fs-utimes to test-fs-utimes-y2K38.js. On non-Windows, check for Y2K38 support and skip if it is unsupported. Fixes: #36591
- Loading branch information
Showing
2 changed files
with
55 additions
and
31 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
'use strict'; | ||
const common = require('../common'); | ||
const tmpdir = require('../common/tmpdir'); | ||
|
||
const assert = require('assert'); | ||
const fs = require('fs'); | ||
|
||
tmpdir.refresh(); | ||
|
||
// Check for Y2K38 support on POSIX. For Windows, assume it's there. | ||
if (!common.isWindows) { | ||
const testFilePath = `${tmpdir.path}/y2k38-test`; | ||
const testFileDate = '203801020304'; | ||
const { spawnSync } = require('child_process'); | ||
const touchResult = spawnSync('touch', | ||
['-t', testFileDate, testFilePath], | ||
{ encoding: 'utf8' }); | ||
assert.strictEqual(touchResult.status, 0); | ||
|
||
const dateResult = spawnSync('date', | ||
['-r', testFilePath, '+%Y%m%d%H%M'], | ||
{ encoding: 'utf8' }); | ||
assert.strictEqual(dateResult.status, 0); | ||
|
||
if (dateResult.stdout.trim() !== testFileDate) { | ||
common.skip('File system appears to lack Y2k38 support'); | ||
} | ||
} | ||
|
||
// Ref: https://github.com/nodejs/node/issues/13255 | ||
const path = `${tmpdir.path}/test-utimes-precision`; | ||
fs.writeFileSync(path, ''); | ||
|
||
const Y2K38_mtime = 2 ** 31; | ||
fs.utimesSync(path, Y2K38_mtime, Y2K38_mtime); | ||
const Y2K38_stats = fs.statSync(path); | ||
assert.strictEqual(Y2K38_stats.mtime.getTime() / 1000, Y2K38_mtime); | ||
|
||
if (common.isWindows) { | ||
// This value would get converted to (double)1713037251359.9998 | ||
const truncate_mtime = 1713037251360; | ||
fs.utimesSync(path, truncate_mtime / 1000, truncate_mtime / 1000); | ||
const truncate_stats = fs.statSync(path); | ||
assert.strictEqual(truncate_stats.mtime.getTime(), truncate_mtime); | ||
|
||
// test Y2K38 for windows | ||
// This value if treaded as a `signed long` gets converted to -2135622133469. | ||
// POSIX systems stores timestamps in {long t_sec, long t_usec}. | ||
// NTFS stores times in nanoseconds in a single `uint64_t`, so when libuv | ||
// calculates (long)`uv_timespec_t.tv_sec` we get 2's complement. | ||
const overflow_mtime = 2159345162531; | ||
fs.utimesSync(path, overflow_mtime / 1000, overflow_mtime / 1000); | ||
const overflow_stats = fs.statSync(path); | ||
assert.strictEqual(overflow_stats.mtime.getTime(), overflow_mtime); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters