@nsshunt/stsappframework 3.1.160 → 3.1.162

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.
Files changed (41) hide show
  1. package/dist/testertesting/app.js +198 -0
  2. package/dist/testertesting/app.js.map +1 -0
  3. package/dist/testertesting/commonTypes.js +39 -0
  4. package/dist/testertesting/commonTypes.js.map +1 -0
  5. package/dist/testertesting/requestResponseHelper.js +83 -0
  6. package/dist/testertesting/requestResponseHelper.js.map +1 -0
  7. package/dist/testertesting/telemetryProcessor.js +114 -0
  8. package/dist/testertesting/telemetryProcessor.js.map +1 -0
  9. package/dist/testertesting/workerInstance.js +141 -0
  10. package/dist/testertesting/workerInstance.js.map +1 -0
  11. package/dist/testertesting/workerManager.js +339 -0
  12. package/dist/testertesting/workerManager.js.map +1 -0
  13. package/dist/testertesting/workerPrimaryTestRunner01.js +62 -0
  14. package/dist/testertesting/workerPrimaryTestRunner01.js.map +1 -0
  15. package/dist/testertesting/workerWorkerTestRunner01.js +146 -0
  16. package/dist/testertesting/workerWorkerTestRunner01.js.map +1 -0
  17. package/package.json +1 -1
  18. package/src/testertesting/app.ts +243 -0
  19. package/src/testertesting/commonTypes.ts +197 -0
  20. package/src/testertesting/requestResponseHelper.ts +95 -0
  21. package/src/testertesting/telemetryProcessor.ts +128 -0
  22. package/src/testertesting/workerInstance.ts +165 -0
  23. package/src/testertesting/workerManager.ts +386 -0
  24. package/src/testertesting/workerPrimaryTestRunner01.ts +81 -0
  25. package/src/testertesting/workerWorkerTestRunner01.ts +184 -0
  26. package/types/testertesting/app.d.ts +2 -0
  27. package/types/testertesting/app.d.ts.map +1 -0
  28. package/types/testertesting/commonTypes.d.ts +167 -0
  29. package/types/testertesting/commonTypes.d.ts.map +1 -0
  30. package/types/testertesting/requestResponseHelper.d.ts +8 -0
  31. package/types/testertesting/requestResponseHelper.d.ts.map +1 -0
  32. package/types/testertesting/telemetryProcessor.d.ts +6 -0
  33. package/types/testertesting/telemetryProcessor.d.ts.map +1 -0
  34. package/types/testertesting/workerInstance.d.ts +18 -0
  35. package/types/testertesting/workerInstance.d.ts.map +1 -0
  36. package/types/testertesting/workerManager.d.ts +14 -0
  37. package/types/testertesting/workerManager.d.ts.map +1 -0
  38. package/types/testertesting/workerPrimaryTestRunner01.d.ts +8 -0
  39. package/types/testertesting/workerPrimaryTestRunner01.d.ts.map +1 -0
  40. package/types/testertesting/workerWorkerTestRunner01.d.ts +16 -0
  41. package/types/testertesting/workerWorkerTestRunner01.d.ts.map +1 -0
@@ -0,0 +1,339 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.STSWorkerManager = void 0;
7
+ /* eslint @typescript-eslint/no-explicit-any: 0, @typescript-eslint/no-unused-vars: 0 */ // --> OFF
8
+ //import MyWorker from './sts-worker?worker' // https://vitejs.dev/guide/features.html#web-workers
9
+ const commonTypes_1 = require("./commonTypes");
10
+ const stsutils_1 = require("@nsshunt/stsutils");
11
+ const stsutils_2 = require("@nsshunt/stsutils");
12
+ const chalk_1 = __importDefault(require("chalk"));
13
+ const telemetryProcessor_1 = require("./telemetryProcessor");
14
+ chalk_1.default.level = 3;
15
+ class STSWorkerManager {
16
+ //#agentSession: string = null;
17
+ #workersEx = {};
18
+ #runner = 0;
19
+ #workerId = 0;
20
+ #options;
21
+ #STSInstrumentController;
22
+ #telemetryProcessor;
23
+ #app;
24
+ constructor(app, options) {
25
+ this.#app = app;
26
+ if (options) {
27
+ this.#options = options;
28
+ }
29
+ else {
30
+ this.#options = {};
31
+ }
32
+ this.#STSInstrumentController = this.#options.publishInstrumentController;
33
+ this.#telemetryProcessor = new telemetryProcessor_1.TelemetryProcessor();
34
+ }
35
+ #debug = (message) => {
36
+ console.log(chalk_1.default.cyan(`pid: [${process.pid}] STSWorkerManager::${message}`));
37
+ };
38
+ get WorkersEx() {
39
+ return this.#workersEx;
40
+ }
41
+ AddWorker = async (useWorkerFactory) => {
42
+ let workerFactory;
43
+ if (useWorkerFactory) {
44
+ // Use the supplied workFactory
45
+ workerFactory = useWorkerFactory;
46
+ }
47
+ else {
48
+ // Use the default workFactory
49
+ workerFactory = this.#options.workerFactory;
50
+ }
51
+ const workerId = this.#workerId++;
52
+ const stsWorkerEx = {
53
+ id: workerId,
54
+ worker: workerFactory.createWorkerThreadWorker(),
55
+ primaryWorker: workerFactory.createPrimaryThreadWorker(this.#app, workerFactory.primaryThreadWorkerOptions),
56
+ state: commonTypes_1.IWorkerState.starting,
57
+ workerThreadWorkerOptions: workerFactory.workerThreadWorkerOptions,
58
+ primaryThreadWorkerOptions: workerFactory.primaryThreadWorkerOptions,
59
+ runnersEx: {},
60
+ AddRunner: (runnerOptions) => this.AddRunnerToWorker(stsWorkerEx, runnerOptions),
61
+ StartRunner: (runner) => this.#StartRunner(stsWorkerEx, runner),
62
+ StopRunner: (runner) => this.#StopRunner(stsWorkerEx, runner),
63
+ Stop: async () => this.#StopWorker(stsWorkerEx),
64
+ GetRunner: (id) => this.#workersEx[workerId].GetRunner(id)
65
+ };
66
+ this.#STSInstrumentController.LogEx(chalk_1.default.yellow(`pid: [${process.pid}] Creating new worker: [${stsWorkerEx.id}]`));
67
+ this.#debug(`Adding worker: [${stsWorkerEx.id}]`);
68
+ /*
69
+ stsWorkerEx.worker.onmessage = function(data: MessageEvent) {
70
+ console.log(data.data);
71
+ }
72
+
73
+ stsWorkerEx.worker.onerror = function(error) {
74
+ console.log(error);
75
+ };
76
+ */
77
+ const { port1, // process message port
78
+ port2 // collector message port
79
+ } = new MessageChannel();
80
+ const workerPort = port1;
81
+ this.#debug(`AddWorker::workerThreadWorkerOptions: [${JSON.stringify(stsWorkerEx.workerThreadWorkerOptions)}]`);
82
+ this.#PostMessageToWorker(stsWorkerEx, commonTypes_1.eIWMessageCommands.MessagePort, {
83
+ port: port2,
84
+ //applicationStoreState: stateCopy,
85
+ options: { ...stsWorkerEx.workerThreadWorkerOptions }
86
+ }, port2);
87
+ // Process messages received back from the worker
88
+ //workerPort.onmessage = async (data: MessageEvent) => {
89
+ workerPort.on('message', (data) => {
90
+ // const publishMessagePayload: IIWMessagePayload = data.data as IIWMessagePayload; browser version
91
+ const publishMessagePayload = data;
92
+ switch (publishMessagePayload.command) {
93
+ case commonTypes_1.eIWMessageCommands.MessagePortResponse:
94
+ this.#debug(`AddWorker::eIWMessageCommands.MessagePortResponse`);
95
+ stsWorkerEx.state = commonTypes_1.IWorkerState.started;
96
+ break;
97
+ case commonTypes_1.eIWMessageCommands.InstrumentTelemetry:
98
+ this.#debug(`AddWorker::eIWMessageCommands.InstrumentTelemetry`);
99
+ this.#ProcessTelemetry(stsWorkerEx, publishMessagePayload.payload);
100
+ break;
101
+ default:
102
+ this.#debug(`AddWorker::default`);
103
+ stsWorkerEx.primaryWorker.ProcessMessageFromWorker(workerPort, publishMessagePayload);
104
+ }
105
+ });
106
+ this.#workersEx[stsWorkerEx.id] = stsWorkerEx;
107
+ this.#debug(`Added worker: [${stsWorkerEx.id}]`);
108
+ return stsWorkerEx;
109
+ };
110
+ AddRunnerToWorker = (stsWorkerEx, runnerOptions) => {
111
+ const runnerEx = this.#CreateAsyncRunner(stsWorkerEx, runnerOptions);
112
+ stsWorkerEx.runnersEx[runnerEx.id] = runnerEx;
113
+ this.#SetRunnerIntoWorker(stsWorkerEx, runnerEx);
114
+ runnerEx.publishInstrumentController.LogEx(chalk_1.default.green(`Added runner: [${runnerEx.id}] into worker: [${stsWorkerEx.id}]`));
115
+ return runnerEx;
116
+ };
117
+ #CreateRunnerCopy(runnerEx) {
118
+ return {
119
+ id: runnerEx.id,
120
+ asyncRunnerContext: { ...runnerEx.asyncRunnerContext },
121
+ options: { ...runnerEx.options },
122
+ state: runnerEx.state,
123
+ instrumentData: { ...runnerEx.instrumentData }
124
+ };
125
+ }
126
+ #SetRunnerIntoWorker = (workerEx, runnerEx) => {
127
+ // Now that the worker is setup, send the options
128
+ //@@ wait until worker in running state
129
+ const payload = {
130
+ runner: this.#CreateRunnerCopy(runnerEx)
131
+ };
132
+ this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.AddAsyncRunner, payload);
133
+ };
134
+ #ProcessTelemetry = (workerEx, payloadContents) => {
135
+ //const store = TelemetryStore();
136
+ const { runner } = payloadContents;
137
+ if (workerEx.runnersEx[runner.id]) {
138
+ const runnerEx = workerEx.runnersEx[runner.id];
139
+ // Copy telemetry
140
+ runnerEx.instrumentData = { ...runner.instrumentData };
141
+ this.#debug(JSON.stringify(runnerEx.instrumentData));
142
+ if (runner.instrumentData.message) {
143
+ runnerEx.instrumentData.message = [...runner.instrumentData.message];
144
+ }
145
+ else {
146
+ runnerEx.instrumentData.message = [];
147
+ }
148
+ const update = this.#telemetryProcessor.ProcessTelemetry(runnerEx.publishInstrumentController, runnerEx.instrumentData);
149
+ if (update) {
150
+ //store.Update(workerEx, runnerEx);
151
+ }
152
+ }
153
+ };
154
+ #CreateAsyncRunner = (workerEx, runnerOptions) => {
155
+ //const applicationStore = ApplicationStore();
156
+ this.#runner++; // The runner number always increases
157
+ this.#STSInstrumentController.LogEx(chalk_1.default.yellow(`Creating new async runner: [${this.#runner}]`));
158
+ const asyncRunnerContext = {
159
+ nid: `\
160
+ ${workerEx.workerThreadWorkerOptions.hostName}${stsutils_1.ModelDelimeter.COMPONENT_SEPERATOR}${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}\
161
+ ${stsutils_1.ModelDelimeter.NID_SEPERATOR}\
162
+ worker${workerEx.id}\
163
+ ${stsutils_1.ModelDelimeter.SEPERATOR}\
164
+ ${this.#runner}`,
165
+ id: this.#runner.toString(),
166
+ hostName: (workerEx.workerThreadWorkerOptions.hostName ? workerEx.workerThreadWorkerOptions.hostName : 'host'),
167
+ agentName: `${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}`,
168
+ threadId: `worker${workerEx.id}`,
169
+ asyncRunnerId: this.#runner
170
+ };
171
+ const runnerEx = {
172
+ id: this.#runner,
173
+ publishInstrumentController: this.#STSInstrumentController.AddPublishInstrumentController(asyncRunnerContext),
174
+ asyncRunnerContext: asyncRunnerContext,
175
+ state: commonTypes_1.IRunnerState.created,
176
+ options: runnerOptions,
177
+ instrumentData: {
178
+ requestCount: 0,
179
+ errorCount: 0,
180
+ retryCount: 0,
181
+ authenticationCount: 0,
182
+ authenticationErrorCount: 0,
183
+ authenticationRetryCount: 0,
184
+ velocity: 0,
185
+ coreCount: 0,
186
+ timer: 0,
187
+ duration: 0,
188
+ latency: 0,
189
+ activeRequestCount: 0,
190
+ message: [],
191
+ childCount: 0,
192
+ rx: 0,
193
+ tx: 0
194
+ },
195
+ Stop: async () => this.#StopRunner(workerEx, runnerEx),
196
+ Start: async () => this.#StartRunner(workerEx, runnerEx),
197
+ Pause: async () => this.#PauseRunner(workerEx, runnerEx),
198
+ Resume: async () => this.#ResumeRunner(workerEx, runnerEx),
199
+ ApplyConfig: async (config) => {
200
+ runnerEx.options = config;
201
+ return true;
202
+ },
203
+ GetConfig: () => runnerEx.options
204
+ };
205
+ return runnerEx;
206
+ };
207
+ #PostMessageToWorker = (workerEx, command, payload, transferObject) => {
208
+ if (transferObject) {
209
+ this.#debug(`#PostMessageToWorker with transfer object`);
210
+ workerEx.worker.postMessage({ command, payload }, [transferObject]);
211
+ this.#debug(`#PostMessageToWorker with transfer object - done...`);
212
+ }
213
+ else {
214
+ this.#debug(`#PostMessageToWorker`);
215
+ workerEx.worker.postMessage({ command, payload });
216
+ }
217
+ };
218
+ #TerminateWorker = (workerEx) => {
219
+ if (workerEx.worker) {
220
+ //const store = TelemetryStore();
221
+ workerEx.worker.terminate();
222
+ this.#debug(`Terminated worker: [${workerEx.id}]`);
223
+ //store.RemoveWorker(workerEx);
224
+ delete this.#workersEx[workerEx.id];
225
+ }
226
+ else {
227
+ // Some other runner has already removed the parent worker, do nothing
228
+ // console.log(`WORKER ALREADY NULL`);
229
+ }
230
+ };
231
+ #StartRunner = async (workerEx, runnerEx) => {
232
+ this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.StartRunner, {
233
+ runner: this.#CreateRunnerCopy(runnerEx)
234
+ });
235
+ return true;
236
+ };
237
+ #StopRunner = async (workerEx, runnerEx = null) => {
238
+ // If runnerEx not provided, Remove the first runner in the collection
239
+ if (runnerEx === null) {
240
+ const ids = Object.keys(workerEx.runnersEx);
241
+ if (ids.length > 0) {
242
+ const id = ids[0];
243
+ runnerEx = workerEx.runnersEx[id];
244
+ }
245
+ }
246
+ if (runnerEx !== null) {
247
+ this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.StopAllAsyncRunners, {
248
+ runner: this.#CreateRunnerCopy(runnerEx)
249
+ });
250
+ runnerEx.publishInstrumentController.LogEx(`Terminating runner: [${runnerEx.id}]`);
251
+ const promArray = [];
252
+ promArray.push((async () => {
253
+ await (0, stsutils_2.Sleep)(100);
254
+ return runnerEx.publishInstrumentController.EndPublish();
255
+ })());
256
+ //const store = TelemetryStore();
257
+ //store.RemoveRunner(workerEx, runnerEx);
258
+ delete workerEx.runnersEx[runnerEx.id];
259
+ const retVal = await Promise.all(promArray);
260
+ console.log(`Removed instrument workers: [${retVal}]`);
261
+ }
262
+ return true;
263
+ };
264
+ #PauseRunner = async (workerEx, runnerEx = null) => {
265
+ return true;
266
+ };
267
+ #ResumeRunner = async (workerEx, runnerEx = null) => {
268
+ return true;
269
+ };
270
+ #StopWorker = async (workerEx) => {
271
+ try {
272
+ if (workerEx.state !== commonTypes_1.IWorkerState.stopped) {
273
+ this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.StopAllAsyncRunners, null);
274
+ //@@ Now wait until we get an ack back from the worker
275
+ // This is because we may be trying to stop BEFORE the worker has had a chance to startup ...
276
+ console.log(`Terminating worker: [${workerEx.id}]`);
277
+ const promArray = [];
278
+ // Terminate only those that are currently running...
279
+ const ids = Object.keys(workerEx.runnersEx);
280
+ ids.forEach((id) => {
281
+ const runnerEx = workerEx.runnersEx[id];
282
+ promArray.push(this.#StopRunner(workerEx, runnerEx));
283
+ });
284
+ await Promise.all(promArray);
285
+ this.#TerminateWorker(workerEx);
286
+ }
287
+ return true;
288
+ }
289
+ catch (error) {
290
+ console.log(`Error in STSTestWorker:StopWorker: [${error}]`);
291
+ return false;
292
+ }
293
+ };
294
+ GetNextAvailableWorker = () => {
295
+ // Calculate the worker with the least runners
296
+ let leastRunnerWorker = null;
297
+ for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
298
+ if (leastRunnerWorker) {
299
+ if (Object.keys(stsWorker.runnersEx).length < Object.keys(leastRunnerWorker.runnersEx).length) {
300
+ leastRunnerWorker = stsWorker;
301
+ }
302
+ }
303
+ else {
304
+ leastRunnerWorker = stsWorker;
305
+ }
306
+ }
307
+ return leastRunnerWorker;
308
+ };
309
+ GetBusyWorker = () => {
310
+ // Calculate the worker with the least runners
311
+ let busyWorker = null;
312
+ for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
313
+ if (busyWorker) {
314
+ if (Object.keys(stsWorker.runnersEx).length > Object.keys(busyWorker.runnersEx).length) {
315
+ busyWorker = stsWorker;
316
+ }
317
+ }
318
+ else {
319
+ busyWorker = stsWorker;
320
+ }
321
+ }
322
+ return busyWorker;
323
+ };
324
+ get Options() {
325
+ return this.#options;
326
+ }
327
+ set Options(options) {
328
+ this.#options = options;
329
+ }
330
+ StopAllWorkers = async () => {
331
+ const promArray = [];
332
+ for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
333
+ promArray.push(stsWorker.Stop());
334
+ }
335
+ await Promise.all(promArray);
336
+ };
337
+ }
338
+ exports.STSWorkerManager = STSWorkerManager;
339
+ //# sourceMappingURL=workerManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workerManager.js","sourceRoot":"","sources":["../../src/testertesting/workerManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.WorkerPrimaryTestRunner01 = void 0;
7
+ const chalk_1 = __importDefault(require("chalk"));
8
+ // Force chalk level
9
+ chalk_1.default.level = 3;
10
+ const commonTypes_1 = require("./commonTypes");
11
+ //import { STSOAuth2Manager, STSOAuth2ManagerPluginKey } from '@nsshunt/stsoauth2plugin'
12
+ // This will execute within the primary thread context and have access to plugins and other Vue application features
13
+ class WorkerPrimaryTestRunner01 {
14
+ // #STSOAuth2Manager: STSOAuth2Manager
15
+ #options;
16
+ #debug = (message) => {
17
+ console.log(chalk_1.default.magenta(`pid: [${process.pid}] WorkerPrimaryTestRunner01::${message}`));
18
+ };
19
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
20
+ constructor(app, options) {
21
+ this.#debug(`constructor`);
22
+ this.#options = options;
23
+ this.#debug(`constructor::options: [${JSON.stringify(this.#options)}]`);
24
+ // this.#STSOAuth2Manager = app.config.globalProperties.$sts[STSOAuth2ManagerPluginKey]
25
+ }
26
+ async ProcessMessageFromWorker(workerPort, publishMessagePayload) {
27
+ this.#debug(`ProcessMessageFromWorker`);
28
+ // Process messages received back from the worker
29
+ switch (publishMessagePayload.command) {
30
+ case commonTypes_1.PublishMessageCommandsTestRunner.GetAccessToken:
31
+ {
32
+ //const access_token = await this.#GetAccessToken();
33
+ const access_token = '1234';
34
+ workerPort.postMessage({
35
+ command: commonTypes_1.PublishMessageCommandsTestRunner.GetAccessTokenResponse,
36
+ payload: {
37
+ messageId: publishMessagePayload.payload.messageId,
38
+ access_token
39
+ }
40
+ });
41
+ }
42
+ break;
43
+ case commonTypes_1.PublishMessageCommandsTestRunner.ExecuteRefreshToken:
44
+ {
45
+ //const access_token = await this.#ExecuteRefreshToken();
46
+ const access_token = '5678';
47
+ workerPort.postMessage({
48
+ command: commonTypes_1.PublishMessageCommandsTestRunner.ExecuteRefreshTokenResponse,
49
+ payload: {
50
+ messageId: publishMessagePayload.payload.messageId,
51
+ access_token
52
+ }
53
+ });
54
+ }
55
+ break;
56
+ default:
57
+ throw new Error(`publishMessagePayload.command: [${publishMessagePayload.command}] not allowed`);
58
+ }
59
+ }
60
+ }
61
+ exports.WorkerPrimaryTestRunner01 = WorkerPrimaryTestRunner01;
62
+ //# sourceMappingURL=workerPrimaryTestRunner01.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workerPrimaryTestRunner01.js","sourceRoot":"","sources":["../../src/testertesting/workerPrimaryTestRunner01.ts"],"names":[],"mappings":";;;;;;AAEA,kDAA0B;AAC1B,oBAAoB;AACpB,eAAK,CAAC,KAAK,GAAG,CAAC,CAAC;AAEhB,+CAC0E;AAE1E,wFAAwF;AAExF,oHAAoH;AACpH,MAAa,yBAAyB;IACtC,yCAAyC;IACrC,QAAQ,CAAgB;IAExB,MAAM,GAAG,CAAC,OAAe,EAAE,EAAE;QACzB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,OAAO,CAAC,SAAS,OAAO,CAAC,GAAG,gCAAgC,OAAO,EAAE,CAAC,CAAC,CAAC;IAC9F,CAAC,CAAA;IAED,+DAA+D;IAC/D,YAAY,GAAQ,EAAE,OAAuB;QACzC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAA;QAC1B,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,MAAM,CAAC,0BAA0B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACxE,8FAA8F;IAClG,CAAC;IAED,KAAK,CAAC,wBAAwB,CAAC,UAAuB,EAAE,qBAAwC;QAC5F,IAAI,CAAC,MAAM,CAAC,0BAA0B,CAAC,CAAA;QACvC,iDAAiD;QACjD,QAAQ,qBAAqB,CAAC,OAA2C,EAAE,CAAC;YAC5E,KAAK,8CAAgC,CAAC,cAAc;gBAAG,CAAC;oBACpD,oDAAoD;oBACpD,MAAM,YAAY,GAAG,MAAM,CAAC;oBAC5B,UAAU,CAAC,WAAW,CAAC;wBACnB,OAAO,EAAE,8CAAgC,CAAC,sBAAsB;wBAChE,OAAO,EAAE;4BACL,SAAS,EAAE,qBAAqB,CAAC,OAAO,CAAC,SAAS;4BAClD,YAAY;yBACiB;qBACpC,CAAC,CAAA;gBAAA,CAAC;gBACH,MAAM;YACV,KAAK,8CAAgC,CAAC,mBAAmB;gBAAG,CAAC;oBACzD,yDAAyD;oBACzD,MAAM,YAAY,GAAG,MAAM,CAAC;oBAC5B,UAAU,CAAC,WAAW,CAAC;wBACnB,OAAO,EAAE,8CAAgC,CAAC,2BAA2B;wBACrE,OAAO,EAAE;4BACL,SAAS,EAAE,qBAAqB,CAAC,OAAO,CAAC,SAAS;4BAClD,YAAY;yBACiB;qBACpC,CAAC,CAAA;gBAAA,CAAC;gBACH,MAAM;YACV;gBACI,MAAM,IAAI,KAAK,CAAC,mCAAmC,qBAAqB,CAAC,OAAO,eAAe,CAAC,CAAC;QACrG,CAAC;IACL,CAAC;CAuBJ;AApED,8DAoEC"}
@@ -0,0 +1,146 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.WorkerWorkerTestRunner01 = void 0;
7
+ /* eslint @typescript-eslint/no-unused-vars: 0, @typescript-eslint/no-explicit-any: 0 */ // --> OFF
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ // Force chalk level
10
+ chalk_1.default.level = 3;
11
+ const commonTypes_1 = require("./commonTypes");
12
+ const workerInstance_1 = require("./workerInstance");
13
+ const debug = (message) => {
14
+ console.log(chalk_1.default.blue(`pid: [${process.pid}] workerWorkerTestRunner01::${message}`));
15
+ };
16
+ // This will execute within a worker thread context
17
+ class WorkerWorkerTestRunner01 extends workerInstance_1.WorkerInstance {
18
+ #logMessageDataSet = {};
19
+ constructor() {
20
+ super();
21
+ debug(`constructor`);
22
+ }
23
+ StartWork = async (runner) => {
24
+ debug(`StartWork::Options: [${JSON.stringify(this.Options)}]`);
25
+ //this.#access_token = await this.#GetAccessToken();
26
+ //await Sleep(this.GetRandomInt(1000));
27
+ return this.PerformTest(runner);
28
+ };
29
+ GenLogMessage = (runner) => {
30
+ if (!this.#logMessageDataSet[runner.id]) {
31
+ this.#logMessageDataSet[runner.id] = {
32
+ adder: 1,
33
+ indent: 0
34
+ };
35
+ }
36
+ const logMessageData = this.#logMessageDataSet[runner.id];
37
+ let message = `${' '.repeat(logMessageData.indent)}>> Hello World <<`;
38
+ const colorCode = runner.asyncRunnerContext.asyncRunnerId % 4;
39
+ switch (colorCode) {
40
+ case 0:
41
+ message = chalk_1.default.green(`${message}`);
42
+ break;
43
+ case 1:
44
+ message = chalk_1.default.yellow(`${message}`);
45
+ break;
46
+ case 2:
47
+ message = chalk_1.default.magenta(`${message}`);
48
+ break;
49
+ case 3:
50
+ message = chalk_1.default.white(`${message}`);
51
+ break;
52
+ }
53
+ console.log(message);
54
+ runner.instrumentData.message.push(message);
55
+ logMessageData.indent += logMessageData.adder;
56
+ if (logMessageData.indent > 20) {
57
+ logMessageData.adder = -1;
58
+ }
59
+ else if (logMessageData.indent === 0) {
60
+ logMessageData.adder = 1;
61
+ }
62
+ };
63
+ PerformTest = async (runner) => {
64
+ debug(`WorkerWorkerTestRunner01::PerformTest`);
65
+ const message = `ID: [${runner.asyncRunnerContext.id}], Worker: [${runner.asyncRunnerContext.threadId}], Runner: [${runner.asyncRunnerContext.asyncRunnerId}] starting ...`;
66
+ console.log(message);
67
+ runner.instrumentData.message = [message];
68
+ this.PostTelemetry(runner);
69
+ runner.instrumentData.message = [];
70
+ /*
71
+ const tester = new TestRest01Service(this.#access_token, runner.options as IRunnerOptionsEx);
72
+
73
+ tester.on('rx', (val: string) => {
74
+ runner.instrumentData.rx += parseInt(val);
75
+ //console.log(runner.instrumentData.rx);
76
+ });
77
+
78
+ tester.on('tx', (val: string) => {
79
+ runner.instrumentData.tx += parseInt(val);
80
+ });
81
+ */
82
+ while (runner.state !== commonTypes_1.IRunnerState.stopped) {
83
+ await (0, stsutils_1.Sleep)(0);
84
+ //let retVal = await tester.StartTest();
85
+ runner.instrumentData.coreCount = 1;
86
+ const options = runner.options;
87
+ await (0, stsutils_1.Sleep)(options.sleepDuration);
88
+ runner.instrumentData.timer++;
89
+ runner.instrumentData.requestCount++;
90
+ runner.instrumentData.velocity = options.messageMod;
91
+ //runner.instrumentData.tx += 256;
92
+ //runner.instrumentData.rx += 6500;
93
+ if (runner.instrumentData.requestCount % options.logMessageMod === 0) {
94
+ this.GenLogMessage(runner);
95
+ }
96
+ if (runner.instrumentData.requestCount % options.messageMod === 0) {
97
+ this.PostTelemetry(runner);
98
+ runner.instrumentData.message = [];
99
+ runner.instrumentData.tx = 0;
100
+ runner.instrumentData.rx = 0;
101
+ }
102
+ if (runner.instrumentData.requestCount % 1000 === 0) {
103
+ const message = `Worker: [${runner.asyncRunnerContext.threadId}], Runner: [${runner.asyncRunnerContext.asyncRunnerId}] has completed: [${runner.instrumentData.requestCount}] iterations of max: [${options.iterations}]`;
104
+ console.log(message);
105
+ runner.instrumentData.message = [message];
106
+ this.PostTelemetry(runner);
107
+ runner.instrumentData.message = [];
108
+ runner.instrumentData.tx = 0;
109
+ runner.instrumentData.rx = 0;
110
+ }
111
+ if (runner.instrumentData.requestCount > options.iterations) {
112
+ runner.state = commonTypes_1.IRunnerState.stopped;
113
+ const message = `Worker: [${runner.asyncRunnerContext.threadId}], Runner: [${runner.asyncRunnerContext.asyncRunnerId}] stopping ...`;
114
+ console.log(message);
115
+ runner.instrumentData.message = [message];
116
+ this.PostTelemetry(runner);
117
+ runner.instrumentData.message = [];
118
+ runner.instrumentData.tx = 0;
119
+ runner.instrumentData.rx = 0;
120
+ }
121
+ }
122
+ };
123
+ }
124
+ exports.WorkerWorkerTestRunner01 = WorkerWorkerTestRunner01;
125
+ const worker_threads_1 = require("worker_threads");
126
+ const stsutils_1 = require("@nsshunt/stsutils");
127
+ let messagePort;
128
+ const worker = new WorkerWorkerTestRunner01();
129
+ worker_threads_1.parentPort?.on('message', (data) => {
130
+ worker.ProcessMessage(data);
131
+ /*
132
+
133
+ if (data.cmd.localeCompare('portmessage') === 0) {
134
+ messagePort = data.port;
135
+ messagePort.on('message', (data) => {
136
+ LogInfoMessage(`webWorker (${process.pid}): message from passed message port = [${data}]`);
137
+ messagePort.postMessage(data);
138
+ });
139
+ } else {
140
+ LogInfoMessage(`webWorker (${process.pid}): message from parent = [${JSON.stringify(data)}]`);
141
+ parentPort?.postMessage(data);
142
+ }
143
+ */
144
+ });
145
+ debug(`file completed ...`);
146
+ //# sourceMappingURL=workerWorkerTestRunner01.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workerWorkerTestRunner01.js","sourceRoot":"","sources":["../../src/testertesting/workerWorkerTestRunner01.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nsshunt/stsappframework",
3
- "version": "3.1.160",
3
+ "version": "3.1.162",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "types": "./types/index.d.ts",