-
Notifications
You must be signed in to change notification settings - Fork 29.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
src: ignore SIGXFSZ, don't terminate (ulimit -f)
Ignore SIGXFSZ signals so that exceeding RLIMIT_FSIZE makes the offending system call fail with EFBIG instead of terminating the process. PR-URL: #27798 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Colin Ihrig <cjihrig@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de>
- Loading branch information
1 parent
3b6424f
commit c0cf173
Showing
2 changed files
with
33 additions
and
1 deletion.
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
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,32 @@ | ||
// Check that exceeding RLIMIT_FSIZE fails with EFBIG | ||
// rather than terminating the process with SIGXFSZ. | ||
'use strict'; | ||
const common = require('../common'); | ||
const tmpdir = require('../common/tmpdir'); | ||
|
||
const assert = require('assert'); | ||
const child_process = require('child_process'); | ||
const fs = require('fs'); | ||
const path = require('path'); | ||
|
||
if (common.isWindows) | ||
common.skip('no RLIMIT_FSIZE on Windows'); | ||
|
||
if (process.config.variables.node_shared) | ||
common.skip('SIGXFSZ signal handler not installed in shared library mode'); | ||
|
||
if (process.argv[2] === 'child') { | ||
const filename = path.join(tmpdir.path, 'efbig.txt'); | ||
tmpdir.refresh(); | ||
fs.writeFileSync(filename, '.'.repeat(1 << 16)); // Exceeds RLIMIT_FSIZE. | ||
} else { | ||
const cmd = `ulimit -f 1 && '${process.execPath}' '${__filename}' child`; | ||
const result = child_process.spawnSync('/bin/sh', ['-c', cmd]); | ||
const haystack = result.stderr.toString(); | ||
const needle = 'Error: EFBIG: file too large, write'; | ||
const ok = haystack.includes(needle); | ||
if (!ok) console.error(haystack); | ||
assert(ok); | ||
assert.strictEqual(result.status, 1); | ||
assert.strictEqual(result.stdout.toString(), ''); | ||
} |