summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/handle_wrap.cc6
-rw-r--r--src/handle_wrap.h2
-rw-r--r--src/pipe_wrap.cc2
-rw-r--r--src/process_wrap.cc2
-rw-r--r--src/signal_wrap.cc2
-rw-r--r--src/tcp_wrap.cc2
-rw-r--r--src/timer_wrap.cc2
-rw-r--r--src/tty_wrap.cc2
-rw-r--r--src/udp_wrap.cc2
-rw-r--r--test/parallel/test-handle-wrap-isrefed-tty.js10
-rw-r--r--test/parallel/test-handle-wrap-isrefed.js74
11 files changed, 57 insertions, 49 deletions
diff --git a/src/handle_wrap.cc b/src/handle_wrap.cc
index 7a7ce8ae26..8421d694a9 100644
--- a/src/handle_wrap.cc
+++ b/src/handle_wrap.cc
@@ -37,11 +37,11 @@ void HandleWrap::Unref(const FunctionCallbackInfo<Value>& args) {
}
-void HandleWrap::IsRefed(const FunctionCallbackInfo<Value>& args) {
+void HandleWrap::Unrefed(const FunctionCallbackInfo<Value>& args) {
HandleWrap* wrap = Unwrap<HandleWrap>(args.Holder());
- bool refed = IsAlive(wrap) && (wrap->flags_ & kUnref) == 0;
- args.GetReturnValue().Set(refed);
+ bool unrefed = wrap->flags_ & kUnref == 1;
+ args.GetReturnValue().Set(unrefed);
}
diff --git a/src/handle_wrap.h b/src/handle_wrap.h
index cb3ba3f5d5..d945143d31 100644
--- a/src/handle_wrap.h
+++ b/src/handle_wrap.h
@@ -35,7 +35,7 @@ class HandleWrap : public AsyncWrap {
static void Close(const v8::FunctionCallbackInfo<v8::Value>& args);
static void Ref(const v8::FunctionCallbackInfo<v8::Value>& args);
static void Unref(const v8::FunctionCallbackInfo<v8::Value>& args);
- static void IsRefed(const v8::FunctionCallbackInfo<v8::Value>& args);
+ static void Unrefed(const v8::FunctionCallbackInfo<v8::Value>& args);
static inline bool IsAlive(const HandleWrap* wrap) {
return wrap != nullptr && wrap->GetHandle() != nullptr;
diff --git a/src/pipe_wrap.cc b/src/pipe_wrap.cc
index 25080041c2..43df5cb715 100644
--- a/src/pipe_wrap.cc
+++ b/src/pipe_wrap.cc
@@ -80,7 +80,7 @@ void PipeWrap::Initialize(Local<Object> target,
env->SetProtoMethod(t, "close", HandleWrap::Close);
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
- env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
StreamWrap::AddMethods(env, t);
diff --git a/src/process_wrap.cc b/src/process_wrap.cc
index 0b7ad41b61..b804d9f35e 100644
--- a/src/process_wrap.cc
+++ b/src/process_wrap.cc
@@ -40,7 +40,7 @@ class ProcessWrap : public HandleWrap {
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
- env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
target->Set(FIXED_ONE_BYTE_STRING(env->isolate(), "Process"),
constructor->GetFunction());
diff --git a/src/signal_wrap.cc b/src/signal_wrap.cc
index ca5201d81a..a008b083f0 100644
--- a/src/signal_wrap.cc
+++ b/src/signal_wrap.cc
@@ -32,7 +32,7 @@ class SignalWrap : public HandleWrap {
env->SetProtoMethod(constructor, "close", HandleWrap::Close);
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
- env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
env->SetProtoMethod(constructor, "start", Start);
env->SetProtoMethod(constructor, "stop", Stop);
diff --git a/src/tcp_wrap.cc b/src/tcp_wrap.cc
index 4e8617af2d..d1cc99e756 100644
--- a/src/tcp_wrap.cc
+++ b/src/tcp_wrap.cc
@@ -87,7 +87,7 @@ void TCPWrap::Initialize(Local<Object> target,
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
- env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
StreamWrap::AddMethods(env, t, StreamBase::kFlagHasWritev);
diff --git a/src/timer_wrap.cc b/src/timer_wrap.cc
index 4a1cd3716a..b2c41ebf73 100644
--- a/src/timer_wrap.cc
+++ b/src/timer_wrap.cc
@@ -39,7 +39,7 @@ class TimerWrap : public HandleWrap {
env->SetProtoMethod(constructor, "close", HandleWrap::Close);
env->SetProtoMethod(constructor, "ref", HandleWrap::Ref);
env->SetProtoMethod(constructor, "unref", HandleWrap::Unref);
- env->SetProtoMethod(constructor, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(constructor, "unrefed", HandleWrap::Unrefed);
env->SetProtoMethod(constructor, "start", Start);
env->SetProtoMethod(constructor, "stop", Stop);
diff --git a/src/tty_wrap.cc b/src/tty_wrap.cc
index 5a1d333c3d..e7acedd27a 100644
--- a/src/tty_wrap.cc
+++ b/src/tty_wrap.cc
@@ -36,7 +36,7 @@ void TTYWrap::Initialize(Local<Object> target,
env->SetProtoMethod(t, "close", HandleWrap::Close);
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
- env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
StreamWrap::AddMethods(env, t, StreamBase::kFlagNoShutdown);
diff --git a/src/udp_wrap.cc b/src/udp_wrap.cc
index ac087f395a..b5f3a3cf54 100644
--- a/src/udp_wrap.cc
+++ b/src/udp_wrap.cc
@@ -108,7 +108,7 @@ void UDPWrap::Initialize(Local<Object> target,
env->SetProtoMethod(t, "ref", HandleWrap::Ref);
env->SetProtoMethod(t, "unref", HandleWrap::Unref);
- env->SetProtoMethod(t, "isRefed", HandleWrap::IsRefed);
+ env->SetProtoMethod(t, "unrefed", HandleWrap::Unrefed);
target->Set(FIXED_ONE_BYTE_STRING(env->isolate(), "UDP"), t->GetFunction());
env->set_udp_constructor_function(t->GetFunction());
diff --git a/test/parallel/test-handle-wrap-isrefed-tty.js b/test/parallel/test-handle-wrap-isrefed-tty.js
index 9656fe06ee..4c31d63b52 100644
--- a/test/parallel/test-handle-wrap-isrefed-tty.js
+++ b/test/parallel/test-handle-wrap-isrefed-tty.js
@@ -9,16 +9,18 @@ function makeAssert(message) {
strictEqual(actual, expected, message);
};
}
-const assert = makeAssert('isRefed() not working on tty_wrap');
+const assert = makeAssert('unrefed() not working on tty_wrap');
if (process.argv[2] === 'child') {
// Test tty_wrap in piped child to guarentee stdin being a TTY.
const ReadStream = require('tty').ReadStream;
const tty = new ReadStream(0);
- assert(Object.getPrototypeOf(tty._handle).hasOwnProperty('isRefed'), true);
- assert(tty._handle.isRefed(), true);
+ assert(Object.getPrototypeOf(tty._handle).hasOwnProperty('unrefed'), true);
+ assert(tty._handle.unrefed(), false);
tty.unref();
- assert(tty._handle.isRefed(), false);
+ assert(tty._handle.unrefed(), true);
+ tty._handle.close();
+ assert(tty._handle.unrefed(), true);
return;
}
diff --git a/test/parallel/test-handle-wrap-isrefed.js b/test/parallel/test-handle-wrap-isrefed.js
index cd828aa1c4..c88534117c 100644
--- a/test/parallel/test-handle-wrap-isrefed.js
+++ b/test/parallel/test-handle-wrap-isrefed.js
@@ -12,86 +12,92 @@ function makeAssert(message) {
// child_process
{
- const assert = makeAssert('isRefed() not working on process_wrap');
+ const assert = makeAssert('unrefed() not working on process_wrap');
const spawn = require('child_process').spawn;
const cmd = common.isWindows ? 'rundll32' : 'ls';
const cp = spawn(cmd);
- assert(Object.getPrototypeOf(cp._handle).hasOwnProperty('isRefed'), true);
- assert(cp._handle.isRefed(), true);
+ assert(Object.getPrototypeOf(cp._handle).hasOwnProperty('unrefed'), true);
+ assert(cp._handle.unrefed(), false);
cp.unref();
- assert(cp._handle.isRefed(), false);
+ assert(cp._handle.unrefed(), true);
cp.ref();
- assert(cp._handle.isRefed(), true);
- cp.unref();
+ assert(cp._handle.unrefed(), false);
+ cp._handle.close();
+ assert(cp._handle.unrefed(), false);
}
// dgram
{
- const assert = makeAssert('isRefed() not working on udp_wrap');
+ const assert = makeAssert('unrefed() not working on udp_wrap');
const dgram = require('dgram');
const sock4 = dgram.createSocket('udp4');
- assert(Object.getPrototypeOf(sock4._handle).hasOwnProperty('isRefed'), true);
- assert(sock4._handle.isRefed(), true);
+ assert(Object.getPrototypeOf(sock4._handle).hasOwnProperty('unrefed'), true);
+ assert(sock4._handle.unrefed(), false);
sock4.unref();
- assert(sock4._handle.isRefed(), false);
+ assert(sock4._handle.unrefed(), true);
sock4.ref();
- assert(sock4._handle.isRefed(), true);
- sock4.unref();
+ assert(sock4._handle.unrefed(), false);
+ sock4._handle.close();
+ assert(sock4._handle.unrefed(), false);
const sock6 = dgram.createSocket('udp6');
- assert(Object.getPrototypeOf(sock6._handle).hasOwnProperty('isRefed'), true);
- assert(sock6._handle.isRefed(), true);
+ assert(Object.getPrototypeOf(sock6._handle).hasOwnProperty('unrefed'), true);
+ assert(sock6._handle.unrefed(), false);
sock6.unref();
- assert(sock6._handle.isRefed(), false);
+ assert(sock6._handle.unrefed(), true);
sock6.ref();
- assert(sock6._handle.isRefed(), true);
- sock6.unref();
+ assert(sock6._handle.unrefed(), false);
+ sock6._handle.close();
+ assert(sock6._handle.unrefed(), false);
}
// pipe
{
- const assert = makeAssert('isRefed() not working on pipe_wrap');
+ const assert = makeAssert('unrefed() not working on pipe_wrap');
const Pipe = process.binding('pipe_wrap').Pipe;
const handle = new Pipe();
- assert(Object.getPrototypeOf(handle).hasOwnProperty('isRefed'), true);
- assert(handle.isRefed(), true);
+ assert(Object.getPrototypeOf(handle).hasOwnProperty('unrefed'), true);
+ assert(handle.unrefed(), false);
handle.unref();
- assert(handle.isRefed(), false);
+ assert(handle.unrefed(), true);
handle.ref();
- assert(handle.isRefed(), true);
- handle.unref();
+ assert(handle.unrefed(), false);
+ handle.close();
+ assert(handle.unrefed(), false);
}
// tcp
{
- const assert = makeAssert('isRefed() not working on tcp_wrap');
+ const assert = makeAssert('unrefed() not working on tcp_wrap');
const net = require('net');
const server = net.createServer(() => {}).listen(common.PORT);
- assert(Object.getPrototypeOf(server._handle).hasOwnProperty('isRefed'), true);
- assert(server._handle.isRefed(), true);
+ assert(Object.getPrototypeOf(server._handle).hasOwnProperty('unrefed'), true);
+ assert(server._handle.unrefed(), false);
assert(server._unref, false);
server.unref();
- assert(server._handle.isRefed(), false);
+ assert(server._handle.unrefed(), true);
assert(server._unref, true);
server.ref();
- assert(server._handle.isRefed(), true);
+ assert(server._handle.unrefed(), false);
assert(server._unref, false);
- server.unref();
+ server._handle.close();
+ assert(server._handle.unrefed(), false);
}
// timers
{
- const assert = makeAssert('isRefed() not working on timer_wrap');
+ const assert = makeAssert('unrefed() not working on timer_wrap');
const timer = setTimeout(() => {}, 500);
timer.unref();
- assert(Object.getPrototypeOf(timer._handle).hasOwnProperty('isRefed'), true);
- assert(timer._handle.isRefed(), false);
+ assert(Object.getPrototypeOf(timer._handle).hasOwnProperty('unrefed'), true);
+ assert(timer._handle.unrefed(), true);
timer.ref();
- assert(timer._handle.isRefed(), true);
- timer.unref();
+ assert(timer._handle.unrefed(), false);
+ timer.close();
+ assert(timer._handle.unrefed(), false);
}