@nsshunt/stsrunnerframework 1.0.158 → 1.0.160

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.
@@ -1550,6 +1550,7 @@ class WorkerInstance {
1550
1550
  }
1551
1551
  if (removeList.length > 0) {
1552
1552
  setTimeout(() => {
1553
+ __privateGet(this, _debug).call(this, chalk.grey(`WorkerInstance:#processLoopExecutor(): Removing runners from collection: [${removeList}]`));
1553
1554
  for (let i = 0; i < removeList.length; i++) {
1554
1555
  __privateGet(this, _runners)[removeList[i]].archived = true;
1555
1556
  if (__privateGet(this, _archiveDeleteTimeout) !== 0) {
@@ -1560,6 +1561,7 @@ class WorkerInstance {
1560
1561
  }
1561
1562
  }
1562
1563
  }
1564
+ __privateGet(this, _debug).call(this, chalk.grey(`WorkerInstance:#processLoopExecutor(): Remaining Runner Count: [${Object.keys(__privateGet(this, _runners)).length}]`));
1563
1565
  setTimeout(__privateGet(this, _processLoopExecutor), 1e3);
1564
1566
  }, 100);
1565
1567
  } else {
@@ -1581,9 +1583,11 @@ class WorkerInstance {
1581
1583
  __privateSet(this, _collectorCollectorPort, workerMessagePort.port);
1582
1584
  if (isNode) {
1583
1585
  __privateGet(this, _collectorCollectorPort).on("message", (data) => {
1586
+ __privateGet(this, _debug).call(this, `collectorCollectorPort on('message'): ${JSON.stringify(data)}`);
1584
1587
  });
1585
1588
  } else {
1586
1589
  __privateGet(this, _collectorCollectorPort).addEventListener("message", (data) => {
1590
+ __privateGet(this, _debug).call(this, `collectorCollectorPort addEventListener('message'): ${JSON.stringify(data.data)}`);
1587
1591
  });
1588
1592
  }
1589
1593
  const response = {
@@ -2016,8 +2020,10 @@ class WorkerInstance {
2016
2020
  const { state } = __privateGet(this, _runners)[runnerId].runner;
2017
2021
  if (state === IRunnerState.paused || state === IRunnerState.created) {
2018
2022
  const currentIteration = __privateGet(this, _GetRunnerIterationById).call(this, runnerId);
2023
+ __privateGet(this, _debug).call(this, `${chalk.magenta(`runner: [${runnerId}]`)} ExecuteRunner(${currentIteration})`);
2019
2024
  result = await ((_a = __privateGet(this, _GetRunnerInstanceById).call(this, runnerId)) == null ? void 0 : _a.ExecuteRunner());
2020
2025
  const newIteration = __privateGet(this, _IncRunnerIterationById).call(this, runnerId);
2026
+ __privateGet(this, _debug).call(this, `${chalk.magenta(` --> runner: [${runnerId}]`)} Next iteration number: [${newIteration}] for next Execute or Resume.`);
2021
2027
  __privateGet(this, _UpdateRunnerStateById).call(this, runnerId, IRunnerState.paused);
2022
2028
  }
2023
2029
  } else {
@@ -2036,7 +2042,9 @@ class WorkerInstance {
2036
2042
  if (__privateGet(this, _runners)[runnerId]) {
2037
2043
  const { state } = __privateGet(this, _runners)[runnerId].runner;
2038
2044
  if (state === IRunnerState.paused || state === IRunnerState.created || state === IRunnerState.running) {
2045
+ __privateGet(this, _debug).call(this, chalk.cyan(`before: [${JSON.stringify(__privateGet(this, _GetRunnerOptionsById).call(this, runnerId))}]`));
2039
2046
  __privateGet(this, _SetRunnerOptionsById).call(this, runnerId, testRunnerTelemetryPayload.runner.options);
2047
+ __privateGet(this, _debug).call(this, chalk.cyan(`after: [${JSON.stringify(__privateGet(this, _GetRunnerOptionsById).call(this, runnerId))}]`));
2040
2048
  result = await ((_a = __privateGet(this, _GetRunnerInstanceById).call(this, runnerId)) == null ? void 0 : _a.UpdateRunner(testRunnerTelemetryPayload.runner.options));
2041
2049
  }
2042
2050
  } else {
@@ -2049,6 +2057,7 @@ class WorkerInstance {
2049
2057
  });
2050
2058
  // ProcessMessage = async(data: MessageEvent) => { // Browser version
2051
2059
  __publicField(this, "ProcessMessage", async (data) => {
2060
+ __privateGet(this, _debug).call(this, `ProcessMessage: data: [${JSON.stringify(data)}]`);
2052
2061
  try {
2053
2062
  const payloadMessage = data;
2054
2063
  switch (payloadMessage.command) {
@@ -2056,35 +2065,47 @@ class WorkerInstance {
2056
2065
  __privateGet(this, _SetMessagePort).call(this, payloadMessage.payload);
2057
2066
  __privateSet(this, _options, payloadMessage.payload.options);
2058
2067
  __privateSet(this, _workerId, payloadMessage.payload.workerId);
2068
+ __privateGet(this, _debug).call(this, `ProcessMessage::#workerId: [${__privateGet(this, _workerId)}]`);
2069
+ __privateGet(this, _debug).call(this, `ProcessMessage::#options: [${JSON.stringify(__privateGet(this, _options))}]`);
2059
2070
  break;
2060
2071
  case eIWMessageCommands.AddRunner:
2072
+ __privateGet(this, _debug).call(this, `ProcessMessage::AddRunner`);
2061
2073
  __privateGet(this, _AddRunner).call(this, payloadMessage.payload);
2062
2074
  break;
2063
2075
  case eIWMessageCommands.StartRunner:
2076
+ __privateGet(this, _debug).call(this, `ProcessMessage::StartRunner`);
2064
2077
  __privateGet(this, _StartRunner).call(this, payloadMessage.payload);
2065
2078
  break;
2066
2079
  case eIWMessageCommands.StopRunner:
2080
+ __privateGet(this, _debug).call(this, `ProcessMessage::StopRunner`);
2067
2081
  __privateGet(this, _StopRunner).call(this, payloadMessage.payload);
2068
2082
  break;
2069
2083
  case eIWMessageCommands.TerminateRunner:
2084
+ __privateGet(this, _debug).call(this, `ProcessMessage::TerminateRunner`);
2070
2085
  __privateGet(this, _TerminateRunner).call(this, payloadMessage.payload);
2071
2086
  break;
2072
2087
  case eIWMessageCommands.PauseRunner:
2088
+ __privateGet(this, _debug).call(this, `ProcessMessage::PauseRunner`);
2073
2089
  __privateGet(this, _PauseRunner).call(this, payloadMessage.payload);
2074
2090
  break;
2075
2091
  case eIWMessageCommands.ResumeRunner:
2092
+ __privateGet(this, _debug).call(this, `ProcessMessage::ResumeRunner`);
2076
2093
  __privateGet(this, _ResumeRunner).call(this, payloadMessage.payload);
2077
2094
  break;
2078
2095
  case eIWMessageCommands.ResetRunner:
2096
+ __privateGet(this, _debug).call(this, `ProcessMessage::ResetRunner`);
2079
2097
  __privateGet(this, _ResetRunner).call(this, payloadMessage.payload);
2080
2098
  break;
2081
2099
  case eIWMessageCommands.ExecuteRunner:
2100
+ __privateGet(this, _debug).call(this, `ProcessMessage::ExecuteRunner`);
2082
2101
  __privateGet(this, _ExecuteRunner).call(this, payloadMessage.payload);
2083
2102
  break;
2084
2103
  case eIWMessageCommands.UpdateRunner:
2104
+ __privateGet(this, _debug).call(this, `ProcessMessage::UpdateRunner`);
2085
2105
  __privateGet(this, _UpdateRunner).call(this, payloadMessage.payload);
2086
2106
  break;
2087
2107
  case eIWMessageCommands.GetRunners:
2108
+ __privateGet(this, _debug).call(this, `ProcessMessage::GetRunners`);
2088
2109
  __privateGet(this, _PostRunnersToWorkerManager).call(this, eIWMessageCommands.GetRunners, payloadMessage);
2089
2110
  break;
2090
2111
  default:
@@ -2329,21 +2350,25 @@ class STSWorkerManager {
2329
2350
  }
2330
2351
  if (removeList.length > 0) {
2331
2352
  setTimeout(async () => {
2353
+ __privateGet(this, _debug2).call(this, chalk.grey(`STSWorkerManager:#processLoopExecutor(): Removing runners from collection: [${JSON.stringify(removeList)}]`));
2332
2354
  for (let i = 0; i < removeList.length; i++) {
2333
2355
  const workerEx = __privateGet(this, _workersEx)[removeList[i].workerId];
2334
2356
  if (workerEx) {
2335
2357
  const runnerEx = workerEx.runnersEx[removeList[i].runnerId];
2336
2358
  if (runnerEx) {
2337
2359
  if (runnerEx.publishInstrumentController) {
2360
+ __privateGet(this, _debug2).call(this, chalk.grey(`Ending publish for runner: [${JSON.stringify(runnerEx.asyncRunnerContext)}]`));
2338
2361
  runnerEx.publishInstrumentController.EndPublish();
2339
2362
  }
2340
2363
  if (runnerEx.state !== IRunnerState.terminated) {
2364
+ __privateGet(this, _debug2).call(this, chalk.grey(`Archive runner: [${JSON.stringify(runnerEx.asyncRunnerContext)}]`));
2341
2365
  const runner = this.CreateRunnerCopy(runnerEx);
2342
2366
  __privateGet(this, _archiveList).push(runner);
2343
2367
  if (__privateGet(this, _archiveList).length > __privateGet(this, _options2).maxArchiveListLength) {
2344
2368
  __privateGet(this, _archiveList).shift();
2345
2369
  }
2346
2370
  } else {
2371
+ __privateGet(this, _debug2).call(this, chalk.grey(`Runner has been terminated and will not be archived, runner: [${JSON.stringify(runnerEx.asyncRunnerContext)}]`));
2347
2372
  }
2348
2373
  runnerEx.archived = true;
2349
2374
  if (__privateGet(this, _archiveDeleteTimeout2) !== 0) {
@@ -2357,6 +2382,7 @@ class STSWorkerManager {
2357
2382
  }
2358
2383
  }
2359
2384
  for (const [, workerEx] of Object.entries(__privateGet(this, _workersEx))) {
2385
+ __privateGet(this, _debug2).call(this, chalk.grey(`STSWorkerManager:#processLoopExecutor(): Remaining runners from worker: [${workerEx.id}]: [${Object.keys(workerEx.runnersEx).length}]`));
2360
2386
  }
2361
2387
  setTimeout(__privateGet(this, _processLoopExecutor2), 1e3);
2362
2388
  }, 100);
@@ -2369,6 +2395,7 @@ class STSWorkerManager {
2369
2395
  }
2370
2396
  });
2371
2397
  __publicField(this, "GetWorkers", async () => {
2398
+ __privateGet(this, _debug2).call(this, `GetWorkers()`);
2372
2399
  try {
2373
2400
  await __privateGet(this, _SyncWorkerDataFromWorkers).call(this);
2374
2401
  const retVal = {};
@@ -2384,6 +2411,7 @@ class STSWorkerManager {
2384
2411
  // only include runners that are in the specified states.
2385
2412
  // Use [] to include all runners irrespective of state.
2386
2413
  __publicField(this, "GetWorkersSmall", async (states) => {
2414
+ __privateGet(this, _debug2).call(this, `GetWorkersSmall()`);
2387
2415
  try {
2388
2416
  await __privateGet(this, _SyncWorkerDataFromWorkers).call(this);
2389
2417
  const retVal = {};
@@ -2398,6 +2426,7 @@ class STSWorkerManager {
2398
2426
  });
2399
2427
  // Filter by plan and/or tag. Leave blank to not use in filter.
2400
2428
  __publicField(this, "GetArchiveList", async (runnerSearchFilters) => {
2429
+ __privateGet(this, _debug2).call(this, `GetArchiveList()`);
2401
2430
  try {
2402
2431
  return __privateGet(this, _archiveList).filter((runner) => {
2403
2432
  var _a, _b;
@@ -2415,6 +2444,7 @@ class STSWorkerManager {
2415
2444
  }
2416
2445
  });
2417
2446
  __publicField(this, "GetWorker", async (workerId) => {
2447
+ __privateGet(this, _debug2).call(this, `GetWorker()`);
2418
2448
  try {
2419
2449
  await __privateGet(this, _SyncWorkerDataFromWorker).call(this, __privateGet(this, _workersEx)[workerId]);
2420
2450
  return this.CreateWorkerCopy(__privateGet(this, _workersEx)[workerId]);
@@ -2424,6 +2454,7 @@ class STSWorkerManager {
2424
2454
  }
2425
2455
  });
2426
2456
  __publicField(this, "GetRunner", async (workerId, runnerId) => {
2457
+ __privateGet(this, _debug2).call(this, `GetRunner()`);
2427
2458
  try {
2428
2459
  await __privateGet(this, _SyncWorkerDataFromWorker).call(this, __privateGet(this, _workersEx)[workerId]);
2429
2460
  return this.CreateRunnerCopy(__privateGet(this, _workersEx)[workerId].runnersEx[runnerId]);
@@ -2433,6 +2464,7 @@ class STSWorkerManager {
2433
2464
  }
2434
2465
  });
2435
2466
  __publicField(this, "AddWorker", async (workerOptions, useWorkerFactory) => {
2467
+ __privateGet(this, _debug2).call(this, `AddWorker()`);
2436
2468
  try {
2437
2469
  let workerFactory;
2438
2470
  if (useWorkerFactory) {
@@ -2490,6 +2522,7 @@ class STSWorkerManager {
2490
2522
  if (__privateGet(this, _STSInstrumentController)) {
2491
2523
  __privateGet(this, _STSInstrumentController).LogEx(chalk.yellow(`pid: [${process.pid}] Creating new worker: [${stsWorkerEx.id}]`));
2492
2524
  }
2525
+ __privateGet(this, _debug2).call(this, `AddWorker::workerThreadWorkerOptions: Worker ID: [${stsWorkerEx.id}] Options: [${stsWorkerEx.options}]`);
2493
2526
  if (stsWorkerEx.options.mocked) {
2494
2527
  stsWorkerEx.worker.SetPort({
2495
2528
  command: eIWMessageCommands.MessagePort,
@@ -2517,9 +2550,11 @@ class STSWorkerManager {
2517
2550
  if (isNode) {
2518
2551
  stsWorkerEx.worker.on("exit", (code) => {
2519
2552
  try {
2553
+ __privateGet(this, _debug2).call(this, chalk.magenta(`STSWorkerManager:stsWorkerEx.worker.on(exit): Worker exited with code: ${code}`));
2520
2554
  __privateGet(this, _EmitWorkerEvent).call(this, "exit", stsWorkerEx);
2521
2555
  if (__privateGet(this, _workersEx)[stsWorkerEx.id]) {
2522
2556
  delete __privateGet(this, _workersEx)[stsWorkerEx.id];
2557
+ __privateGet(this, _debug2).call(this, chalk.magenta(`STSWorkerManager:stsWorkerEx.worker.on(exit): Worker: [${stsWorkerEx.id}] has been removed from the worker collection.`));
2523
2558
  }
2524
2559
  } catch (error) {
2525
2560
  __privateGet(this, _error2).call(this, chalk.red(`STSWorkerManager:stsWorkerEx.worker.on(exit): Error: [${error}] Worker: [${stsWorkerEx.id}]`));
@@ -2540,6 +2575,7 @@ class STSWorkerManager {
2540
2575
  __privateGet(this, _EmitWorkerEvent).call(this, "onerror", stsWorkerEx);
2541
2576
  if (__privateGet(this, _workersEx)[stsWorkerEx.id]) {
2542
2577
  delete __privateGet(this, _workersEx)[stsWorkerEx.id];
2578
+ __privateGet(this, _debug2).call(this, chalk.magenta(`STSWorkerManager:stsWorkerEx.worker.onerror(error): Worker: [${stsWorkerEx.id}] has been removed from the worker collection.`));
2543
2579
  }
2544
2580
  } catch (error2) {
2545
2581
  __privateGet(this, _error2).call(this, chalk.red(`STSWorkerManager:stsWorkerEx.worker.onerror(error): Error: [${error2}] Worker: [${stsWorkerEx.id}]`));
@@ -2560,6 +2596,7 @@ class STSWorkerManager {
2560
2596
  const publishMessagePayload2 = data;
2561
2597
  switch (publishMessagePayload2.command) {
2562
2598
  case eIWMessageCommands.MessagePortResponse:
2599
+ __privateGet(this, _debug2).call(this, `AddWorker:processMessage(): eIWMessageCommands.MessagePortResponse`);
2563
2600
  break;
2564
2601
  case eIWMessageCommands.InstrumentTelemetry:
2565
2602
  __privateGet(this, _ProcessTelemetry).call(this, stsWorkerEx, publishMessagePayload2.payload);
@@ -2602,6 +2639,7 @@ class STSWorkerManager {
2602
2639
  });
2603
2640
  }
2604
2641
  __privateGet(this, _workersEx)[stsWorkerEx.id] = stsWorkerEx;
2642
+ __privateGet(this, _debug2).call(this, `Added worker: [${stsWorkerEx.id}]`);
2605
2643
  await Sleep(10);
2606
2644
  const worker = await this.GetWorker(stsWorkerEx.id);
2607
2645
  if (worker.id.localeCompare(stsWorkerEx.id) === 0) {
@@ -2615,6 +2653,7 @@ class STSWorkerManager {
2615
2653
  }
2616
2654
  });
2617
2655
  __publicField(this, "AddRunnerToWorker", async (stsWorkerEx, runnerOptions) => {
2656
+ __privateGet(this, _debug2).call(this, `AddRunnerToWorker()`);
2618
2657
  try {
2619
2658
  const runnerEx = __privateGet(this, _CreateAsyncRunner).call(this, stsWorkerEx, runnerOptions);
2620
2659
  stsWorkerEx.runnersEx[runnerEx.id] = runnerEx;
@@ -2623,6 +2662,7 @@ class STSWorkerManager {
2623
2662
  runnerEx.publishInstrumentController.LogEx(chalk.green(`Added runner: [${runnerEx.id}] into worker: [${stsWorkerEx.id}]`));
2624
2663
  }
2625
2664
  if (retVal) {
2665
+ __privateGet(this, _debug2).call(this, chalk.green(`Added runner: [${runnerEx.id}] into worker: [${stsWorkerEx.id}] result: [${JSON.stringify(retVal)}]`));
2626
2666
  }
2627
2667
  return runnerEx;
2628
2668
  } catch (error) {
@@ -2707,6 +2747,7 @@ class STSWorkerManager {
2707
2747
  runner: { ...runner }
2708
2748
  });
2709
2749
  __privateGet(this, _SyncRunnerData).call(this, runnerEx, runner);
2750
+ __privateGet(this, _debug2).call(this, `STSWorkerManager:#RunnerStateChange(): Worker: [${workerEx.id}] Runner: [${runner.id}] Previous State: [${previousState}] State: [${runner.state}]`);
2710
2751
  __privateGet(this, _EmitRunnerEvent).call(this, "StateChange", workerEx, runner.id);
2711
2752
  }
2712
2753
  } catch (error) {
@@ -2785,8 +2826,11 @@ class STSWorkerManager {
2785
2826
  __privateAdd(this, _PostMessageToWorkerUsingDefaultChannel, (workerEx, command, payload, transferObject) => {
2786
2827
  try {
2787
2828
  if (transferObject) {
2829
+ __privateGet(this, _debug2).call(this, `#PostMessageToWorker with transfer object`);
2788
2830
  workerEx.worker.postMessage({ command, payload }, [transferObject]);
2831
+ __privateGet(this, _debug2).call(this, `#PostMessageToWorker with transfer object - done...`);
2789
2832
  } else {
2833
+ __privateGet(this, _debug2).call(this, `#PostMessageToWorker`);
2790
2834
  workerEx.worker.postMessage({ command, payload });
2791
2835
  }
2792
2836
  } catch (error) {
@@ -2901,7 +2945,7 @@ class STSWorkerManager {
2901
2945
  };
2902
2946
  workerEx.messagePort.postMessage({ command, payload });
2903
2947
  } catch (error) {
2904
- __privateGet(this, _error2).call(this, `ResumeRunner(): Error: [${error}]`);
2948
+ __privateGet(this, _error2).call(this, `#ResumeRunner(): Error: [${error}]`);
2905
2949
  throw error;
2906
2950
  }
2907
2951
  });
@@ -2932,7 +2976,7 @@ class STSWorkerManager {
2932
2976
  };
2933
2977
  workerEx.messagePort.postMessage({ command, payload });
2934
2978
  } catch (error) {
2935
- __privateGet(this, _error2).call(this, `UpdateRunner(): Error: [${error}]`);
2979
+ __privateGet(this, _error2).call(this, `#UpdateRunner(): Error: [${error}]`);
2936
2980
  throw error;
2937
2981
  }
2938
2982
  });
@@ -3005,8 +3049,10 @@ class STSWorkerManager {
3005
3049
  if (workerEx.worker) {
3006
3050
  setTimeout(() => {
3007
3051
  workerEx.worker.terminate();
3052
+ __privateGet(this, _debug2).call(this, `Terminated worker: [${workerEx.id}]`);
3008
3053
  if (__privateGet(this, _workersEx)[workerEx.id]) {
3009
3054
  delete __privateGet(this, _workersEx)[workerEx.id];
3055
+ __privateGet(this, _debug2).call(this, chalk.magenta(`STSWorkerManager:stsWorkerEx.worker.on(exit): Worker: [${workerEx.id}] has been removed from the worker collection.`));
3010
3056
  }
3011
3057
  }, 500);
3012
3058
  }
@@ -3017,6 +3063,7 @@ class STSWorkerManager {
3017
3063
  }
3018
3064
  });
3019
3065
  __publicField(this, "GetNextAvailableWorker", () => {
3066
+ __privateGet(this, _debug2).call(this, `GetNextAvailableWorker()`);
3020
3067
  try {
3021
3068
  let leastRunnerWorker = null;
3022
3069
  for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
@@ -3030,11 +3077,12 @@ class STSWorkerManager {
3030
3077
  }
3031
3078
  return leastRunnerWorker;
3032
3079
  } catch (error) {
3033
- __privateGet(this, _error2).call(this, `#GetNextAvailableWorker(): Error: [${error}]`);
3080
+ __privateGet(this, _error2).call(this, `GetNextAvailableWorker(): Error: [${error}]`);
3034
3081
  return null;
3035
3082
  }
3036
3083
  });
3037
3084
  __publicField(this, "GetBusyWorker", () => {
3085
+ __privateGet(this, _debug2).call(this, `GetBusyWorker()`);
3038
3086
  try {
3039
3087
  let busyWorker = null;
3040
3088
  for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
@@ -3048,7 +3096,7 @@ class STSWorkerManager {
3048
3096
  }
3049
3097
  return busyWorker;
3050
3098
  } catch (error) {
3051
- __privateGet(this, _error2).call(this, `#GetBusyWorker(): Error: [${error}]`);
3099
+ __privateGet(this, _error2).call(this, `GetBusyWorker(): Error: [${error}]`);
3052
3100
  return null;
3053
3101
  }
3054
3102
  });
@@ -3316,7 +3364,7 @@ class STSWorkerManager {
3316
3364
  }
3317
3365
  return workerCopy;
3318
3366
  } catch (error) {
3319
- __privateGet(this, _error2).call(this, `CreateWorkerCopy(): Error: [${error}]`);
3367
+ __privateGet(this, _error2).call(this, `#CreateWorkerCopy(): Error: [${error}]`);
3320
3368
  throw error;
3321
3369
  }
3322
3370
  }