@nsshunt/stsappframework 3.1.160 → 3.1.161
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.
- package/dist/testertesting/app.js +194 -0
- package/dist/testertesting/app.js.map +1 -0
- package/dist/testertesting/commonTypes.js +16 -0
- package/dist/testertesting/commonTypes.js.map +1 -0
- package/dist/testertesting/requestResponseHelper.js +83 -0
- package/dist/testertesting/requestResponseHelper.js.map +1 -0
- package/dist/testertesting/stsTestWorkerDefinitions.js +34 -0
- package/dist/testertesting/stsTestWorkerDefinitions.js.map +1 -0
- package/dist/testertesting/workerInstance.js +131 -0
- package/dist/testertesting/workerInstance.js.map +1 -0
- package/dist/testertesting/workerManager.js +417 -0
- package/dist/testertesting/workerManager.js.map +1 -0
- package/dist/testertesting/workerPrimaryTestRunner01.js +62 -0
- package/dist/testertesting/workerPrimaryTestRunner01.js.map +1 -0
- package/dist/testertesting/workerWorkerTestRunner01.js +146 -0
- package/dist/testertesting/workerWorkerTestRunner01.js.map +1 -0
- package/package.json +1 -1
- package/src/testertesting/app.ts +238 -0
- package/src/testertesting/commonTypes.ts +50 -0
- package/src/testertesting/requestResponseHelper.ts +95 -0
- package/src/testertesting/stsTestWorkerDefinitions.ts +150 -0
- package/src/testertesting/workerInstance.ts +154 -0
- package/src/testertesting/workerManager.ts +478 -0
- package/src/testertesting/workerPrimaryTestRunner01.ts +81 -0
- package/src/testertesting/workerWorkerTestRunner01.ts +184 -0
- package/types/testertesting/app.d.ts +2 -0
- package/types/testertesting/app.d.ts.map +1 -0
- package/types/testertesting/commonTypes.d.ts +44 -0
- package/types/testertesting/commonTypes.d.ts.map +1 -0
- package/types/testertesting/requestResponseHelper.d.ts +8 -0
- package/types/testertesting/requestResponseHelper.d.ts.map +1 -0
- package/types/testertesting/stsTestWorkerDefinitions.d.ts +124 -0
- package/types/testertesting/stsTestWorkerDefinitions.d.ts.map +1 -0
- package/types/testertesting/workerInstance.d.ts +18 -0
- package/types/testertesting/workerInstance.d.ts.map +1 -0
- package/types/testertesting/workerManager.d.ts +14 -0
- package/types/testertesting/workerManager.d.ts.map +1 -0
- package/types/testertesting/workerPrimaryTestRunner01.d.ts +8 -0
- package/types/testertesting/workerPrimaryTestRunner01.d.ts.map +1 -0
- package/types/testertesting/workerWorkerTestRunner01.d.ts +16 -0
- package/types/testertesting/workerWorkerTestRunner01.d.ts.map +1 -0
|
@@ -0,0 +1,417 @@
|
|
|
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 stsobservability_1 = require("@nsshunt/stsobservability");
|
|
11
|
+
const stsutils_1 = require("@nsshunt/stsutils");
|
|
12
|
+
const stsTestWorkerDefinitions_1 = require("./stsTestWorkerDefinitions");
|
|
13
|
+
const stsutils_2 = require("@nsshunt/stsutils");
|
|
14
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
15
|
+
chalk_1.default.level = 3;
|
|
16
|
+
class STSWorkerManager {
|
|
17
|
+
//#agentSession: string = null;
|
|
18
|
+
#workersEx = {};
|
|
19
|
+
#runner = 0;
|
|
20
|
+
#workerId = 0;
|
|
21
|
+
#options;
|
|
22
|
+
#STSInstrumentController;
|
|
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
|
+
}
|
|
34
|
+
#debug = (message) => {
|
|
35
|
+
console.log(chalk_1.default.cyan(`pid: [${process.pid}] STSWorkerManager::${message}`));
|
|
36
|
+
};
|
|
37
|
+
get WorkersEx() {
|
|
38
|
+
return this.#workersEx;
|
|
39
|
+
}
|
|
40
|
+
AddWorker = async (useWorkerFactory) => {
|
|
41
|
+
let workerFactory;
|
|
42
|
+
if (useWorkerFactory) {
|
|
43
|
+
// Use the supplied workFactory
|
|
44
|
+
workerFactory = useWorkerFactory;
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
// Use the default workFactory
|
|
48
|
+
workerFactory = this.#options.workerFactory;
|
|
49
|
+
}
|
|
50
|
+
const stsWorkerEx = {
|
|
51
|
+
id: this.#workerId++, // uuidv4()
|
|
52
|
+
worker: workerFactory.createWorkerThreadWorker(),
|
|
53
|
+
primaryWorker: workerFactory.createPrimaryThreadWorker(this.#app, workerFactory.primaryThreadWorkerOptions),
|
|
54
|
+
state: stsTestWorkerDefinitions_1.IWorkerState.starting,
|
|
55
|
+
workerThreadWorkerOptions: workerFactory.workerThreadWorkerOptions,
|
|
56
|
+
primaryThreadWorkerOptions: workerFactory.primaryThreadWorkerOptions,
|
|
57
|
+
runnersEx: {},
|
|
58
|
+
AddRunner: (runnerOptions) => this.AddRunnerToWorker(stsWorkerEx, runnerOptions),
|
|
59
|
+
StopRunner: (runner) => this.#StopRunner(stsWorkerEx, runner),
|
|
60
|
+
Stop: async () => this.#StopWorker(stsWorkerEx)
|
|
61
|
+
};
|
|
62
|
+
this.#STSInstrumentController.LogEx(chalk_1.default.yellow(`pid: [${process.pid}] Creating new worker: [${stsWorkerEx.id}]`));
|
|
63
|
+
this.#debug(`Adding worker: [${stsWorkerEx.id}]`);
|
|
64
|
+
/*
|
|
65
|
+
stsWorkerEx.worker.onmessage = function(data: MessageEvent) {
|
|
66
|
+
console.log(data.data);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
stsWorkerEx.worker.onerror = function(error) {
|
|
70
|
+
console.log(error);
|
|
71
|
+
};
|
|
72
|
+
*/
|
|
73
|
+
const { port1, // process message port
|
|
74
|
+
port2 // collector message port
|
|
75
|
+
} = new MessageChannel();
|
|
76
|
+
const workerPort = port1;
|
|
77
|
+
this.#debug(`AddWorker::workerThreadWorkerOptions: [${JSON.stringify(stsWorkerEx.workerThreadWorkerOptions)}]`);
|
|
78
|
+
this.#PostMessageToWorker(stsWorkerEx, commonTypes_1.eIWMessageCommands.MessagePort, {
|
|
79
|
+
port: port2,
|
|
80
|
+
//applicationStoreState: stateCopy,
|
|
81
|
+
options: { ...stsWorkerEx.workerThreadWorkerOptions }
|
|
82
|
+
}, port2);
|
|
83
|
+
// Process messages received back from the worker
|
|
84
|
+
//workerPort.onmessage = async (data: MessageEvent) => {
|
|
85
|
+
workerPort.on('message', (data) => {
|
|
86
|
+
// const publishMessagePayload: IIWMessagePayload = data.data as IIWMessagePayload; browser version
|
|
87
|
+
const publishMessagePayload = data;
|
|
88
|
+
switch (publishMessagePayload.command) {
|
|
89
|
+
case commonTypes_1.eIWMessageCommands.MessagePortResponse:
|
|
90
|
+
this.#debug(`AddWorker::eIWMessageCommands.MessagePortResponse`);
|
|
91
|
+
stsWorkerEx.state = stsTestWorkerDefinitions_1.IWorkerState.started;
|
|
92
|
+
break;
|
|
93
|
+
case commonTypes_1.eIWMessageCommands.InstrumentTelemetry:
|
|
94
|
+
this.#debug(`AddWorker::eIWMessageCommands.InstrumentTelemetry`);
|
|
95
|
+
this.#ProcessTelemetry(stsWorkerEx, publishMessagePayload.payload);
|
|
96
|
+
break;
|
|
97
|
+
default:
|
|
98
|
+
this.#debug(`AddWorker::default`);
|
|
99
|
+
stsWorkerEx.primaryWorker.ProcessMessageFromWorker(workerPort, publishMessagePayload);
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
this.#workersEx[stsWorkerEx.id] = stsWorkerEx;
|
|
103
|
+
this.#debug(`Added worker: [${stsWorkerEx.id}]`);
|
|
104
|
+
return stsWorkerEx;
|
|
105
|
+
};
|
|
106
|
+
AddRunnerToWorker = (stsWorkerEx, runnerOptions) => {
|
|
107
|
+
const runnerEx = this.#CreateAsyncRunner(stsWorkerEx, runnerOptions);
|
|
108
|
+
stsWorkerEx.runnersEx[runnerEx.id] = runnerEx;
|
|
109
|
+
this.#SetRunnerIntoWorker(stsWorkerEx, runnerEx);
|
|
110
|
+
runnerEx.publishInstrumentController.LogEx(chalk_1.default.green(`Added runner: [${runnerEx.id}] into worker: [${stsWorkerEx.id}]`));
|
|
111
|
+
return runnerEx;
|
|
112
|
+
};
|
|
113
|
+
#CreateRunnerCopy(runnerEx) {
|
|
114
|
+
return {
|
|
115
|
+
id: runnerEx.id,
|
|
116
|
+
asyncRunnerContext: { ...runnerEx.asyncRunnerContext },
|
|
117
|
+
options: { ...runnerEx.options },
|
|
118
|
+
state: runnerEx.state,
|
|
119
|
+
instrumentData: { ...runnerEx.instrumentData }
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
#SetRunnerIntoWorker = (workerEx, runnerEx) => {
|
|
123
|
+
// Now that the worker is setup, send the options
|
|
124
|
+
//@@ wait until worker in running state
|
|
125
|
+
const payload = {
|
|
126
|
+
runner: this.#CreateRunnerCopy(runnerEx)
|
|
127
|
+
};
|
|
128
|
+
this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.AddAsyncRunner, payload);
|
|
129
|
+
};
|
|
130
|
+
#ProcessTelemetry = (workerEx, payloadContents) => {
|
|
131
|
+
//const store = TelemetryStore();
|
|
132
|
+
const { runner } = payloadContents;
|
|
133
|
+
if (workerEx.runnersEx[runner.id]) {
|
|
134
|
+
const runnerEx = workerEx.runnersEx[runner.id];
|
|
135
|
+
let update = false;
|
|
136
|
+
// Copy telemetry
|
|
137
|
+
runnerEx.instrumentData = { ...runner.instrumentData };
|
|
138
|
+
this.#debug(JSON.stringify(runnerEx.instrumentData));
|
|
139
|
+
if (runner.instrumentData.message) {
|
|
140
|
+
runnerEx.instrumentData.message = [...runner.instrumentData.message];
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
runnerEx.instrumentData.message = [];
|
|
144
|
+
}
|
|
145
|
+
if (runner.instrumentData.message) {
|
|
146
|
+
runner.instrumentData.message.forEach((message) => {
|
|
147
|
+
runnerEx.publishInstrumentController.LogEx(message);
|
|
148
|
+
});
|
|
149
|
+
update = true;
|
|
150
|
+
}
|
|
151
|
+
if (runner.instrumentData.requestCount) {
|
|
152
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.REQUEST_COUNT_GAUGE, {
|
|
153
|
+
val: runnerEx.instrumentData.requestCount
|
|
154
|
+
});
|
|
155
|
+
update = true;
|
|
156
|
+
}
|
|
157
|
+
if (runner.instrumentData.errorCount) {
|
|
158
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.ERROR_COUNT_GAUGE, {
|
|
159
|
+
val: runnerEx.instrumentData.errorCount
|
|
160
|
+
});
|
|
161
|
+
update = true;
|
|
162
|
+
}
|
|
163
|
+
if (runner.instrumentData.retryCount) {
|
|
164
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.RETRY_COUNT_GAUGE, {
|
|
165
|
+
val: runnerEx.instrumentData.retryCount
|
|
166
|
+
});
|
|
167
|
+
update = true;
|
|
168
|
+
}
|
|
169
|
+
if (runner.instrumentData.authenticationCount) {
|
|
170
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.AUTHENTICATION_COUNT_GAUGE, {
|
|
171
|
+
val: runnerEx.instrumentData.authenticationCount
|
|
172
|
+
});
|
|
173
|
+
update = true;
|
|
174
|
+
}
|
|
175
|
+
if (runner.instrumentData.authenticationErrorCount) {
|
|
176
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.AUTHENTICATION_ERROR_COUNT_GAUGE, {
|
|
177
|
+
val: runnerEx.instrumentData.authenticationCount
|
|
178
|
+
});
|
|
179
|
+
update = true;
|
|
180
|
+
}
|
|
181
|
+
if (runner.instrumentData.authenticationRetryCount) {
|
|
182
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.AUTHENTICATION_RETRY_COUNT_GAUGE, {
|
|
183
|
+
val: runnerEx.instrumentData.authenticationCount
|
|
184
|
+
});
|
|
185
|
+
update = true;
|
|
186
|
+
}
|
|
187
|
+
if (runner.instrumentData.coreCount) {
|
|
188
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.CORE_COUNT_GAUGE, {
|
|
189
|
+
val: runnerEx.instrumentData.coreCount
|
|
190
|
+
});
|
|
191
|
+
update = true;
|
|
192
|
+
}
|
|
193
|
+
if (runner.instrumentData.timer) {
|
|
194
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.TIMER_GAUGE, {
|
|
195
|
+
val: runnerEx.instrumentData.timer
|
|
196
|
+
});
|
|
197
|
+
update = true;
|
|
198
|
+
}
|
|
199
|
+
if (runner.instrumentData.activeRequestCount) {
|
|
200
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.ACTIVE_REQUEST_GAUGE, {
|
|
201
|
+
val: runnerEx.instrumentData.activeRequestCount
|
|
202
|
+
});
|
|
203
|
+
update = true;
|
|
204
|
+
}
|
|
205
|
+
if (runner.instrumentData.velocity) {
|
|
206
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.VELOCITY_GAUGE, {
|
|
207
|
+
Inc: runnerEx.instrumentData.velocity
|
|
208
|
+
});
|
|
209
|
+
update = true;
|
|
210
|
+
}
|
|
211
|
+
if (runner.instrumentData.duration) {
|
|
212
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.DURATION_GAUGE, {
|
|
213
|
+
val: runnerEx.instrumentData.duration
|
|
214
|
+
});
|
|
215
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.DURATION_HISTOGRAM_GAUGE, {
|
|
216
|
+
val: runnerEx.instrumentData.duration
|
|
217
|
+
});
|
|
218
|
+
update = true;
|
|
219
|
+
}
|
|
220
|
+
if (runner.instrumentData.latency) {
|
|
221
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.LATENCY_GAUGE, {
|
|
222
|
+
val: runnerEx.instrumentData.latency
|
|
223
|
+
});
|
|
224
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.LATENCY_HISTOGRAM_GAUGE, {
|
|
225
|
+
val: runnerEx.instrumentData.latency
|
|
226
|
+
});
|
|
227
|
+
update = true;
|
|
228
|
+
}
|
|
229
|
+
if (runner.instrumentData.childCount) {
|
|
230
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.CHILD_COUNT, {
|
|
231
|
+
val: runnerEx.instrumentData.childCount
|
|
232
|
+
});
|
|
233
|
+
update = true;
|
|
234
|
+
}
|
|
235
|
+
if (runner.instrumentData.rx) {
|
|
236
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.NETWORK_RX_GAUGE, {
|
|
237
|
+
Inc: runnerEx.instrumentData.rx
|
|
238
|
+
});
|
|
239
|
+
update = true;
|
|
240
|
+
}
|
|
241
|
+
if (runner.instrumentData.tx) {
|
|
242
|
+
runnerEx.publishInstrumentController.UpdateInstrument(stsobservability_1.Gauge.NETWORK_TX_GAUGE, {
|
|
243
|
+
Inc: runnerEx.instrumentData.tx
|
|
244
|
+
});
|
|
245
|
+
update = true;
|
|
246
|
+
}
|
|
247
|
+
if (update) {
|
|
248
|
+
//store.Update(workerEx, runnerEx);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
};
|
|
252
|
+
#CreateAsyncRunner = (workerEx, runnerOptions) => {
|
|
253
|
+
//const applicationStore = ApplicationStore();
|
|
254
|
+
this.#runner++; // The runner number always increases
|
|
255
|
+
this.#STSInstrumentController.LogEx(chalk_1.default.yellow(`Creating new async runner: [${this.#runner}]`));
|
|
256
|
+
const asyncRunnerContext = {
|
|
257
|
+
nid: `\
|
|
258
|
+
${workerEx.workerThreadWorkerOptions.hostName}${stsutils_1.ModelDelimeter.COMPONENT_SEPERATOR}${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}\
|
|
259
|
+
${stsutils_1.ModelDelimeter.NID_SEPERATOR}\
|
|
260
|
+
worker${workerEx.id}\
|
|
261
|
+
${stsutils_1.ModelDelimeter.SEPERATOR}\
|
|
262
|
+
${this.#runner}`,
|
|
263
|
+
id: this.#runner.toString(),
|
|
264
|
+
hostName: (workerEx.workerThreadWorkerOptions.hostName ? workerEx.workerThreadWorkerOptions.hostName : 'host'),
|
|
265
|
+
agentName: `${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}`,
|
|
266
|
+
threadId: `worker${workerEx.id}`,
|
|
267
|
+
asyncRunnerId: this.#runner
|
|
268
|
+
};
|
|
269
|
+
const runnerEx = {
|
|
270
|
+
id: this.#runner,
|
|
271
|
+
publishInstrumentController: this.#STSInstrumentController.AddPublishInstrumentController(asyncRunnerContext),
|
|
272
|
+
asyncRunnerContext: asyncRunnerContext,
|
|
273
|
+
state: stsTestWorkerDefinitions_1.IRunnerState.created,
|
|
274
|
+
options: runnerOptions,
|
|
275
|
+
instrumentData: {
|
|
276
|
+
requestCount: 0,
|
|
277
|
+
errorCount: 0,
|
|
278
|
+
retryCount: 0,
|
|
279
|
+
authenticationCount: 0,
|
|
280
|
+
authenticationErrorCount: 0,
|
|
281
|
+
authenticationRetryCount: 0,
|
|
282
|
+
velocity: 0,
|
|
283
|
+
coreCount: 0,
|
|
284
|
+
timer: 0,
|
|
285
|
+
duration: 0,
|
|
286
|
+
latency: 0,
|
|
287
|
+
activeRequestCount: 0,
|
|
288
|
+
message: [],
|
|
289
|
+
childCount: 0,
|
|
290
|
+
rx: 0,
|
|
291
|
+
tx: 0
|
|
292
|
+
},
|
|
293
|
+
Stop: async () => this.#StopRunner(workerEx, runnerEx)
|
|
294
|
+
};
|
|
295
|
+
return runnerEx;
|
|
296
|
+
};
|
|
297
|
+
#PostMessageToWorker = (workerEx, command, payload, transferObject) => {
|
|
298
|
+
if (transferObject) {
|
|
299
|
+
this.#debug(`#PostMessageToWorker with transfer object`);
|
|
300
|
+
workerEx.worker.postMessage({ command, payload }, [transferObject]);
|
|
301
|
+
this.#debug(`#PostMessageToWorker with transfer object - done...`);
|
|
302
|
+
}
|
|
303
|
+
else {
|
|
304
|
+
this.#debug(`#PostMessageToWorker`);
|
|
305
|
+
workerEx.worker.postMessage({ command, payload });
|
|
306
|
+
}
|
|
307
|
+
};
|
|
308
|
+
#TerminateWorker = (workerEx) => {
|
|
309
|
+
if (workerEx.worker) {
|
|
310
|
+
//const store = TelemetryStore();
|
|
311
|
+
workerEx.worker.terminate();
|
|
312
|
+
this.#debug(`Terminated worker: [${workerEx.id}]`);
|
|
313
|
+
//store.RemoveWorker(workerEx);
|
|
314
|
+
delete this.#workersEx[workerEx.id];
|
|
315
|
+
}
|
|
316
|
+
else {
|
|
317
|
+
// Some other runner has already removed the parent worker, do nothing
|
|
318
|
+
// console.log(`WORKER ALREADY NULL`);
|
|
319
|
+
}
|
|
320
|
+
};
|
|
321
|
+
#StopRunner = async (workerEx, runnerEx = null) => {
|
|
322
|
+
// If runnerEx not provided, Remove the first runner in the collection
|
|
323
|
+
if (runnerEx === null) {
|
|
324
|
+
const ids = Object.keys(workerEx.runnersEx);
|
|
325
|
+
if (ids.length > 0) {
|
|
326
|
+
const id = ids[0];
|
|
327
|
+
runnerEx = workerEx.runnersEx[id];
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
if (runnerEx !== null) {
|
|
331
|
+
this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.StopAllAsyncRunners, {
|
|
332
|
+
runner: this.#CreateRunnerCopy(runnerEx)
|
|
333
|
+
});
|
|
334
|
+
runnerEx.publishInstrumentController.LogEx(`Terminating runner: [${runnerEx.id}]`);
|
|
335
|
+
const promArray = [];
|
|
336
|
+
promArray.push((async () => {
|
|
337
|
+
await (0, stsutils_2.Sleep)(100);
|
|
338
|
+
return runnerEx.publishInstrumentController.EndPublish();
|
|
339
|
+
})());
|
|
340
|
+
//const store = TelemetryStore();
|
|
341
|
+
//store.RemoveRunner(workerEx, runnerEx);
|
|
342
|
+
delete workerEx.runnersEx[runnerEx.id];
|
|
343
|
+
const retVal = await Promise.all(promArray);
|
|
344
|
+
console.log(`Removed instrument workers: [${retVal}]`);
|
|
345
|
+
}
|
|
346
|
+
return true;
|
|
347
|
+
};
|
|
348
|
+
#StopWorker = async (workerEx) => {
|
|
349
|
+
try {
|
|
350
|
+
if (workerEx.state !== stsTestWorkerDefinitions_1.IWorkerState.stopped) {
|
|
351
|
+
this.#PostMessageToWorker(workerEx, commonTypes_1.eIWMessageCommands.StopAllAsyncRunners, null);
|
|
352
|
+
//@@ Now wait until we get an ack back from the worker
|
|
353
|
+
// This is because we may be trying to stop BEFORE the worker has had a chance to startup ...
|
|
354
|
+
console.log(`Terminating worker: [${workerEx.id}]`);
|
|
355
|
+
const promArray = [];
|
|
356
|
+
// Terminate only those that are currently running...
|
|
357
|
+
const ids = Object.keys(workerEx.runnersEx);
|
|
358
|
+
ids.forEach((id) => {
|
|
359
|
+
const runnerEx = workerEx.runnersEx[id];
|
|
360
|
+
promArray.push(this.#StopRunner(workerEx, runnerEx));
|
|
361
|
+
});
|
|
362
|
+
await Promise.all(promArray);
|
|
363
|
+
this.#TerminateWorker(workerEx);
|
|
364
|
+
}
|
|
365
|
+
return true;
|
|
366
|
+
}
|
|
367
|
+
catch (error) {
|
|
368
|
+
console.log(`Error in STSTestWorker:StopWorker: [${error}]`);
|
|
369
|
+
return false;
|
|
370
|
+
}
|
|
371
|
+
};
|
|
372
|
+
GetNextAvailableWorker = () => {
|
|
373
|
+
// Calculate the worker with the least runners
|
|
374
|
+
let leastRunnerWorker = null;
|
|
375
|
+
for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
|
|
376
|
+
if (leastRunnerWorker) {
|
|
377
|
+
if (Object.keys(stsWorker.runnersEx).length < Object.keys(leastRunnerWorker.runnersEx).length) {
|
|
378
|
+
leastRunnerWorker = stsWorker;
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
else {
|
|
382
|
+
leastRunnerWorker = stsWorker;
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
return leastRunnerWorker;
|
|
386
|
+
};
|
|
387
|
+
GetBusyWorker = () => {
|
|
388
|
+
// Calculate the worker with the least runners
|
|
389
|
+
let busyWorker = null;
|
|
390
|
+
for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
|
|
391
|
+
if (busyWorker) {
|
|
392
|
+
if (Object.keys(stsWorker.runnersEx).length > Object.keys(busyWorker.runnersEx).length) {
|
|
393
|
+
busyWorker = stsWorker;
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
else {
|
|
397
|
+
busyWorker = stsWorker;
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
return busyWorker;
|
|
401
|
+
};
|
|
402
|
+
get Options() {
|
|
403
|
+
return this.#options;
|
|
404
|
+
}
|
|
405
|
+
set Options(options) {
|
|
406
|
+
this.#options = options;
|
|
407
|
+
}
|
|
408
|
+
StopAllWorkers = async () => {
|
|
409
|
+
const promArray = [];
|
|
410
|
+
for (const [, stsWorker] of Object.entries(this.WorkersEx)) {
|
|
411
|
+
promArray.push(stsWorker.Stop());
|
|
412
|
+
}
|
|
413
|
+
await Promise.all(promArray);
|
|
414
|
+
};
|
|
415
|
+
}
|
|
416
|
+
exports.STSWorkerManager = STSWorkerManager;
|
|
417
|
+
//# 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 stsTestWorkerDefinitions_1 = require("./stsTestWorkerDefinitions");
|
|
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 stsTestWorkerDefinitions_1.PublishMessageCommandsTestRunner.GetAccessToken:
|
|
31
|
+
{
|
|
32
|
+
//const access_token = await this.#GetAccessToken();
|
|
33
|
+
const access_token = '1234';
|
|
34
|
+
workerPort.postMessage({
|
|
35
|
+
command: stsTestWorkerDefinitions_1.PublishMessageCommandsTestRunner.GetAccessTokenResponse,
|
|
36
|
+
payload: {
|
|
37
|
+
messageId: publishMessagePayload.payload.messageId,
|
|
38
|
+
access_token
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
break;
|
|
43
|
+
case stsTestWorkerDefinitions_1.PublishMessageCommandsTestRunner.ExecuteRefreshToken:
|
|
44
|
+
{
|
|
45
|
+
//const access_token = await this.#ExecuteRefreshToken();
|
|
46
|
+
const access_token = '5678';
|
|
47
|
+
workerPort.postMessage({
|
|
48
|
+
command: stsTestWorkerDefinitions_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,yEACuF;AAEvF,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,2DAAgC,CAAC,cAAc;gBAAG,CAAC;oBACpD,oDAAoD;oBACpD,MAAM,YAAY,GAAG,MAAM,CAAC;oBAC5B,UAAU,CAAC,WAAW,CAAC;wBACnB,OAAO,EAAE,2DAAgC,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,2DAAgC,CAAC,mBAAmB;gBAAG,CAAC;oBACzD,yDAAyD;oBACzD,MAAM,YAAY,GAAG,MAAM,CAAC;oBAC5B,UAAU,CAAC,WAAW,CAAC;wBACnB,OAAO,EAAE,2DAAgC,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 stsTestWorkerDefinitions_1 = require("./stsTestWorkerDefinitions");
|
|
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 !== stsTestWorkerDefinitions_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 = stsTestWorkerDefinitions_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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"}
|