aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorSam Roberts <sam@strongloop.com>2014-07-23 14:22:22 -0700
committerFedor Indutny <fedor@indutny.com>2014-07-28 18:30:26 +0400
commit832ec1cd507ed344badd2ed97d3da92975650a95 (patch)
tree5e89adade63db2faa4a62ba2a59a85c8af05b0fe /test
parent9a63a1d89b5a2a015eadd5ef5d7e42039858c5ae (diff)
downloadandroid-node-v8-832ec1cd507ed344badd2ed97d3da92975650a95.tar.gz
android-node-v8-832ec1cd507ed344badd2ed97d3da92975650a95.tar.bz2
android-node-v8-832ec1cd507ed344badd2ed97d3da92975650a95.zip
process: throw TypeError if kill pid not a number
Currently, invalid usage such as: process.kill('SIGTERM') process.kill(null) process.kill(undefined); all coerce the pid to 0, and signal the current process. Signed-off-by: Fedor Indutny <fedor@indutny.com>
Diffstat (limited to 'test')
-rw-r--r--test/simple/test-process-kill-pid.js64
1 files changed, 64 insertions, 0 deletions
diff --git a/test/simple/test-process-kill-pid.js b/test/simple/test-process-kill-pid.js
new file mode 100644
index 0000000000..af65b64718
--- /dev/null
+++ b/test/simple/test-process-kill-pid.js
@@ -0,0 +1,64 @@
+// 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.
+
+
+var common = require('../common');
+var assert = require('assert');
+
+var pass;
+var wait = setInterval(function(){}, 1000);
+
+process.on('exit', function(code) {
+ if (code === 0) {
+ assert.ok(pass);
+ }
+});
+
+// test variants of pid
+//
+// null: TypeError
+// undefined: TypeError
+//
+// 'SIGTERM': TypeError
+//
+// String(process.pid): TypeError
+//
+// Nan, Infinity, -Infinity: TypeError
+//
+// 0, process.pid: ourself
+
+assert.throws(function() { process.kill('SIGTERM'); }, TypeError);
+assert.throws(function() { process.kill(String(process.pid)); }, TypeError);
+assert.throws(function() { process.kill(null); }, TypeError);
+assert.throws(function() { process.kill(undefined); }, TypeError);
+assert.throws(function() { process.kill(+'not a number'); }, TypeError);
+assert.throws(function() { process.kill(1/0); }, TypeError);
+assert.throws(function() { process.kill(-1/0); }, TypeError);
+
+process.once('SIGHUP', function() {
+ process.once('SIGHUP', function() {
+ pass = true;
+ clearInterval(wait);
+ });
+ process.kill(process.pid, 'SIGHUP');
+});
+
+process.kill(0, 'SIGHUP');