@axe-core/watcher 4.3.0-next.20ff242f → 4.3.0-next.2dedd647

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -35,7 +35,7 @@ SOFTWARE.
35
35
 
36
36
  ## brace-expansion
37
37
 
38
- **Version**: 5.0.5
38
+ **Version**: 5.0.6
39
39
 
40
40
  **License**: MIT
41
41
 
@@ -101,8 +101,70 @@ export const shouldUseEnvProxy = function () {
101
101
  * @property {Object} options - The fetch options.
102
102
  * @property {number} timeout - The timeout in milliseconds.
103
103
  * @property {MessagePort} port - The message port for communication.
104
+ * @property {SharedArrayBuffer} signalBuffer - Used to wake the main thread.
105
+ * Encoding: Int32Array of length 2.
106
+ * [0] wake-reason: 0 = still waiting, 1 = postMessage delivered,
107
+ * 2 = worker died before delivering a message.
108
+ * [1] exit code when [0] === 2; otherwise 0.
104
109
  */
105
- const { url, options, timeout, port } = workerData
110
+ const SIGNAL_WAITING = 0
111
+ const SIGNAL_POSTMESSAGE = 1
112
+ const SIGNAL_DIED = 2
113
+
114
+ const { url, options, timeout, port, signalBuffer } = workerData
115
+ const signalArray = new Int32Array(signalBuffer)
116
+
117
+ /**
118
+ * Wake the main thread, which is blocked in Atomics.wait on signalArray[0].
119
+ * Call after every postMessage so the caller never spins waiting for a
120
+ * message that's already arrived. Idempotent — once signalArray[0] has been
121
+ * set, re-entry is a no-op.
122
+ */
123
+ function notifyMainThread() {
124
+ if (Atomics.load(signalArray, 0) !== SIGNAL_WAITING) {
125
+ return
126
+ }
127
+ Atomics.store(signalArray, 0, SIGNAL_POSTMESSAGE)
128
+ Atomics.notify(signalArray, 0)
129
+ }
130
+
131
+ // Worker-death watchdogs. These run inside the worker thread (unlike
132
+ // worker.on('error') / worker.on('exit') on the parent, which can't fire
133
+ // before syncFetch's synchronous throw because libuv events don't deliver
134
+ // while the main thread is in Atomics.wait or running sync code).
135
+ //
136
+ // They sit between top-level destructuring and the fetch try-block, which
137
+ // means any error originating before this point (bad workerData, broken
138
+ // imports) still falls back to the main thread's plain timeout. That trade
139
+ // is acceptable: catastrophic-startup is rare and unrecoverable.
140
+ process.on('uncaughtException', error => {
141
+ if (Atomics.load(signalArray, 0) !== SIGNAL_WAITING) {
142
+ return
143
+ }
144
+ // Forward through the normal port channel so the caller gets the full
145
+ // error chain. If postMessage itself throws (e.g. error wasn't cloneable),
146
+ // we have no remaining channel to deliver the error — force an exit so
147
+ // the death watchdog below fires synchronously and wakes the parent.
148
+ // Without this, installing an uncaughtException handler suppresses Node's
149
+ // default exit and the parent blocks for the full mainThreadTimeout.
150
+ try {
151
+ const wrapped = new FetchWorkerError({ url: sanitizeUrl(url) })
152
+ wrapped.cause = error
153
+ port.postMessage({ error: wrapped })
154
+ notifyMainThread()
155
+ } catch {
156
+ process.exit(1)
157
+ }
158
+ })
159
+
160
+ process.on('exit', code => {
161
+ if (Atomics.load(signalArray, 0) !== SIGNAL_WAITING) {
162
+ return
163
+ }
164
+ Atomics.store(signalArray, 1, code)
165
+ Atomics.store(signalArray, 0, SIGNAL_DIED)
166
+ Atomics.notify(signalArray, 0)
167
+ })
106
168
 
107
169
  try {
108
170
  let dispatcher = getGlobalDispatcher()
@@ -133,6 +195,7 @@ try {
133
195
  port.postMessage({
134
196
  data: responseData
135
197
  })
198
+ notifyMainThread()
136
199
  } catch (error) {
137
200
  const HTTP_PROXY = process.env.http_proxy || process.env.HTTP_PROXY
138
201
  const HTTPS_PROXY = process.env.https_proxy || process.env.HTTPS_PROXY
@@ -165,6 +228,7 @@ try {
165
228
  port.postMessage({
166
229
  error: err
167
230
  })
231
+ notifyMainThread()
168
232
  } finally {
169
233
  port.close()
170
234
  }
@@ -1,5 +1,13 @@
1
1
  export interface SyncFetchCustomOptions {
2
2
  timeout?: number;
3
+ /**
4
+ * @internal Test-only override for the worker script path. Allows tests to
5
+ * substitute a fixture worker that intentionally dies before notifying, so
6
+ * the in-worker death watchdogs (process.on('uncaughtException') /
7
+ * process.on('exit')) and the signalBuffer-driven timeout error can be
8
+ * exercised end-to-end.
9
+ */
10
+ _workerPath?: string;
3
11
  }
4
12
  export interface SyncFetchResponse {
5
13
  status: number;
@@ -9,3 +17,27 @@ export interface SyncFetchResponse {
9
17
  ok: boolean;
10
18
  }
11
19
  export declare function syncFetch(url: string, options?: RequestInit, customOptions?: SyncFetchCustomOptions): SyncFetchResponse;
20
+ /**
21
+ * Wake-reason values written to `signalArray[0]` by sync-fetch-worker.mjs.
22
+ *
23
+ * @internal Exported for tests.
24
+ */
25
+ export declare const SIGNAL_WAITING = 0;
26
+ /** @internal */
27
+ export declare const SIGNAL_POSTMESSAGE = 1;
28
+ /** @internal */
29
+ export declare const SIGNAL_DIED = 2;
30
+ /**
31
+ * Build the diagnostic Error thrown when the worker fails to deliver a message
32
+ * before the main-thread timeout. When the worker's death-watchdog fired
33
+ * (`wakeReason === SIGNAL_DIED`) the exit code is folded into the message so
34
+ * the failure is debuggable instead of opaque. Otherwise the wait simply
35
+ * timed out and we report the plain timeout.
36
+ *
37
+ * @internal Exported for tests.
38
+ */
39
+ export declare function buildTimeoutError(args: {
40
+ mainThreadTimeout: number;
41
+ wakeReason: number;
42
+ exitCode: number;
43
+ }): Error;
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SIGNAL_DIED = exports.SIGNAL_POSTMESSAGE = exports.SIGNAL_WAITING = void 0;
3
4
  exports.syncFetch = syncFetch;
5
+ exports.buildTimeoutError = buildTimeoutError;
4
6
  const node_worker_threads_1 = require("node:worker_threads");
5
7
  const node_path_1 = require("node:path");
6
8
  function syncFetch(url, options = {}, customOptions = {
@@ -10,28 +12,34 @@ function syncFetch(url, options = {}, customOptions = {
10
12
  const processingBuffer = 3000;
11
13
  const mainThreadTimeout = timeout + processingBuffer;
12
14
  const { port1, port2 } = new node_worker_threads_1.MessageChannel();
13
- const sleepBuffer = new SharedArrayBuffer(4);
14
- const sleepArray = new Int32Array(sleepBuffer);
15
- const worker = new node_worker_threads_1.Worker((0, node_path_1.join)(__dirname, 'sync-fetch-worker.mjs'), {
15
+ const signalBuffer = new SharedArrayBuffer(8);
16
+ const signalArray = new Int32Array(signalBuffer);
17
+ const workerPath = customOptions._workerPath ?? (0, node_path_1.join)(__dirname, 'sync-fetch-worker.mjs');
18
+ const worker = new node_worker_threads_1.Worker(workerPath, {
16
19
  name: 'sync-fetch',
17
20
  eval: false,
18
21
  workerData: {
19
22
  url,
20
23
  options,
21
24
  timeout,
22
- port: port2
25
+ port: port2,
26
+ signalBuffer
23
27
  },
24
28
  transferList: [port2]
25
29
  });
26
- const { startTime } = performance.mark('axe-watcher:sync-fetch:start');
30
+ worker.on('error', () => {
31
+ });
32
+ performance.mark('axe-watcher:sync-fetch:start');
27
33
  let message;
28
34
  try {
29
- while (message === undefined) {
30
- if (performance.now() - startTime > mainThreadTimeout) {
31
- throw new Error(`Request timed out - worker thread did not respond within ${mainThreadTimeout}ms`);
32
- }
33
- Atomics.wait(sleepArray, 0, 0, 5);
34
- message = (0, node_worker_threads_1.receiveMessageOnPort)(port1);
35
+ Atomics.wait(signalArray, 0, 0, mainThreadTimeout);
36
+ message = (0, node_worker_threads_1.receiveMessageOnPort)(port1);
37
+ if (message === undefined) {
38
+ throw buildTimeoutError({
39
+ mainThreadTimeout,
40
+ wakeReason: Atomics.load(signalArray, 0),
41
+ exitCode: Atomics.load(signalArray, 1)
42
+ });
35
43
  }
36
44
  const { data, error } = message.message;
37
45
  if (error) {
@@ -63,6 +71,16 @@ function syncFetch(url, options = {}, customOptions = {
63
71
  });
64
72
  }
65
73
  }
74
+ exports.SIGNAL_WAITING = 0;
75
+ exports.SIGNAL_POSTMESSAGE = 1;
76
+ exports.SIGNAL_DIED = 2;
77
+ function buildTimeoutError(args) {
78
+ const { mainThreadTimeout, wakeReason, exitCode } = args;
79
+ const reason = wakeReason === exports.SIGNAL_DIED
80
+ ? `worker exited with code ${exitCode} before responding`
81
+ : `worker thread did not respond within ${mainThreadTimeout}ms`;
82
+ return new Error(`Request timed out - ${reason}`);
83
+ }
66
84
  function sanitizeHeaders(headers) {
67
85
  if (!headers) {
68
86
  return undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"sync-fetch.js","sourceRoot":"","sources":["../../src/utils/sync-fetch.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sync-fetch.js","sourceRoot":"","sources":["../../src/utils/sync-fetch.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ function a1_0xea81(_0x1d9baa,_0x1a3a3d){_0x1d9baa=_0x1d9baa-(-0x389*0x9+-0x8b*0x32+-0x8e*-0x6d);var _0x45a93f=a1_0x35ce();var _0x564f2c=_0x45a93f[_0x1d9baa];return _0x564f2c;}(function(_0x340231,_0x11e2f9){var _0x58293d=a1_0xea81,_0x15285b=_0x340231();while(!![]){try{var _0x35a84a=-parseInt(_0x58293d(0x1a0))/(0x733+0x2181*0x1+-0x28b3)*(-parseInt(_0x58293d(0x18a))/(0x5*-0x1+-0x2*0x2c5+0x3*0x1db))+-parseInt(_0x58293d(0x19c))/(-0x4*-0x2f7+-0xc42*-0x1+-0x3*0x809)+-parseInt(_0x58293d(0x191))/(-0x93a*-0x1+-0x1900+0xfca)+-parseInt(_0x58293d(0x1a2))/(0x2497+0xd39+0x7*-0x71d)+parseInt(_0x58293d(0x18f))/(0x5*-0x4a7+0xeda+0x86f)+parseInt(_0x58293d(0x185))/(-0x305+-0x3c1*-0x2+-0x476)*(-parseInt(_0x58293d(0x1a6))/(0x3*-0x5f0+-0x1056+0x222e))+parseInt(_0x58293d(0x19d))/(0xda0+-0xbb3+-0x1e4)*(parseInt(_0x58293d(0x19f))/(-0x2*0xee8+-0x1500+0x32da));if(_0x35a84a===_0x11e2f9)break;else _0x15285b['push'](_0x15285b['shift']());}catch(_0x15b097){_0x15285b['push'](_0x15285b['shift']());}}}(a1_0x35ce,-0x6f26e+-0x5*-0x33a1+0xa0f24),((()=>{var _0x5b9c72=a1_0xea81,_0x5d852c={'FvhNS':_0x5b9c72(0x187),'iUrnU':function(_0x421ba5,_0x57c148){return _0x421ba5(_0x57c148);},'ASzwd':function(_0x6f7535,_0x4c6754){return _0x6f7535(_0x4c6754);},'LBbyq':function(_0x1f3557,_0x4ce128){return _0x1f3557(_0x4ce128);},'zrjMi':_0x5b9c72(0x183)+_0x5b9c72(0x1a8)+'nd','SWVeC':function(_0x388f5f,_0x333cbe){return _0x388f5f(_0x333cbe);},'ZaVrz':_0x5b9c72(0x1a7)+_0x5b9c72(0x199)+_0x5b9c72(0x19a),'NGocy':function(_0x2e398f,_0x2cd6f6){return _0x2e398f!==_0x2cd6f6;}},_0x4b57a1={0x8a5(_0x5f29ed,_0x32de1b,_0x461113){'use strict';var _0xdec4e1=_0x5b9c72;var _0x5a5859=this&&this[_0xdec4e1(0x18e)+_0xdec4e1(0x195)]||function(_0x1a94dc){var _0x473701=_0xdec4e1;return _0x1a94dc&&_0x1a94dc[_0x473701(0x187)]?_0x1a94dc:{'default':_0x1a94dc};};Object[_0xdec4e1(0x198)+_0xdec4e1(0x19e)](_0x32de1b,_0x5d852c[_0xdec4e1(0x18c)],{'value':!(0x197b*0x1+0x1bdf+-0x355a)}),_0x5d852c[_0xdec4e1(0x186)](_0x461113,-0x2*-0xd3b+0x2*0x601+0x1ecf*-0x1);const _0xc6712=(0x13a5*0x1+0x26bf+-0x3a64,_0x5d852c[_0xdec4e1(0x18d)](_0x5a5859,_0x5d852c[_0xdec4e1(0x180)](_0x461113,-0x57b*0x1+-0x1273+0x2d9c))[_0xdec4e1(0x193)])(_0x5d852c[_0xdec4e1(0x1a4)]);chrome[_0xdec4e1(0x181)][_0xdec4e1(0x192)][_0xdec4e1(0x1a3)+'r']((_0x29074f,_0x157114)=>!(!_0x29074f||_0xdec4e1(0x184)!=typeof _0x29074f||!(_0xdec4e1(0x189)in _0x29074f)||(_0xc6712(_0xdec4e1(0x194)+_0xdec4e1(0x1a5),{'action':_0x29074f[_0xdec4e1(0x189)],'tabId':_0x157114[_0xdec4e1(0x188)]?.['id']}),_0x29074f[_0xdec4e1(0x189)],_0xc6712(_0xdec4e1(0x190)+_0xdec4e1(0x17f),_0x29074f[_0xdec4e1(0x189)]),0xfb*0x1d+-0x112+0x67*-0x44))),_0x5d852c[_0xdec4e1(0x18b)](_0xc6712,_0x5d852c[_0xdec4e1(0x19b)]);},0x15ae(_0x59b298,_0x4de700){'use strict';var _0xd241cb=_0x5b9c72;Object[_0xd241cb(0x198)+_0xd241cb(0x19e)](_0x4de700,_0x5d852c[_0xd241cb(0x18c)],{'value':!(0x1ece+0xea*0x1+-0x1fb8)}),_0x4de700[_0xd241cb(0x193)]=_0x715802=>(Date[_0xd241cb(0x1a1)](),(_0x3bb098,_0x122a79)=>{});},0x7a9(){}},_0x391c11={};!function _0x2ddb2d(_0x4a83c8){var _0x419092=_0x5b9c72,_0xbc5ba1=_0x391c11[_0x4a83c8];if(_0x5d852c[_0x419092(0x196)](void(0x1*-0x1b25+0x1*0xe4b+0xcda),_0xbc5ba1))return _0xbc5ba1[_0x419092(0x197)];var _0x2cd928=_0x391c11[_0x4a83c8]={'exports':{}};return _0x4b57a1[_0x4a83c8][_0x419092(0x182)](_0x2cd928[_0x419092(0x197)],_0x2cd928,_0x2cd928[_0x419092(0x197)],_0x2ddb2d),_0x2cd928[_0x419092(0x197)];}(-0xbf9+0x17*-0x19f+-0x134d*-0x3);})()));function a1_0x35ce(){var _0x38cd2d=['runtime','call','axe-watche','object','201313AGZRNh','iUrnU','__esModule','tab','action','2bZpXOY','SWVeC','FvhNS','ASzwd','__importDe','289392NzVlWF','Unknown\x20ac','1613836HOmCYE','onMessage','default','Received\x20m','fault','NGocy','exports','defineProp','rker\x20initi','alized','ZaVrz','88980FFEgNZ','4589928CCsUfP','erty','20OjslXb','471243KjwDTX','now','2599740gVwvGr','addListene','zrjMi','essage','88RiLDzR','Service\x20wo','r:backgrou','tion','LBbyq'];a1_0x35ce=function(){return _0x38cd2d;};return a1_0x35ce();}
@@ -0,0 +1 @@
1
+ /*! Copyright Deque 2021-2026 All Rights Reserved */