summaryrefslogtreecommitdiff
path: root/test/sequential/test-fs-stat-sync-overflow.js
diff options
context:
space:
mode:
authorUjjwal Sharma <usharma1998@gmail.com>2018-03-06 19:07:56 +0530
committerGus Caplan <me@gus.host>2018-03-08 10:37:21 -0600
commit635c8c4e1c3155d66e35aec4c6370e72cf53fdeb (patch)
tree5cadd6542f471b149cd871763fd51bf915b892f9 /test/sequential/test-fs-stat-sync-overflow.js
parentd0518c28ceb777206d1b59ca640c47cfb81c5686 (diff)
downloadnode-new-635c8c4e1c3155d66e35aec4c6370e72cf53fdeb.tar.gz
test: rename tests to remove "regress" keyword
Rename affected tests to remove the "regress" keyword as well as improve naming scheme. Refs: https://github.com/nodejs/node/issues/19105 PR-URL: https://github.com/nodejs/node/pull/19161 Refs: https://github.com/nodejs/node/blob/master/doc/guides/writing-tests.md#test-structure Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Ruben Bridgewater <ruben@bridgewater.de> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Richard Lau <riclau@uk.ibm.com> Reviewed-By: Gireesh Punathil <gpunathi@in.ibm.com>
Diffstat (limited to 'test/sequential/test-fs-stat-sync-overflow.js')
-rw-r--r--test/sequential/test-fs-stat-sync-overflow.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/test/sequential/test-fs-stat-sync-overflow.js b/test/sequential/test-fs-stat-sync-overflow.js
new file mode 100644
index 0000000000..c770b6b156
--- /dev/null
+++ b/test/sequential/test-fs-stat-sync-overflow.js
@@ -0,0 +1,41 @@
+// Copyright Joyent, Inc. and other Node contributors.
+//
+// Permission is hereby granted, free of charge, to any person obtaining a
+// copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to permit
+// persons to whom the Software is furnished to do so, subject to the
+// following conditions:
+//
+// The above copyright notice and this permission notice shall be included
+// in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
+// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
+// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
+// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
+// USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+'use strict';
+require('../common');
+const { fixturesDir } = require('../common/fixtures');
+
+// Check that the calls to Integer::New() and Date::New() succeed and bail out
+// if they don't.
+// V8 returns an empty handle on stack overflow. Trying to set the empty handle
+// as a property on an object results in a NULL pointer dereference in release
+// builds and an assert in debug builds.
+// https://github.com/nodejs/node-v0.x-archive/issues/4015
+
+const assert = require('assert');
+const { exec } = require('child_process');
+
+const cmd =
+ `"${process.execPath}" "${fixturesDir}/test-regress-GH-4015.js"`;
+
+exec(cmd, function(err, stdout, stderr) {
+ assert(/RangeError: Maximum call stack size exceeded/.test(stderr));
+});