mirror of
https://github.com/zebrajr/node.git
synced 2026-01-15 12:15:26 +00:00
diagnostics_channel: fix diagnostics channel memory leak
PR-URL: https://github.com/nodejs/node/pull/45633 Reviewed-By: Stephen Belanger <admin@stephenbelanger.com> Reviewed-By: Yagiz Nizipli <yagiz@nizipli.com> Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Minwoo Jung <nodecorelab@gmail.com> Reviewed-By: Darshan Sen <raisinten@gmail.com>
This commit is contained in:
@@ -122,6 +122,9 @@ function unsubscribe(name, subscription) {
|
||||
}
|
||||
|
||||
channels[name].decRef();
|
||||
if (channels[name].getRef() === 0) {
|
||||
delete channels[name];
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
@@ -265,6 +265,13 @@ void WeakReference::Get(const FunctionCallbackInfo<Value>& args) {
|
||||
args.GetReturnValue().Set(weak_ref->target_.Get(isolate));
|
||||
}
|
||||
|
||||
void WeakReference::GetRef(const FunctionCallbackInfo<Value>& args) {
|
||||
WeakReference* weak_ref = Unwrap<WeakReference>(args.Holder());
|
||||
Isolate* isolate = args.GetIsolate();
|
||||
args.GetReturnValue().Set(
|
||||
v8::Number::New(isolate, weak_ref->reference_count_));
|
||||
}
|
||||
|
||||
void WeakReference::IncRef(const FunctionCallbackInfo<Value>& args) {
|
||||
WeakReference* weak_ref = Unwrap<WeakReference>(args.Holder());
|
||||
weak_ref->reference_count_++;
|
||||
@@ -361,6 +368,7 @@ void RegisterExternalReferences(ExternalReferenceRegistry* registry) {
|
||||
registry->Register(ArrayBufferViewHasBuffer);
|
||||
registry->Register(WeakReference::New);
|
||||
registry->Register(WeakReference::Get);
|
||||
registry->Register(WeakReference::GetRef);
|
||||
registry->Register(WeakReference::IncRef);
|
||||
registry->Register(WeakReference::DecRef);
|
||||
registry->Register(GuessHandleType);
|
||||
@@ -464,6 +472,7 @@ void Initialize(Local<Object> target,
|
||||
WeakReference::kInternalFieldCount);
|
||||
weak_ref->Inherit(BaseObject::GetConstructorTemplate(env));
|
||||
SetProtoMethod(isolate, weak_ref, "get", WeakReference::Get);
|
||||
SetProtoMethod(isolate, weak_ref, "getRef", WeakReference::GetRef);
|
||||
SetProtoMethod(isolate, weak_ref, "incRef", WeakReference::IncRef);
|
||||
SetProtoMethod(isolate, weak_ref, "decRef", WeakReference::DecRef);
|
||||
SetConstructorFunction(context, target, "WeakReference", weak_ref);
|
||||
|
||||
@@ -23,6 +23,7 @@ class WeakReference : public SnapshotableObject {
|
||||
v8::Local<v8::Object> target);
|
||||
static void New(const v8::FunctionCallbackInfo<v8::Value>& args);
|
||||
static void Get(const v8::FunctionCallbackInfo<v8::Value>& args);
|
||||
static void GetRef(const v8::FunctionCallbackInfo<v8::Value>& args);
|
||||
static void IncRef(const v8::FunctionCallbackInfo<v8::Value>& args);
|
||||
static void DecRef(const v8::FunctionCallbackInfo<v8::Value>& args);
|
||||
|
||||
|
||||
24
test/parallel/test-diagnostics-channel-memory-leak.js
Normal file
24
test/parallel/test-diagnostics-channel-memory-leak.js
Normal file
@@ -0,0 +1,24 @@
|
||||
// Flags: --expose-gc
|
||||
'use strict';
|
||||
|
||||
// This test ensures that diagnostic channel references aren't leaked.
|
||||
|
||||
require('../common');
|
||||
const { ok } = require('assert');
|
||||
|
||||
const { subscribe, unsubscribe } = require('diagnostics_channel');
|
||||
|
||||
function noop() {}
|
||||
|
||||
const heapUsedBefore = process.memoryUsage().heapUsed;
|
||||
|
||||
for (let i = 0; i < 1000; i++) {
|
||||
subscribe(String(i), noop);
|
||||
unsubscribe(String(i), noop);
|
||||
}
|
||||
|
||||
global.gc();
|
||||
|
||||
const heapUsedAfter = process.memoryUsage().heapUsed;
|
||||
|
||||
ok(heapUsedBefore >= heapUsedAfter);
|
||||
Reference in New Issue
Block a user