Skip to content

Commit c028d21

Browse files
simon-idaduh95
authored andcommitted
diagnostics_channel: fix unsubscribe during publish
PR-URL: #55116 Reviewed-By: Stephen Belanger <admin@stephenbelanger.com> Reviewed-By: Claudio Wunder <cwunder@gnome.org>
1 parent 8ceefeb commit c028d21

File tree

2 files changed

+11
-3
lines changed

2 files changed

+11
-3
lines changed

lib/diagnostics_channel.js

Lines changed: 10 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,8 @@ const {
44
ArrayPrototypeAt,
55
ArrayPrototypeIndexOf,
66
ArrayPrototypePush,
7+
ArrayPrototypePushApply,
8+
ArrayPrototypeSlice,
79
ArrayPrototypeSplice,
810
ObjectDefineProperty,
911
ObjectGetPrototypeOf,
@@ -97,6 +99,7 @@ function wrapStoreRun(store, data, next, transform = defaultTransform) {
9799
class ActiveChannel {
98100
subscribe(subscription) {
99101
validateFunction(subscription, 'subscription');
102+
this._subscribers = ArrayPrototypeSlice(this._subscribers);
100103
ArrayPrototypePush(this._subscribers, subscription);
101104
channels.incRef(this.name);
102105
}
@@ -105,7 +108,10 @@ class ActiveChannel {
105108
const index = ArrayPrototypeIndexOf(this._subscribers, subscription);
106109
if (index === -1) return false;
107110

108-
ArrayPrototypeSplice(this._subscribers, index, 1);
111+
const before = ArrayPrototypeSlice(this._subscribers, 0, index);
112+
const after = ArrayPrototypeSlice(this._subscribers, index + 1);
113+
this._subscribers = before;
114+
ArrayPrototypePushApply(this._subscribers, after);
109115

110116
channels.decRef(this.name);
111117
maybeMarkInactive(this);
@@ -137,9 +143,10 @@ class ActiveChannel {
137143
}
138144

139145
publish(data) {
140-
for (let i = 0; i < (this._subscribers?.length || 0); i++) {
146+
const subscribers = this._subscribers;
147+
for (let i = 0; i < (subscribers?.length || 0); i++) {
141148
try {
142-
const onMessage = this._subscribers[i];
149+
const onMessage = subscribers[i];
143150
onMessage(data, this.name);
144151
} catch (err) {
145152
process.nextTick(() => {

test/parallel/test-diagnostics-channel-sync-unsubscribe.js

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,7 @@ const published_data = 'some message';
99
const onMessageHandler = common.mustCall(() => dc.unsubscribe(channel_name, onMessageHandler));
1010

1111
dc.subscribe(channel_name, onMessageHandler);
12+
dc.subscribe(channel_name, common.mustCall());
1213

1314
// This must not throw.
1415
dc.channel(channel_name).publish(published_data);

0 commit comments

Comments
 (0)
pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy