Skip to content

Commit 280e745

Browse files
committed
fixup! test: fix writefile with fd
1 parent 23bae8a commit 280e745

File tree

1 file changed

+22
-20
lines changed

1 file changed

+22
-20
lines changed

test/parallel/test-fs-writefile-with-fd.js

+22-20
Original file line numberDiff line numberDiff line change
@@ -12,26 +12,38 @@ const join = require('path').join;
1212
const tmpdir = require('../common/tmpdir');
1313
tmpdir.refresh();
1414

15-
const fdsToCloseOnExit = [];
1615
{
1716
/* writeFileSync() test. */
1817
const filename = join(tmpdir.path, 'test.txt');
1918

2019
/* Open the file descriptor. */
2120
const fd = fs.openSync(filename, 'w');
22-
fdsToCloseOnExit.push(fd);
23-
24-
/* Write only five characters, so that the position moves to five. */
25-
assert.deepStrictEqual(fs.writeSync(fd, 'Hello'), 5);
26-
assert.deepStrictEqual(fs.readFileSync(filename).toString(), 'Hello');
21+
try {
22+
/* Write only five characters, so that the position moves to five. */
23+
assert.deepStrictEqual(fs.writeSync(fd, 'Hello'), 5);
24+
assert.deepStrictEqual(fs.readFileSync(filename).toString(), 'Hello');
2725

28-
/* Write some more with writeFileSync(). */
29-
fs.writeFileSync(fd, 'World');
26+
/* Write some more with writeFileSync(). */
27+
fs.writeFileSync(fd, 'World');
3028

31-
/* New content should be written at position five, instead of zero. */
32-
assert.deepStrictEqual(fs.readFileSync(filename).toString(), 'HelloWorld');
29+
/* New content should be written at position five, instead of zero. */
30+
assert.deepStrictEqual(fs.readFileSync(filename).toString(), 'HelloWorld');
31+
} finally {
32+
fs.closeSync(fd);
33+
}
3334
}
3435

36+
const fdsToCloseOnExit = [];
37+
process.on('beforeExit', common.mustCall(() => {
38+
for (const fd of fdsToCloseOnExit) {
39+
try {
40+
fs.closeSync(fd);
41+
} catch {
42+
// Failed to close, ignore
43+
}
44+
}
45+
}));
46+
3547
{
3648
/* writeFile() test. */
3749
const file = join(tmpdir.path, 'test1.txt');
@@ -82,13 +94,3 @@ const fdsToCloseOnExit = [];
8294

8395
controller.abort();
8496
}
85-
86-
process.on('beforeExit', () => {
87-
for (const fd of fdsToCloseOnExit) {
88-
try {
89-
fs.closeSync(fd);
90-
} catch {
91-
// Failed to close, ignore
92-
}
93-
}
94-
});

0 commit comments

Comments
 (0)