@nsshunt/stsvueutils 1.0.15 → 1.0.17

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.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stsvueutils.mjs","sources":["../src/plugins/stsPluginKeys.ts","../node_modules/tiny-emitter/index.js","../src/plugins/emitter.ts","../node_modules/js-cookie/dist/js.cookie.mjs","../src/plugins/stsStorage.ts","../src/plugins/storage.ts","../src/stores/TelemetryStore.ts","../src/plugins/stsTestWorkerDefinitions.ts","../src/plugins/workerManager.ts","../src/plugins/requestResponseHelper.ts","../src/plugins/workerInstance.ts"],"sourcesContent":["// Individual STS plugin keys for provide/inject logic\nexport const STSStoragePluginKey = Symbol('storage')\nexport const STSEmitterPluginKey = Symbol('emitter')\nexport const STSWorkerManagerPluginKey = Symbol('workerManager')\n","function E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n","import { inject } from 'vue'\n\nimport { STSEmitterPluginKey } from './stsPluginKeys';\n\nimport * as te from 'tiny-emitter';\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSEmitterPlugin = (): te.TinyEmitter => inject(STSEmitterPluginKey) as te.TinyEmitter\n\n// https://learnvue.co/2021/06/building-your-own-vue-3-plugin-a-full-guide/\nexport const STSEmitterPlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: (app: any) => {\n const tinyEmitter: te.TinyEmitter = new te.TinyEmitter();\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSEmitterPluginKey] = tinyEmitter;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSEmitterPluginKey, tinyEmitter);\n }\n}\n","/*! js-cookie v3.0.1 | MIT */\n/* eslint-disable no-var */\nfunction assign (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n target[key] = source[key];\n }\n }\n return target\n}\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\nvar defaultConverter = {\n read: function (value) {\n if (value[0] === '\"') {\n value = value.slice(1, -1);\n }\n return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n },\n write: function (value) {\n return encodeURIComponent(value).replace(\n /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n decodeURIComponent\n )\n }\n};\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\n\nfunction init (converter, defaultAttributes) {\n function set (key, value, attributes) {\n if (typeof document === 'undefined') {\n return\n }\n\n attributes = assign({}, defaultAttributes, attributes);\n\n if (typeof attributes.expires === 'number') {\n attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n }\n if (attributes.expires) {\n attributes.expires = attributes.expires.toUTCString();\n }\n\n key = encodeURIComponent(key)\n .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n .replace(/[()]/g, escape);\n\n var stringifiedAttributes = '';\n for (var attributeName in attributes) {\n if (!attributes[attributeName]) {\n continue\n }\n\n stringifiedAttributes += '; ' + attributeName;\n\n if (attributes[attributeName] === true) {\n continue\n }\n\n // Considers RFC 6265 section 5.2:\n // ...\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n // Consume the characters of the unparsed-attributes up to,\n // not including, the first %x3B (\";\") character.\n // ...\n stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n }\n\n return (document.cookie =\n key + '=' + converter.write(value, key) + stringifiedAttributes)\n }\n\n function get (key) {\n if (typeof document === 'undefined' || (arguments.length && !key)) {\n return\n }\n\n // To prevent the for loop in the first place assign an empty array\n // in case there are no cookies at all.\n var cookies = document.cookie ? document.cookie.split('; ') : [];\n var jar = {};\n for (var i = 0; i < cookies.length; i++) {\n var parts = cookies[i].split('=');\n var value = parts.slice(1).join('=');\n\n try {\n var foundKey = decodeURIComponent(parts[0]);\n jar[foundKey] = converter.read(value, foundKey);\n\n if (key === foundKey) {\n break\n }\n } catch (e) {}\n }\n\n return key ? jar[key] : jar\n }\n\n return Object.create(\n {\n set: set,\n get: get,\n remove: function (key, attributes) {\n set(\n key,\n '',\n assign({}, attributes, {\n expires: -1\n })\n );\n },\n withAttributes: function (attributes) {\n return init(this.converter, assign({}, this.attributes, attributes))\n },\n withConverter: function (converter) {\n return init(assign({}, this.converter, converter), this.attributes)\n }\n },\n {\n attributes: { value: Object.freeze(defaultAttributes) },\n converter: { value: Object.freeze(converter) }\n }\n )\n}\n\nvar api = init(defaultConverter, { path: '/' });\n/* eslint-enable no-var */\n\nexport default api;\n","import Debug from 'debug';\nconst debug = Debug(`proc:${process.pid}:storage.ts`);\n\nimport Cookies from 'js-cookie'\nimport type { JSONObject } from \"@nsshunt/stsutils\";\n\nlet PREFIX = '_ststra_';\n\nexport interface IStsStorage<T> {\n\tget(key: string): T | null\n\tset(key: string, value: T, options?: JSONObject): void\n\tremove(key: string): void\n}\n\nexport enum ClientStorageType {\n\tLOCAL_STORAGE = 'LocalStorage', //@@ todo\n\tSESSION_STORAGE = 'SessionStorage',\n\tCOOKIE_STORAGE = 'CookieStorage',\n\tMEMORY_STORAGE = 'MemoryStorage' //@@ todo\n}\n\nclass CookieStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const raw = Cookies.get(PREFIX + key);\n if (raw) {\n return JSON.parse(raw);\n } else {\n return null;\n }\n }\n\n set = (key: string, value: T, options: JSONObject = { }) => {\n let cookieAttributes: Cookies.CookieAttributes = { };\n if ('https:' === window.location.protocol) {\n cookieAttributes = {\n secure: true,\n sameSite: 'none'\n };\n }\n\t\n if (options && options.daysUntilExpire) {\n cookieAttributes.expires = options.daysUntilExpire;\n } else {\n cookieAttributes.expires = 1;\n }\n debug(`CookieStorage.set: key: ${key}, value: [${value}]`);\n Cookies.set(PREFIX + key, JSON.stringify(value), cookieAttributes);\n }\n\n remove = (key: string): void => {\n Cookies.remove(PREFIX + key);\n }\n}\n\nclass SessionStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const value: string | null = sessionStorage.getItem(PREFIX + key);\n if (value) {\n return JSON.parse(value);\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`SessionStorage.set: key: ${key}, value: [${value}]`);\n sessionStorage.setItem(PREFIX + key, JSON.stringify(value));\n }\n \n remove = (key: string): void => {\n sessionStorage.removeItem(PREFIX + key);\n }\n}\n\nclass LocalStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const value: string | null = localStorage.getItem(PREFIX + key);\n if (value) {\n return JSON.parse(value);\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`LocalStorage.set: key: ${key}, value: [${value}]`);\n localStorage.setItem(PREFIX + key, JSON.stringify(value));\n }\n \n remove = (key: string): void => {\n localStorage.removeItem(PREFIX + key);\n }\n}\n\nclass MemoryStorage<T> implements IStsStorage<T>\n{\n #store: Record<string, T> = { };\n\n get = (key: string): T | null => {\n const value: T = this.#store[PREFIX + key];\n if (value) {\n return value;\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`MemoryStorage.set: key: ${key}, value: [${value}]`);\n this.#store[PREFIX + key] = value;\n }\n \n remove = (key: string): void => {\n delete this.#store[PREFIX + key];\n }\n}\n\nexport interface IClientStorageOptions {\n\tclientStorageType: ClientStorageType\n\tusePrefix: boolean\n\tstorageOptions?: JSONObject\n}\n\nexport class ClientStorageFactory<T>\n{\n #storage: IStsStorage<T>;\n\n constructor(options: IClientStorageOptions) {\n if (options.usePrefix === false) {\n PREFIX = '';\n }\n switch (options.clientStorageType) {\n case ClientStorageType.SESSION_STORAGE :\n this.#storage = new SessionStorage<T>();\n break;\n case ClientStorageType.LOCAL_STORAGE :\n this.#storage = new LocalStorage<T>();\n break;\n case ClientStorageType.COOKIE_STORAGE :\n this.#storage = new CookieStorage<T>();\n break;\n case ClientStorageType.MEMORY_STORAGE :\n this.#storage = new MemoryStorage<T>();\n break;\n default:\n throw new Error(`Unknown [${options.clientStorageType}] storage type.`);\n }\n return;\n }\n\n GetStorage(): IStsStorage<T>\n {\n return this.#storage;\n }\n}\n","import { inject } from \"vue\";\n\n// Declare STS plugin keys (for provide)\n// https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\nimport { STSStoragePluginKey } from './stsPluginKeys';\n\nimport { ClientStorageType, ClientStorageFactory, type IStsStorage } from './stsStorage'\n\nexport interface ISTSStoragePluginOptions {\n\tclientStorageType: ClientStorageType\n}\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSStoragePlugin = <T>(): IStsStorage<T> => inject(STSStoragePluginKey) as IStsStorage<T>\n\n// https://learnvue.co/2021/06/building-your-own-vue-3-plugin-a-full-guide/\nexport const STSStoragePlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: <T>(app: any, options: ISTSStoragePluginOptions) => {\n const cs = new ClientStorageFactory<T>({clientStorageType: options.clientStorageType, usePrefix: true});\n\n const pluginInstance = cs.GetStorage();\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n // This allows access to the $sts property within templates.\n // Also, outside of script setup or setup(), this.$sts can be used.\n // If access is required within script setup, use the useSTSStoragePlugin composable function. Example;\n // import { useSTSStoragePlugin } from './storage';\n // const STSStorageString = useSTSStoragePlugin<string>();\n //\n // Note: An alternate to get access to this global is to use the hidden API call such as;\n // const app: ComponentInternalInstance | null = getCurrentInstance();\n // Assign the $sts plugin helper (legacy method - see below (injects) for updated usage)\n // let $sts: any\n // if (app) $sts = app.appContext.config.globalProperties.$sts;\n\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSStoragePluginKey] = pluginInstance;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSStoragePluginKey, pluginInstance);\n }\n}\n","import { defineStore } from 'pinia'\n\nimport type { IWorker, IWorkerEx, IRunnerEx, IRunner, ITelemetryStore } from './../plugins/stsTestWorkerDefinitions'\n\n// https://pinia.vuejs.org/\n// https://seb-l.github.io/pinia-plugin-persist/\nexport const TelemetryStore = defineStore('__sts__TelemetryStore', {\n // State\n // https://pinia.vuejs.org/core-concepts/state.html\n state: (): ITelemetryStore => {\n return {\n workers: { }\n }\n },\n\n // Getters\n // https://pinia.vuejs.org/core-concepts/getters.html\n\n // Actions\n // https://pinia.vuejs.org/core-concepts/actions.html\n actions: {\n RemoveWorker(workerEx: IWorkerEx) {\n delete this.workers[workerEx.id];\n },\n\n RemoveRunner(workerEx: IWorkerEx, runnerEx: IRunnerEx) {\n const worker: IWorker = this.workers[workerEx.id];\n if (worker && worker.runners) {\n delete worker.runners[runnerEx.id];\n }\n },\n\n Update(workerEx: IWorkerEx, runnerEx: IRunnerEx) {\n if (!this.workers[workerEx.id]) {\n // Create a new telemetry record\n this.workers[workerEx.id] = {\n id: workerEx.id,\n state: workerEx.state,\n primaryThreadWorkerOptions: { ...workerEx.primaryThreadWorkerOptions },\n workerThreadWorkerOptions: { ...workerEx.workerThreadWorkerOptions },\n runners: { }\n } as IWorker\n }\n const worker: IWorker = this.workers[workerEx.id];\n // Now check for the async runner\n if (worker.runners) {\n if (!worker.runners[runnerEx.id]) {\n // Create a new asyncRunnerInstance telemetry record\n const runner: IRunner = {\n id: runnerEx.id,\n asyncRunnerContext: { ...runnerEx.asyncRunnerContext },\n options: { ...runnerEx.options },\n state: runnerEx.state,\n instrumentData: { ...runnerEx.instrumentData },\n }\n worker.runners[runner.id] = runner;\n } else {\n const runner: IRunner = worker.runners[runnerEx.id];\n runner.instrumentData = { ...runnerEx.instrumentData }\n }\n }\n }\n }\n});\n","import type { IPublishMessagePayloadContentBase, IAsyncRunnerContext, PublishInstrumentController, IPublishMessagePayload } from '@nsshunt/stspublisherserver'\n\nexport interface ISTSAgentWorkerMessagePort extends IPublishMessagePayloadContentBase {\n port: MessagePort\n options: IWorkerOptions\n}\n\nexport enum IRunnerState {\n\tcreated = 'created',\n\trunning = 'running',\n\tstopped = 'stopped',\n\tpaused = 'paused',\n\terror = 'error',\n}\n\nexport interface IRunnerTelemetry {\n\tcount: number\n\tvelocity: number\n\tmessage: string[]\n}\n\nexport interface IRunner {\n\tid: number\n\tasyncRunnerContext: IAsyncRunnerContext\n\toptions: IRunnerOptions\n\tstate: IRunnerState\n\tinstrumentData: IRunnerTelemetry\n}\n\nexport interface IRunnerEx extends IRunner {\n publishInstrumentController: PublishInstrumentController\n Stop: () => Promise<boolean>\n}\n\nexport enum IWorkerState {\n\tstarting = 'starting',\n\tstarted = 'started',\n\tstopped = 'stopped'\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IWorkerOptions {\n hostName: string\n agentId: string\n userAgent: string\n}\n\nexport type Runners = Record<string, IRunner>\n\nexport interface IWorker {\n\tid: number\n\tstate: IWorkerState\n primaryThreadWorkerOptions: IWorkerOptions\n\tworkerThreadWorkerOptions: IWorkerOptions\n\trunners?: Runners // Will be created by utility helper\n}\n\nexport type Workers = Record<string, IWorker>\n\nexport interface IPrimaryWorker {\n ProcessMessageFromWorker(workerPort: MessagePort, publishMessagePayload: IPublishMessagePayload): Promise<void>\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IRunnerOptions {\n\n}\n\nexport interface IWorkerEx extends IWorker {\n\tworker: Worker\n primaryWorker: IPrimaryWorker\n\trunnersEx: Record<string, IRunnerEx>\n\tAddRunner: (runnerOptions: IRunnerOptions) => IRunnerEx\n\tStopRunner: (runner: IRunnerEx) => Promise<boolean>\n\tStop: () => Promise<boolean>\n}\n\nexport interface ISTSTestWorkerOptions {\n messageMod: number\n iterations: number\n}\n\nexport interface ITelemetryStore {\n\tworkers: Workers\n}\n\nexport interface ITestRunnerTelemetryPayload extends IPublishMessagePayloadContentBase {\n\trunner: IRunner\n}\n\nexport interface IWorkerFactory {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n createPrimaryThreadWorker: (app: any, options: IWorkerOptions) => IPrimaryWorker\n\tcreateWorkerThreadWorker: () => Worker // | wt.Worker\n get workerThreadWorkerOptions(): IWorkerOptions // These options will be passed as a message to the thread worker once setup\n get primaryThreadWorkerOptions(): IWorkerOptions // These options will be passed as a message to the thread worker once setup\n}\n\nexport interface IWorkerManagerOptions {\n workerFactory: IWorkerFactory\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}:workerManager`);\n\n//import MyWorker from './sts-worker?worker' // https://vitejs.dev/guide/features.html#web-workers\nimport { type IAsyncRunnerContext, IPublishMessagePayload, IPublishMessagePayloadContentBase, \n type PublishMessageCommand, PublishMessageCommands, type AgentPublishInstrumentController } from '@nsshunt/stspublisherserver' \n \nimport { Gauge, InstrumentGaugeTelemetry } from '@nsshunt/stsinstrumentation'\n\nimport { ModelDelimeter } from '@nsshunt/stsmodels'\n\nimport { TelemetryStore } from './../stores/TelemetryStore'\n//import { ApplicationStore } from './../stores/applicationStore'\n\nimport type { ISTSAgentWorkerMessagePort, IWorkerEx, IRunner, IRunnerEx,\n ITestRunnerTelemetryPayload, IRunnerOptions, IRunnerTelemetry,\n IWorkerManagerOptions, IWorkerFactory } from './stsTestWorkerDefinitions'\n\nimport { IWorkerState, IRunnerState } from './stsTestWorkerDefinitions'\nimport { Sleep } from '@nsshunt/stsutils';\nimport { inject } from 'vue';\n\nimport { STSInstrumentControllerPluginKey, GetSTSInstrumentControllerPluginKey, GetSTSInstrumentController } from '@nsshunt/stspublisherserver'\nimport { STSWorkerManagerPluginKey } from './stsPluginKeys';\n\nexport class STSWorkerManager {\n //#agentSession: string = null;\n #workersEx: Record<string, IWorkerEx> = { };\n #runner = 0;\n #workerId = 0;\n #options: IWorkerManagerOptions;\n #STSInstrumentController: AgentPublishInstrumentController\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n #app: any\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n constructor(app: any, options?: IWorkerManagerOptions) {\n this.#app = app;\n if (options) {\n this.#options = options;\n } else {\n this.#options = { } as IWorkerManagerOptions;\n }\n\n debug(`CompareSTSInstrumentControllerPluginKeyWMEx(): [${CompareSTSInstrumentControllerPluginKeyWMEx()}]`);\n\n debug(`Attempting to get STSInstrumentControllerPlugin using symbol: [${String(STSInstrumentControllerPluginKey)}]`);\n //this.#STSInstrumentController = app.config.globalProperties.$sts[STSInstrumentControllerPluginKey]\n //this.#STSInstrumentController = app.config.globalProperties.$sts[GetSTSInstrumentControllerPluginKey()]\n this.#STSInstrumentController = GetSTSInstrumentController(app);\n //this.#STSInstrumentController = app.config.globalProperties.$sts.aic;\n\n debug(this.#STSInstrumentController);\n debug('keys within app.config.globalProperties.$sts');\n for (const [key, value] of Object.entries(app.config.globalProperties.$sts)) {\n debug(`${key}`);\n }\n\n if (!this.#STSInstrumentController) {\n debug(`Failed to get STSInstrumentControllerPlugin using symbol: [${String(STSInstrumentControllerPluginKey)}]`);\n }\n }\n \n get WorkersEx(): Record<string, IWorkerEx>\n {\n return this.#workersEx;\n }\n\n AddWorker = async (useWorkerFactory?: IWorkerFactory): Promise<IWorkerEx> => {\n let workerFactory: IWorkerFactory;\n if (useWorkerFactory) {\n // Use the supplied workFactory\n workerFactory = useWorkerFactory;\n } else {\n // Use the default workFactory\n workerFactory = this.#options.workerFactory\n }\n const stsWorkerEx: IWorkerEx = {\n id: this.#workerId++, // uuidv4()\n worker: workerFactory.createWorkerThreadWorker(),\n primaryWorker: workerFactory.createPrimaryThreadWorker(this.#app, workerFactory.primaryThreadWorkerOptions),\n state: IWorkerState.starting,\n workerThreadWorkerOptions: workerFactory.workerThreadWorkerOptions,\n primaryThreadWorkerOptions: workerFactory.primaryThreadWorkerOptions,\n runnersEx: { } as Record<string, IRunnerEx>,\n AddRunner: (runnerOptions: IRunnerOptions): IRunnerEx => this.AddRunnerToWorker(stsWorkerEx, runnerOptions),\n StopRunner: (runner: IRunnerEx): Promise<boolean> => this.#StopRunner(stsWorkerEx, runner),\n Stop: async (): Promise<boolean> => this.#StopWorker(stsWorkerEx)\n }\n console.log(`Adding worker: [${stsWorkerEx.id}]`);\n\n stsWorkerEx.worker.onmessage = function(data: MessageEvent) {\n console.log(data.data);\n }\n\n stsWorkerEx.worker.onerror = function(error) {\n console.log(error);\n };\n\n const { \n port1, // process message port\n port2 // collector message port\n } = new MessageChannel();\n\n const workerPort = port1;\n \n console.log(`STSWorkerManager::AddWorker::workerThreadWorkerOptions: [${JSON.stringify(stsWorkerEx.workerThreadWorkerOptions)}]`);\n\n this.#PostMessageToWorker(stsWorkerEx, PublishMessageCommands.MessagePort, {\n port: port2,\n //applicationStoreState: stateCopy,\n options: { ...stsWorkerEx.workerThreadWorkerOptions }\n } as ISTSAgentWorkerMessagePort, port2);\n \n // Process messages received back from the worker\n workerPort.onmessage = async (data: MessageEvent) => {\n const publishMessagePayload: IPublishMessagePayload = data.data as IPublishMessagePayload;\n switch (publishMessagePayload.command) {\n case PublishMessageCommands.MessagePortResponse : \n stsWorkerEx.state = IWorkerState.started;\n break;\n case PublishMessageCommands.InstrumentTelemetry :\n this.#ProcessTelemetry(stsWorkerEx, publishMessagePayload.payload as ITestRunnerTelemetryPayload);\n break;\n default :\n stsWorkerEx.primaryWorker.ProcessMessageFromWorker(workerPort, publishMessagePayload);\n }\n }\n\n this.#workersEx[stsWorkerEx.id] = stsWorkerEx;\n\n console.log(`Added worker: [${stsWorkerEx.id}]`);\n\n return stsWorkerEx;\n }\n\n AddRunnerToWorker = (stsWorkerEx: IWorkerEx, runnerOptions: IRunnerOptions): IRunnerEx => {\n const runnerEx: IRunnerEx = this.#CreateAsyncRunner(stsWorkerEx, runnerOptions);\n stsWorkerEx.runnersEx[runnerEx.id] = runnerEx;\n this.#SetRunnerIntoWorker(stsWorkerEx, runnerEx);\n return runnerEx;\n }\n\n #CreateRunnerCopy(runnerEx: IRunnerEx): IRunner {\n return {\n id: runnerEx.id,\n asyncRunnerContext: { ...runnerEx.asyncRunnerContext },\n options: { ...runnerEx.options },\n state: runnerEx.state,\n instrumentData: { ...runnerEx.instrumentData }\n } as IRunner\n }\n\n #SetRunnerIntoWorker = (workerEx: IWorkerEx, runnerEx: IRunnerEx): void => {\n // Now that the worker is setup, send the options\n //@@ wait until worker in running state\n const payload: ITestRunnerTelemetryPayload = {\n runner: this.#CreateRunnerCopy(runnerEx)\n }\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Add, payload);\n }\n\n #ProcessTelemetry = (workerEx: IWorkerEx, payloadContents: ITestRunnerTelemetryPayload): void => {\n const store = TelemetryStore();\n\n const { runner } = payloadContents;\n\n if (workerEx.runnersEx[runner.id]) {\n const runnerEx: IRunnerEx = workerEx.runnersEx[runner.id];\n let update = false;\n\n // Copy telemetry\n runnerEx.instrumentData.count = runner.instrumentData.count;\n runnerEx.instrumentData.velocity = runner.instrumentData.velocity;\n if (runner.instrumentData.message) {\n runnerEx.instrumentData.message = [...runner.instrumentData.message];\n } else {\n runnerEx.instrumentData.message = [ ];\n }\n\n if (runner.instrumentData.message) {\n runner.instrumentData.message.forEach((message) => {\n runnerEx.publishInstrumentController.LogEx(message);\n });\n update = true;\n }\n\n if (runner.instrumentData.count) {\n runnerEx.publishInstrumentController.UpdateInstrument(Gauge.REQUEST_COUNT_GAUGE, {\n val: runnerEx.instrumentData.count\n } as InstrumentGaugeTelemetry);\n runnerEx.publishInstrumentController.UpdateInstrument(Gauge.VELOCITY_GAUGE, {\n Inc: runnerEx.instrumentData.velocity\n } as InstrumentGaugeTelemetry);\n update = true;\n }\n\n if (update) {\n store.Update(workerEx, runnerEx);\n }\n }\n }\n\n #CreateAsyncRunner = (workerEx: IWorkerEx, runnerOptions: IRunnerOptions): IRunnerEx => {\n //const applicationStore = ApplicationStore();\n\n \n\n this.#runner++; // The runner number always increases\n const asyncRunnerContext: IAsyncRunnerContext = {\n nid: `\\\n${workerEx.workerThreadWorkerOptions.hostName}${ModelDelimeter.COMPONENT_SEPERATOR}${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}\\\n${ModelDelimeter.NID_SEPERATOR}\\\nworker${workerEx.id}\\\n${ModelDelimeter.SEPERATOR}\\\n${this.#runner}`,\n id: this.#runner.toString(),\n hostName: (workerEx.workerThreadWorkerOptions.hostName ? workerEx.workerThreadWorkerOptions.hostName : 'host'),\n agentName: `${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}`,\n threadId: `worker${workerEx.id}`,\n asyncRunnerId: this.#runner\n }\n const runnerEx: IRunnerEx = {\n id: this.#runner,\n publishInstrumentController: this.#STSInstrumentController.AddPublishInstrumentController(asyncRunnerContext),\n asyncRunnerContext: asyncRunnerContext,\n state: IRunnerState.created,\n options: runnerOptions,\n instrumentData: {\n count: 0,\n velocity: 0,\n message: [ ]\n } as IRunnerTelemetry,\n Stop: async (): Promise<boolean> => this.#StopRunner(workerEx, runnerEx)\n }\n return runnerEx;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n #PostMessageToWorker = (workerEx: IWorkerEx, command: PublishMessageCommand, payload: IPublishMessagePayloadContentBase | null, transferObject?: any) => {\n if (transferObject) {\n console.log(`#PostMessageToWorker with transfer object`);\n workerEx.worker.postMessage({ command, payload }, [transferObject]);\n console.log(`#PostMessageToWorker with transfer object - done...`);\n } else {\n console.log(`#PostMessageToWorker`);\n workerEx.worker.postMessage({ command, payload });\n }\n }\n\n #TerminateWorker = (workerEx: IWorkerEx) => {\n if (workerEx.worker) {\n const store = TelemetryStore();\n\n workerEx.worker.terminate();\n //@@workerEx.worker = null;\n console.log(`Terminated worker: [${workerEx.id}]`);\n store.RemoveWorker(workerEx);\n delete this.#workersEx[workerEx.id];\n } else {\n // Some other runner has already removed the parent worker, do nothing\n // console.log(`WORKER ALREADY NULL`);\n }\n }\n\n #StopRunner = async (workerEx: IWorkerEx, runnerEx: IRunnerEx | null = null): Promise<boolean> => {\n // If runnerEx not provided, Remove the first runner in the collection\n if (runnerEx === null) {\n const ids: string[] = Object.keys(workerEx.runnersEx);\n if (ids.length > 0) {\n const id = ids[0];\n runnerEx = workerEx.runnersEx[id];\n }\n }\n if (runnerEx !== null) {\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Stop, {\n runner: this.#CreateRunnerCopy(runnerEx)\n } as ITestRunnerTelemetryPayload);\n\n runnerEx.publishInstrumentController.LogEx(`Terminating runner: [${runnerEx.id}]`);\n \n const promArray: Promise<boolean[]>[] = [ ];\n\n promArray.push((async (): Promise<boolean[]> => {\n await Sleep(100);\n return runnerEx.publishInstrumentController.InstrumentTerminate();\n })());\n\n const store = TelemetryStore();\n store.RemoveRunner(workerEx, runnerEx);\n\n delete workerEx.runnersEx[runnerEx.id];\n\n const retVal = await Promise.all(promArray);\n console.log(`Removed instrument workers: [${retVal}]`);\n\n /*\n // If the removed runner was the last runner, remove the worker\n if (Object.keys(workerEx.runnersEx).length === 0) {\n this.#TerminateWorker(workerEx);\n }\n */\n }\n return true;\n }\n\n #StopWorker = async (workerEx: IWorkerEx): Promise<boolean> => {\n try {\n if (workerEx.state !== IWorkerState.stopped) {\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Stop, null);\n \n //@@ Now wait until we get an ack back from the worker\n // This is because we may be trying to stop BEFORE the worker has had a chance to startup ...\n \n console.log(`Terminating worker: [${workerEx.id}]`);\n const promArray: Promise<boolean>[] = [ ];\n \n // Terminate only those that are currently running...\n const ids: string[] = Object.keys(workerEx.runnersEx);\n\n ids.forEach((id) => {\n const runnerEx: IRunnerEx = workerEx.runnersEx[id];\n promArray.push(this.#StopRunner(workerEx, runnerEx));\n });\n await Promise.all(promArray);\n\n this.#TerminateWorker(workerEx);\n }\n return true;\n } catch (error) {\n console.log(`Error in STSTestWorker:StopWorker: [${error}]`);\n return false;\n }\n }\n\n GetNextAvailableWorker = (): IWorkerEx | null => {\n // Calculate the worker with the least runners\n let leastRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (leastRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length < Object.keys(leastRunnerWorker.runnersEx).length) {\n leastRunnerWorker = stsWorker;\n }\n } else {\n leastRunnerWorker = stsWorker;\n }\n }\n return leastRunnerWorker;\n }\n\n GetBusyWorker = (): IWorkerEx | null => {\n // Calculate the worker with the least runners\n let busyWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (busyWorker) {\n if (Object.keys(stsWorker.runnersEx).length > Object.keys(busyWorker.runnersEx).length) {\n busyWorker = stsWorker;\n }\n } else {\n busyWorker = stsWorker;\n }\n }\n return busyWorker;\n }\n\n get Options(): IWorkerManagerOptions {\n return this.#options;\n }\n\n set Options(options: IWorkerManagerOptions) {\n this.#options = options;\n }\n\n /*\n StopRunner = async () => {\n // Calculate the worker with the most runners\n let largestRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (largestRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length > Object.keys(largestRunnerWorker.runnersEx).length) {\n largestRunnerWorker = stsWorker;\n }\n } else {\n largestRunnerWorker = stsWorker;\n }\n }\n if (largestRunnerWorker) largestRunnerWorker.StopRunner();\n }\n */\n\n /*\n StopWorker = async () => {\n // Calculate the worker with the least runners\n let largestRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (largestRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length < Object.keys(largestRunnerWorker.runnersEx).length) {\n largestRunnerWorker = stsWorker;\n }\n } else {\n largestRunnerWorker = stsWorker;\n }\n }\n if (largestRunnerWorker) largestRunnerWorker.Stop();\n }\n */\n\n StopAllWorkers = async () => {\n const promArray = [ ];\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n promArray.push(stsWorker.Stop());\n }\n\n await Promise.all(promArray);\n }\n}\n\nexport const GetSTSInstrumentControllerPluginKeyWM = (): symbol => STSInstrumentControllerPluginKey\n\nexport const CompareSTSInstrumentControllerPluginKeyWM = (val: symbol): boolean => val === STSInstrumentControllerPluginKey\n\nexport const CompareSTSInstrumentControllerPluginKeyWMEx = (): boolean => STSInstrumentControllerPluginKey === GetSTSInstrumentControllerPluginKey()\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSWorkerManager = (): STSWorkerManager => inject(STSWorkerManagerPluginKey) as STSWorkerManager\n\nexport const STSWorkerManagerPlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: (app: any, options?: IWorkerManagerOptions) => {\n const wm = new STSWorkerManager(app, options);\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSWorkerManagerPluginKey] = wm;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSWorkerManagerPluginKey, wm);\n }\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}`);\n\nimport type { IPublishMessagePayload } from '@nsshunt/stspublisherserver';\n\ndeclare interface RequestResponseMessage {\n\tpublishMessagePayload: IPublishMessagePayload\n\tpublishMessagePayloadResponse?: IPublishMessagePayload\n\tcb: () => void,\n\ttimeout: NodeJS.Timeout\n}\n\ndeclare type RequestResponseMessages = Record<string, RequestResponseMessage>;\n\nexport class RequestResponseHelper\n{\n #requestResponseMessages: RequestResponseMessages = { }\n #requestResponseMessageTimeout = 10000; //@@ config\n #port: MessagePort\n\n constructor(port: MessagePort) {\n this.#port = port\n this.#SetupListener();\n }\n\n PostMessage = (message: IPublishMessagePayload): Promise<IPublishMessagePayload> => {\n return new Promise((resolve, reject) => {\n const { messageId } = message.payload;\n if (messageId) {\n if (this.#requestResponseMessages[messageId]) {\n reject(`RequestResponseHelper: Message with id: [${messageId}] already exists within the Request/Response record structure`);\n } else {\n this.#requestResponseMessages[messageId] = {\n publishMessagePayload: { ...message },\n cb: () => {\n const detail = this.#requestResponseMessages[messageId].publishMessagePayloadResponse;\n clearTimeout(this.#requestResponseMessages[messageId].timeout);\n setTimeout(() => {\n delete this.#requestResponseMessages[messageId];\n }, 0);\n if (detail) {\n debug(`RequestResponseHelper: Resolving response message with id: [${messageId}] from target worker port. Details: [${JSON.stringify(detail)}]`);\n resolve(detail);\n } else {\n const msg = `Could not get detail from this.#requestResponseMessages[messageId].publishMessagePayloadResponse`;\n debug(msg);\n reject(msg);\n }\n },\n timeout: setTimeout(() => {\n setTimeout(() => {\n delete this.#requestResponseMessages[messageId];\n }, 0);\n debug(`RequestResponseHelper: Timeout has occurred after: [${this.#requestResponseMessageTimeout}]ms with message id: [${messageId}]. Details: [${JSON.stringify(this.#requestResponseMessages[messageId].publishMessagePayload)}]`);\n reject('RequestResponseHelper: Did not receive response form parent process.');\n }, this.#requestResponseMessageTimeout) // max message timeout allowed\n }\n debug(`RequestResponseHelper: Sending message with id: [${messageId}] to target worker port. Details: [${JSON.stringify(this.#requestResponseMessages[messageId].publishMessagePayload)}]`);\n this.#port.postMessage(message);\n }\n } else {\n const msg = `RequestResponseHelper: Response did not include a message id`;\n debug(msg);\n reject(msg);\n }\n });\n }\n\n #SetupListener = () => {\n this.#port.onmessage = async (msg: MessageEvent) => {\n const publishMessagePayload: IPublishMessagePayload = msg.data as IPublishMessagePayload;\n if (publishMessagePayload.payload.messageId) {\n const messageId = publishMessagePayload.payload.messageId;\n if (messageId && messageId !== '') {\n if (this.#requestResponseMessages[messageId]) {\n const requestResponseMessage: RequestResponseMessage = this.#requestResponseMessages[messageId];\n requestResponseMessage.publishMessagePayloadResponse = { ...publishMessagePayload };\n requestResponseMessage.cb();\n } else {\n throw new Error(`RequestResponseHelper: Could not find Request/Response message with id: [${messageId}]`);\n }\n }\n }\n }\n }\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}:workerInstance`);\n\nimport { IPublishMessagePayload, PublishMessageCommands, IPublishMessagePayloadContentBase } from '@nsshunt/stspublisherserver' // '@nsshunt/stspublisherserver' //'./plugins/publishers/publisherAgent'\n\nimport type { ISTSAgentWorkerMessagePort, IRunner, ITestRunnerTelemetryPayload } from './stsTestWorkerDefinitions'\nimport { IRunnerState } from './stsTestWorkerDefinitions'\n\nimport { RequestResponseHelper } from './requestResponseHelper'\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IWorkerInstanceOptions {\n\n}\n\nexport abstract class WorkerInstance {\n #collectorCollectorPort: MessagePort | null = null;\n #requestResponseHelper: RequestResponseHelper | null = null;\n #runners: Record<string, IRunner> = { };\n #options: IWorkerInstanceOptions | null = null;\n\n constructor() {\n debug(`WorkerInstance::constructor`)\n }\n\n GetRandomInt = (max: number) => {\n debug(`WorkerInstance::GetRandomInt`)\n return Math.floor(Math.random() * Math.floor(max));\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n StartWork = async (runner: IRunner): Promise<void> => {\n debug(`WorkerInstance::StartWork`)\n return;\n }\n\n PostTelemetry = (runner: IRunner) => {\n //debug(`WorkerInstance::PostTelemetry`)\n if (this.#collectorCollectorPort) {\n const message: IPublishMessagePayload = {\n command: PublishMessageCommands.InstrumentTelemetry,\n payload: {\n runner\n } as ITestRunnerTelemetryPayload\n }\n this.#collectorCollectorPort.postMessage(message);\n }\n }\n\n get RequestResponseHelper(): RequestResponseHelper | null {\n return this.#requestResponseHelper;\n }\n\n get CollectorCollectorPort(): MessagePort | null {\n return this.#collectorCollectorPort;\n }\n\n get Options(): IWorkerInstanceOptions | null {\n return this.#options;\n }\n\n #SetMessagePort = (workerMessagePort: ISTSAgentWorkerMessagePort) => {\n debug(`WorkerInstance::SetMessagePort`)\n this.#collectorCollectorPort = workerMessagePort.port as MessagePort;\n this.#collectorCollectorPort.onmessage = function(data: MessageEvent) {\n console.log(`collectorCollectorPort onmessage: ${data.data}`);\n }\n\n this.#requestResponseHelper = new RequestResponseHelper(this.#collectorCollectorPort);\n\n const response: IPublishMessagePayload = {\n command: PublishMessageCommands.MessagePortResponse,\n payload: { } as IPublishMessagePayloadContentBase\n }\n\n this.#collectorCollectorPort.postMessage(response);\n }\n\n StartRunner = async (runner: IRunner) => {\n debug(`WorkerInstance::StartRunner`)\n console.log(`StartTests: [${JSON.stringify(runner)}]`);\n runner.state = IRunnerState.running;\n this.StartWork(runner);\n }\n\n #AddAsyncRunner = (testRunnerTelemetryPayload: ITestRunnerTelemetryPayload) => {\n debug(`WorkerInstance::AddAsyncRunner`)\n const { runner } = testRunnerTelemetryPayload;\n this.#runners[runner.id] = runner;\n this.StartRunner(runner);\n }\n\n #StopRunners = (testRunnerTelemetryPayload: ITestRunnerTelemetryPayload) => {\n debug(`WorkerInstance::StopRunners`)\n if (testRunnerTelemetryPayload === null) {\n for (const [, testRunner] of Object.entries(this.#runners)) {\n testRunner.state = IRunnerState.stopped;\n }\n } else {\n const runner: IRunner = this.#runners[testRunnerTelemetryPayload.runner.id];\n if (runner) {\n runner.state = IRunnerState.stopped;\n }\n }\n }\n\n ProcessMessage = async(data: MessageEvent) => {\n debug(`WorkerInstance::ProcessMessage`)\n try {\n const payloadMessage: IPublishMessagePayload = data.data as IPublishMessagePayload;\n switch (payloadMessage.command) {\n case PublishMessageCommands.MessagePort :\n this.#SetMessagePort(payloadMessage.payload as ISTSAgentWorkerMessagePort);\n this.#options = (payloadMessage.payload as ISTSAgentWorkerMessagePort).options;\n debug(`WorkerInstance::ProcessMessage::#options: [${JSON.stringify(this.#options)}]`)\n break;\n case PublishMessageCommands.Add :\n this.#AddAsyncRunner(payloadMessage.payload as ITestRunnerTelemetryPayload);\n break;\n case PublishMessageCommands.Stop :\n this.#StopRunners(payloadMessage.payload as ITestRunnerTelemetryPayload);\n break;\n default :\n debug(`Invalid payloadMessage.command: [${payloadMessage.command}] - Ignoring`);\n }\n } catch (error) {\n console.log(error);\n }\n }\n}"],"names":["STSStoragePluginKey","STSEmitterPluginKey","STSWorkerManagerPluginKey","E","name","callback","ctx","e","self","listener","data","evtArr","i","len","evts","liveEvents","tinyEmitterModule","TinyEmitter","tinyEmitter","useSTSEmitterPlugin","inject","STSEmitterPlugin","app","te.TinyEmitter","assign","target","source","key","defaultConverter","value","init","converter","defaultAttributes","set","attributes","stringifiedAttributes","attributeName","get","cookies","jar","parts","foundKey","api","debug","Debug","PREFIX","ClientStorageType","CookieStorage","__publicField","raw","Cookies","options","cookieAttributes","SessionStorage","LocalStorage","MemoryStorage","__privateAdd","_store","__privateGet","ClientStorageFactory","_storage","__privateSet","useSTSStoragePlugin","STSStoragePlugin","pluginInstance","TelemetryStore","defineStore","workerEx","runnerEx","worker","runner","IRunnerState","IWorkerState","debugModule","STSWorkerManager","_CreateRunnerCopy","_workersEx","_runner","_workerId","_options","_STSInstrumentController","_app","useWorkerFactory","workerFactory","stsWorkerEx","__privateWrapper","runnerOptions","_StopRunner","_StopWorker","error","port1","port2","workerPort","_PostMessageToWorker","PublishMessageCommands","publishMessagePayload","_ProcessTelemetry","_CreateAsyncRunner","_SetRunnerIntoWorker","payload","__privateMethod","CreateRunnerCopy_fn","payloadContents","store","update","message","Gauge","asyncRunnerContext","ModelDelimeter","command","transferObject","_TerminateWorker","ids","id","promArray","Sleep","retVal","leastRunnerWorker","stsWorker","busyWorker","CompareSTSInstrumentControllerPluginKeyWMEx","STSInstrumentControllerPluginKey","GetSTSInstrumentController","GetSTSInstrumentControllerPluginKeyWM","CompareSTSInstrumentControllerPluginKeyWM","val","GetSTSInstrumentControllerPluginKey","useSTSWorkerManager","STSWorkerManagerPlugin","wm","RequestResponseHelper","port","_requestResponseMessages","_requestResponseMessageTimeout","_port","resolve","reject","messageId","detail","msg","_SetupListener","requestResponseMessage","WorkerInstance","_collectorCollectorPort","_requestResponseHelper","_runners","max","_SetMessagePort","workerMessagePort","response","_AddAsyncRunner","testRunnerTelemetryPayload","_StopRunners","testRunner","payloadMessage"],"mappings":"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","x_google_ignoreList":[1,3]}
@@ -0,0 +1,2 @@
1
+ (function(i,l){typeof exports=="object"&&typeof module<"u"?l(exports,require("vue"),require("debug"),require("@nsshunt/stspublisherserver"),require("@nsshunt/stsinstrumentation"),require("@nsshunt/stsmodels"),require("pinia"),require("@nsshunt/stsutils")):typeof define=="function"&&define.amd?define(["exports","vue","debug","@nsshunt/stspublisherserver","@nsshunt/stsinstrumentation","@nsshunt/stsmodels","pinia","@nsshunt/stsutils"],l):(i=typeof globalThis<"u"?globalThis:i||self,l(i["@nsshunt/stsvueutils"]={},i.vue,i.debug,i.stspublisherserver,i.stsinstrumentation,i.stsmodels,i.pinia,i.stsutils))})(this,function(i,l,g,m,U,re,ye,ke){var $,P,w,R,z,W,C,N,j,de,V,Y,Q,M,X,v,Z,f,E,b,x,T,K,A,D,ee,te,se;"use strict";var je=Object.defineProperty;var Ee=(i,l,g)=>l in i?je(i,l,{enumerable:!0,configurable:!0,writable:!0,value:g}):i[l]=g;var d=(i,l,g)=>(Ee(i,typeof l!="symbol"?l+"":l,g),g),ue=(i,l,g)=>{if(!l.has(i))throw TypeError("Cannot "+g)};var o=(i,l,g)=>(ue(i,l,"read from private field"),g?g.call(i):l.get(i)),c=(i,l,g)=>{if(l.has(i))throw TypeError("Cannot add the same private member more than once");l instanceof WeakSet?l.add(i):l.set(i,g)},p=(i,l,g,m)=>(ue(i,l,"write to private field"),m?m.call(i,g):l.set(i,g),g),ce=(i,l,g,m)=>({set _(U){p(i,l,U,g)},get _(){return o(i,l,m)}}),ge=(i,l,g)=>(ue(i,l,"access private method"),g);const _=Symbol("storage"),J=Symbol("emitter"),H=Symbol("workerManager");var ne={},Te={get exports(){return ne},set exports(r){ne=r}};function oe(){}oe.prototype={on:function(r,e,t){var s=this.e||(this.e={});return(s[r]||(s[r]=[])).push({fn:e,ctx:t}),this},once:function(r,e,t){var s=this;function n(){s.off(r,n),e.apply(t,arguments)}return n._=e,this.on(r,n,t)},emit:function(r){var e=[].slice.call(arguments,1),t=((this.e||(this.e={}))[r]||[]).slice(),s=0,n=t.length;for(s;s<n;s++)t[s].fn.apply(t[s].ctx,e);return this},off:function(r,e){var t=this.e||(this.e={}),s=t[r],n=[];if(s&&e)for(var a=0,u=s.length;a<u;a++)s[a].fn!==e&&s[a].fn._!==e&&n.push(s[a]);return n.length?t[r]=n:delete t[r],this}},Te.exports=oe;var Pe=ne.TinyEmitter=oe;const Re=()=>l.inject(J),We={install:r=>{const e=new Pe;r.config.globalProperties.$sts||(r.config.globalProperties.$sts={}),r.config.globalProperties.$sts[J]=e,r.provide(J,e)}};/*! js-cookie v3.0.1 | MIT */function L(r){for(var e=1;e<arguments.length;e++){var t=arguments[e];for(var s in t)r[s]=t[s]}return r}var Ce={read:function(r){return r[0]==='"'&&(r=r.slice(1,-1)),r.replace(/(%[\dA-F]{2})+/gi,decodeURIComponent)},write:function(r){return encodeURIComponent(r).replace(/%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,decodeURIComponent)}};function ie(r,e){function t(n,a,u){if(!(typeof document>"u")){u=L({},e,u),typeof u.expires=="number"&&(u.expires=new Date(Date.now()+u.expires*864e5)),u.expires&&(u.expires=u.expires.toUTCString()),n=encodeURIComponent(n).replace(/%(2[346B]|5E|60|7C)/g,decodeURIComponent).replace(/[()]/g,escape);var h="";for(var y in u)u[y]&&(h+="; "+y,u[y]!==!0&&(h+="="+u[y].split(";")[0]));return document.cookie=n+"="+r.write(a,n)+h}}function s(n){if(!(typeof document>"u"||arguments.length&&!n)){for(var a=document.cookie?document.cookie.split("; "):[],u={},h=0;h<a.length;h++){var y=a[h].split("="),Ne=y.slice(1).join("=");try{var le=decodeURIComponent(y[0]);if(u[le]=r.read(Ne,le),n===le)break}catch{}}return n?u[n]:u}}return Object.create({set:t,get:s,remove:function(n,a){t(n,"",L({},a,{expires:-1}))},withAttributes:function(n){return ie(this.converter,L({},this.attributes,n))},withConverter:function(n){return ie(L({},this.converter,n),this.attributes)}},{attributes:{value:Object.freeze(e)},converter:{value:Object.freeze(r)}})}var ae=ie(Ce,{path:"/"});const F=g(`proc:${process.pid}:storage.ts`);let S="_ststra_";var me=(r=>(r.LOCAL_STORAGE="LocalStorage",r.SESSION_STORAGE="SessionStorage",r.COOKIE_STORAGE="CookieStorage",r.MEMORY_STORAGE="MemoryStorage",r))(me||{});class Me{constructor(){d(this,"get",e=>{const t=ae.get(S+e);return t?JSON.parse(t):null});d(this,"set",(e,t,s={})=>{let n={};window.location.protocol==="https:"&&(n={secure:!0,sameSite:"none"}),s&&s.daysUntilExpire?n.expires=s.daysUntilExpire:n.expires=1,F(`CookieStorage.set: key: ${e}, value: [${t}]`),ae.set(S+e,JSON.stringify(t),n)});d(this,"remove",e=>{ae.remove(S+e)})}}class Ie{constructor(){d(this,"get",e=>{const t=sessionStorage.getItem(S+e);return t?JSON.parse(t):null});d(this,"set",(e,t)=>{F(`SessionStorage.set: key: ${e}, value: [${t}]`),sessionStorage.setItem(S+e,JSON.stringify(t))});d(this,"remove",e=>{sessionStorage.removeItem(S+e)})}}class Oe{constructor(){d(this,"get",e=>{const t=localStorage.getItem(S+e);return t?JSON.parse(t):null});d(this,"set",(e,t)=>{F(`LocalStorage.set: key: ${e}, value: [${t}]`),localStorage.setItem(S+e,JSON.stringify(t))});d(this,"remove",e=>{localStorage.removeItem(S+e)})}}class $e{constructor(){c(this,$,{});d(this,"get",e=>{const t=o(this,$)[S+e];return t||null});d(this,"set",(e,t)=>{F(`MemoryStorage.set: key: ${e}, value: [${t}]`),o(this,$)[S+e]=t});d(this,"remove",e=>{delete o(this,$)[S+e]})}}$=new WeakMap;class he{constructor(e){c(this,P,void 0);switch(e.usePrefix===!1&&(S=""),e.clientStorageType){case"SessionStorage":p(this,P,new Ie);break;case"LocalStorage":p(this,P,new Oe);break;case"CookieStorage":p(this,P,new Me);break;case"MemoryStorage":p(this,P,new $e);break;default:throw new Error(`Unknown [${e.clientStorageType}] storage type.`)}}GetStorage(){return o(this,P)}}P=new WeakMap;const we=()=>l.inject(_),ve={install:(r,e)=>{const s=new he({clientStorageType:e.clientStorageType,usePrefix:!0}).GetStorage();r.config.globalProperties.$sts||(r.config.globalProperties.$sts={}),r.config.globalProperties.$sts[_]=s,r.provide(_,s)}},B=ye.defineStore("__sts__TelemetryStore",{state:()=>({workers:{}}),actions:{RemoveWorker(r){delete this.workers[r.id]},RemoveRunner(r,e){const t=this.workers[r.id];t&&t.runners&&delete t.runners[e.id]},Update(r,e){this.workers[r.id]||(this.workers[r.id]={id:r.id,state:r.state,primaryThreadWorkerOptions:{...r.primaryThreadWorkerOptions},workerThreadWorkerOptions:{...r.workerThreadWorkerOptions},runners:{}});const t=this.workers[r.id];if(t.runners)if(t.runners[e.id]){const s=t.runners[e.id];s.instrumentData={...e.instrumentData}}else{const s={id:e.id,asyncRunnerContext:{...e.asyncRunnerContext},options:{...e.options},state:e.state,instrumentData:{...e.instrumentData}};t.runners[s.id]=s}}}});var I=(r=>(r.created="created",r.running="running",r.stopped="stopped",r.paused="paused",r.error="error",r))(I||{}),q=(r=>(r.starting="starting",r.started="started",r.stopped="stopped",r))(q||{});const O=g(`proc:${process.pid}:workerManager`);class pe{constructor(e,t){c(this,j);c(this,w,{});c(this,R,0);c(this,z,0);c(this,W,void 0);c(this,C,void 0);c(this,N,void 0);d(this,"AddWorker",async e=>{let t;e?t=e:t=o(this,W).workerFactory;const s={id:ce(this,z)._++,worker:t.createWorkerThreadWorker(),primaryWorker:t.createPrimaryThreadWorker(o(this,N),t.primaryThreadWorkerOptions),state:q.starting,workerThreadWorkerOptions:t.workerThreadWorkerOptions,primaryThreadWorkerOptions:t.primaryThreadWorkerOptions,runnersEx:{},AddRunner:h=>this.AddRunnerToWorker(s,h),StopRunner:h=>o(this,v).call(this,s,h),Stop:async()=>o(this,Z).call(this,s)};console.log(`Adding worker: [${s.id}]`),s.worker.onmessage=function(h){console.log(h.data)},s.worker.onerror=function(h){console.log(h)};const{port1:n,port2:a}=new MessageChannel,u=n;return console.log(`STSWorkerManager::AddWorker::workerThreadWorkerOptions: [${JSON.stringify(s.workerThreadWorkerOptions)}]`),o(this,M).call(this,s,m.PublishMessageCommands.MessagePort,{port:a,options:{...s.workerThreadWorkerOptions}},a),u.onmessage=async h=>{const y=h.data;switch(y.command){case m.PublishMessageCommands.MessagePortResponse:s.state=q.started;break;case m.PublishMessageCommands.InstrumentTelemetry:o(this,Y).call(this,s,y.payload);break;default:s.primaryWorker.ProcessMessageFromWorker(u,y)}},o(this,w)[s.id]=s,console.log(`Added worker: [${s.id}]`),s});d(this,"AddRunnerToWorker",(e,t)=>{const s=o(this,Q).call(this,e,t);return e.runnersEx[s.id]=s,o(this,V).call(this,e,s),s});c(this,V,(e,t)=>{const s={runner:ge(this,j,de).call(this,t)};o(this,M).call(this,e,m.PublishMessageCommands.Add,s)});c(this,Y,(e,t)=>{const s=B(),{runner:n}=t;if(e.runnersEx[n.id]){const a=e.runnersEx[n.id];let u=!1;a.instrumentData.count=n.instrumentData.count,a.instrumentData.velocity=n.instrumentData.velocity,n.instrumentData.message?a.instrumentData.message=[...n.instrumentData.message]:a.instrumentData.message=[],n.instrumentData.message&&(n.instrumentData.message.forEach(h=>{a.publishInstrumentController.LogEx(h)}),u=!0),n.instrumentData.count&&(a.publishInstrumentController.UpdateInstrument(U.Gauge.REQUEST_COUNT_GAUGE,{val:a.instrumentData.count}),a.publishInstrumentController.UpdateInstrument(U.Gauge.VELOCITY_GAUGE,{Inc:a.instrumentData.velocity}),u=!0),u&&s.Update(e,a)}});c(this,Q,(e,t)=>{ce(this,R)._++;const s={nid:`${e.workerThreadWorkerOptions.hostName}${re.ModelDelimeter.COMPONENT_SEPERATOR}${e.workerThreadWorkerOptions.agentId}-${e.workerThreadWorkerOptions.userAgent}${re.ModelDelimeter.NID_SEPERATOR}worker${e.id}${re.ModelDelimeter.SEPERATOR}${o(this,R)}`,id:o(this,R).toString(),hostName:e.workerThreadWorkerOptions.hostName?e.workerThreadWorkerOptions.hostName:"host",agentName:`${e.workerThreadWorkerOptions.agentId}-${e.workerThreadWorkerOptions.userAgent}`,threadId:`worker${e.id}`,asyncRunnerId:o(this,R)},n={id:o(this,R),publishInstrumentController:o(this,C).AddPublishInstrumentController(s),asyncRunnerContext:s,state:I.created,options:t,instrumentData:{count:0,velocity:0,message:[]},Stop:async()=>o(this,v).call(this,e,n)};return n});c(this,M,(e,t,s,n)=>{n?(console.log("#PostMessageToWorker with transfer object"),e.worker.postMessage({command:t,payload:s},[n]),console.log("#PostMessageToWorker with transfer object - done...")):(console.log("#PostMessageToWorker"),e.worker.postMessage({command:t,payload:s}))});c(this,X,e=>{if(e.worker){const t=B();e.worker.terminate(),console.log(`Terminated worker: [${e.id}]`),t.RemoveWorker(e),delete o(this,w)[e.id]}});c(this,v,async(e,t=null)=>{if(t===null){const s=Object.keys(e.runnersEx);if(s.length>0){const n=s[0];t=e.runnersEx[n]}}if(t!==null){o(this,M).call(this,e,m.PublishMessageCommands.Stop,{runner:ge(this,j,de).call(this,t)}),t.publishInstrumentController.LogEx(`Terminating runner: [${t.id}]`);const s=[];s.push((async()=>(await ke.Sleep(100),t.publishInstrumentController.InstrumentTerminate()))()),B().RemoveRunner(e,t),delete e.runnersEx[t.id];const a=await Promise.all(s);console.log(`Removed instrument workers: [${a}]`)}return!0});c(this,Z,async e=>{try{if(e.state!==q.stopped){o(this,M).call(this,e,m.PublishMessageCommands.Stop,null),console.log(`Terminating worker: [${e.id}]`);const t=[];Object.keys(e.runnersEx).forEach(n=>{const a=e.runnersEx[n];t.push(o(this,v).call(this,e,a))}),await Promise.all(t),o(this,X).call(this,e)}return!0}catch(t){return console.log(`Error in STSTestWorker:StopWorker: [${t}]`),!1}});d(this,"GetNextAvailableWorker",()=>{let e=null;for(const[,t]of Object.entries(this.WorkersEx))e?Object.keys(t.runnersEx).length<Object.keys(e.runnersEx).length&&(e=t):e=t;return e});d(this,"GetBusyWorker",()=>{let e=null;for(const[,t]of Object.entries(this.WorkersEx))e?Object.keys(t.runnersEx).length>Object.keys(e.runnersEx).length&&(e=t):e=t;return e});d(this,"StopAllWorkers",async()=>{const e=[];for(const[,t]of Object.entries(this.WorkersEx))e.push(t.Stop());await Promise.all(e)});p(this,N,e),t?p(this,W,t):p(this,W,{}),O(`CompareSTSInstrumentControllerPluginKeyWMEx(): [${Se()}]`),O(`Attempting to get STSInstrumentControllerPlugin using symbol: [${String(m.STSInstrumentControllerPluginKey)}]`),p(this,C,m.GetSTSInstrumentController(e)),O(o(this,C)),O("keys within app.config.globalProperties.$sts");for(const[s,n]of Object.entries(e.config.globalProperties.$sts))O(`${s}`);o(this,C)||O(`Failed to get STSInstrumentControllerPlugin using symbol: [${String(m.STSInstrumentControllerPluginKey)}]`)}get WorkersEx(){return o(this,w)}get Options(){return o(this,W)}set Options(e){p(this,W,e)}}w=new WeakMap,R=new WeakMap,z=new WeakMap,W=new WeakMap,C=new WeakMap,N=new WeakMap,j=new WeakSet,de=function(e){return{id:e.id,asyncRunnerContext:{...e.asyncRunnerContext},options:{...e.options},state:e.state,instrumentData:{...e.instrumentData}}},V=new WeakMap,Y=new WeakMap,Q=new WeakMap,M=new WeakMap,X=new WeakMap,v=new WeakMap,Z=new WeakMap;const be=()=>m.STSInstrumentControllerPluginKey,Ae=r=>r===m.STSInstrumentControllerPluginKey,Se=()=>m.STSInstrumentControllerPluginKey===m.GetSTSInstrumentControllerPluginKey(),De=()=>l.inject(H),qe={install:(r,e)=>{const t=new pe(r,e);r.config.globalProperties.$sts||(r.config.globalProperties.$sts={}),r.config.globalProperties.$sts[H]=t,r.provide(H,t)}},G=g(`proc:${process.pid}`);class fe{constructor(e){c(this,f,{});c(this,E,1e4);c(this,b,void 0);d(this,"PostMessage",e=>new Promise((t,s)=>{const{messageId:n}=e.payload;if(n)o(this,f)[n]?s(`RequestResponseHelper: Message with id: [${n}] already exists within the Request/Response record structure`):(o(this,f)[n]={publishMessagePayload:{...e},cb:()=>{const a=o(this,f)[n].publishMessagePayloadResponse;if(clearTimeout(o(this,f)[n].timeout),setTimeout(()=>{delete o(this,f)[n]},0),a)G(`RequestResponseHelper: Resolving response message with id: [${n}] from target worker port. Details: [${JSON.stringify(a)}]`),t(a);else{const u="Could not get detail from this.#requestResponseMessages[messageId].publishMessagePayloadResponse";G(u),s(u)}},timeout:setTimeout(()=>{setTimeout(()=>{delete o(this,f)[n]},0),G(`RequestResponseHelper: Timeout has occurred after: [${o(this,E)}]ms with message id: [${n}]. Details: [${JSON.stringify(o(this,f)[n].publishMessagePayload)}]`),s("RequestResponseHelper: Did not receive response form parent process.")},o(this,E))},G(`RequestResponseHelper: Sending message with id: [${n}] to target worker port. Details: [${JSON.stringify(o(this,f)[n].publishMessagePayload)}]`),o(this,b).postMessage(e));else{const a="RequestResponseHelper: Response did not include a message id";G(a),s(a)}}));c(this,x,()=>{o(this,b).onmessage=async e=>{const t=e.data;if(t.payload.messageId){const s=t.payload.messageId;if(s&&s!=="")if(o(this,f)[s]){const n=o(this,f)[s];n.publishMessagePayloadResponse={...t},n.cb()}else throw new Error(`RequestResponseHelper: Could not find Request/Response message with id: [${s}]`)}}});p(this,b,e),o(this,x).call(this)}}f=new WeakMap,E=new WeakMap,b=new WeakMap,x=new WeakMap;const k=g(`proc:${process.pid}:workerInstance`);class Ge{constructor(){c(this,T,null);c(this,K,null);c(this,A,{});c(this,D,null);d(this,"GetRandomInt",e=>(k("WorkerInstance::GetRandomInt"),Math.floor(Math.random()*Math.floor(e))));d(this,"StartWork",async e=>{k("WorkerInstance::StartWork")});d(this,"PostTelemetry",e=>{if(o(this,T)){const t={command:m.PublishMessageCommands.InstrumentTelemetry,payload:{runner:e}};o(this,T).postMessage(t)}});c(this,ee,e=>{k("WorkerInstance::SetMessagePort"),p(this,T,e.port),o(this,T).onmessage=function(s){console.log(`collectorCollectorPort onmessage: ${s.data}`)},p(this,K,new fe(o(this,T)));const t={command:m.PublishMessageCommands.MessagePortResponse,payload:{}};o(this,T).postMessage(t)});d(this,"StartRunner",async e=>{k("WorkerInstance::StartRunner"),console.log(`StartTests: [${JSON.stringify(e)}]`),e.state=I.running,this.StartWork(e)});c(this,te,e=>{k("WorkerInstance::AddAsyncRunner");const{runner:t}=e;o(this,A)[t.id]=t,this.StartRunner(t)});c(this,se,e=>{if(k("WorkerInstance::StopRunners"),e===null)for(const[,t]of Object.entries(o(this,A)))t.state=I.stopped;else{const t=o(this,A)[e.runner.id];t&&(t.state=I.stopped)}});d(this,"ProcessMessage",async e=>{k("WorkerInstance::ProcessMessage");try{const t=e.data;switch(t.command){case m.PublishMessageCommands.MessagePort:o(this,ee).call(this,t.payload),p(this,D,t.payload.options),k(`WorkerInstance::ProcessMessage::#options: [${JSON.stringify(o(this,D))}]`);break;case m.PublishMessageCommands.Add:o(this,te).call(this,t.payload);break;case m.PublishMessageCommands.Stop:o(this,se).call(this,t.payload);break;default:k(`Invalid payloadMessage.command: [${t.command}] - Ignoring`)}}catch(t){console.log(t)}});k("WorkerInstance::constructor")}get RequestResponseHelper(){return o(this,K)}get CollectorCollectorPort(){return o(this,T)}get Options(){return o(this,D)}}T=new WeakMap,K=new WeakMap,A=new WeakMap,D=new WeakMap,ee=new WeakMap,te=new WeakMap,se=new WeakMap,i.ClientStorageFactory=he,i.ClientStorageType=me,i.CompareSTSInstrumentControllerPluginKeyWM=Ae,i.CompareSTSInstrumentControllerPluginKeyWMEx=Se,i.GetSTSInstrumentControllerPluginKeyWM=be,i.IRunnerState=I,i.IWorkerState=q,i.RequestResponseHelper=fe,i.STSEmitterPlugin=We,i.STSEmitterPluginKey=J,i.STSStoragePlugin=ve,i.STSStoragePluginKey=_,i.STSWorkerManager=pe,i.STSWorkerManagerPlugin=qe,i.STSWorkerManagerPluginKey=H,i.TelemetryStore=B,i.WorkerInstance=Ge,i.useSTSEmitterPlugin=Re,i.useSTSStoragePlugin=we,i.useSTSWorkerManager=De,Object.defineProperty(i,Symbol.toStringTag,{value:"Module"})});
2
+ //# sourceMappingURL=stsvueutils.umd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stsvueutils.umd.js","sources":["../src/plugins/stsPluginKeys.ts","../node_modules/tiny-emitter/index.js","../src/plugins/emitter.ts","../node_modules/js-cookie/dist/js.cookie.mjs","../src/plugins/stsStorage.ts","../src/plugins/storage.ts","../src/stores/TelemetryStore.ts","../src/plugins/stsTestWorkerDefinitions.ts","../src/plugins/workerManager.ts","../src/plugins/requestResponseHelper.ts","../src/plugins/workerInstance.ts"],"sourcesContent":["// Individual STS plugin keys for provide/inject logic\nexport const STSStoragePluginKey = Symbol('storage')\nexport const STSEmitterPluginKey = Symbol('emitter')\nexport const STSWorkerManagerPluginKey = Symbol('workerManager')\n","function E () {\n // Keep this empty so it's easier to inherit from\n // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3)\n}\n\nE.prototype = {\n on: function (name, callback, ctx) {\n var e = this.e || (this.e = {});\n\n (e[name] || (e[name] = [])).push({\n fn: callback,\n ctx: ctx\n });\n\n return this;\n },\n\n once: function (name, callback, ctx) {\n var self = this;\n function listener () {\n self.off(name, listener);\n callback.apply(ctx, arguments);\n };\n\n listener._ = callback\n return this.on(name, listener, ctx);\n },\n\n emit: function (name) {\n var data = [].slice.call(arguments, 1);\n var evtArr = ((this.e || (this.e = {}))[name] || []).slice();\n var i = 0;\n var len = evtArr.length;\n\n for (i; i < len; i++) {\n evtArr[i].fn.apply(evtArr[i].ctx, data);\n }\n\n return this;\n },\n\n off: function (name, callback) {\n var e = this.e || (this.e = {});\n var evts = e[name];\n var liveEvents = [];\n\n if (evts && callback) {\n for (var i = 0, len = evts.length; i < len; i++) {\n if (evts[i].fn !== callback && evts[i].fn._ !== callback)\n liveEvents.push(evts[i]);\n }\n }\n\n // Remove event from queue to prevent memory leak\n // Suggested by https://github.com/lazd\n // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910\n\n (liveEvents.length)\n ? e[name] = liveEvents\n : delete e[name];\n\n return this;\n }\n};\n\nmodule.exports = E;\nmodule.exports.TinyEmitter = E;\n","import { inject } from 'vue'\n\nimport { STSEmitterPluginKey } from './stsPluginKeys';\n\nimport * as te from 'tiny-emitter';\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSEmitterPlugin = (): te.TinyEmitter => inject(STSEmitterPluginKey) as te.TinyEmitter\n\n// https://learnvue.co/2021/06/building-your-own-vue-3-plugin-a-full-guide/\nexport const STSEmitterPlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: (app: any) => {\n const tinyEmitter: te.TinyEmitter = new te.TinyEmitter();\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSEmitterPluginKey] = tinyEmitter;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSEmitterPluginKey, tinyEmitter);\n }\n}\n","/*! js-cookie v3.0.1 | MIT */\n/* eslint-disable no-var */\nfunction assign (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n target[key] = source[key];\n }\n }\n return target\n}\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\nvar defaultConverter = {\n read: function (value) {\n if (value[0] === '\"') {\n value = value.slice(1, -1);\n }\n return value.replace(/(%[\\dA-F]{2})+/gi, decodeURIComponent)\n },\n write: function (value) {\n return encodeURIComponent(value).replace(\n /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,\n decodeURIComponent\n )\n }\n};\n/* eslint-enable no-var */\n\n/* eslint-disable no-var */\n\nfunction init (converter, defaultAttributes) {\n function set (key, value, attributes) {\n if (typeof document === 'undefined') {\n return\n }\n\n attributes = assign({}, defaultAttributes, attributes);\n\n if (typeof attributes.expires === 'number') {\n attributes.expires = new Date(Date.now() + attributes.expires * 864e5);\n }\n if (attributes.expires) {\n attributes.expires = attributes.expires.toUTCString();\n }\n\n key = encodeURIComponent(key)\n .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)\n .replace(/[()]/g, escape);\n\n var stringifiedAttributes = '';\n for (var attributeName in attributes) {\n if (!attributes[attributeName]) {\n continue\n }\n\n stringifiedAttributes += '; ' + attributeName;\n\n if (attributes[attributeName] === true) {\n continue\n }\n\n // Considers RFC 6265 section 5.2:\n // ...\n // 3. If the remaining unparsed-attributes contains a %x3B (\";\")\n // character:\n // Consume the characters of the unparsed-attributes up to,\n // not including, the first %x3B (\";\") character.\n // ...\n stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];\n }\n\n return (document.cookie =\n key + '=' + converter.write(value, key) + stringifiedAttributes)\n }\n\n function get (key) {\n if (typeof document === 'undefined' || (arguments.length && !key)) {\n return\n }\n\n // To prevent the for loop in the first place assign an empty array\n // in case there are no cookies at all.\n var cookies = document.cookie ? document.cookie.split('; ') : [];\n var jar = {};\n for (var i = 0; i < cookies.length; i++) {\n var parts = cookies[i].split('=');\n var value = parts.slice(1).join('=');\n\n try {\n var foundKey = decodeURIComponent(parts[0]);\n jar[foundKey] = converter.read(value, foundKey);\n\n if (key === foundKey) {\n break\n }\n } catch (e) {}\n }\n\n return key ? jar[key] : jar\n }\n\n return Object.create(\n {\n set: set,\n get: get,\n remove: function (key, attributes) {\n set(\n key,\n '',\n assign({}, attributes, {\n expires: -1\n })\n );\n },\n withAttributes: function (attributes) {\n return init(this.converter, assign({}, this.attributes, attributes))\n },\n withConverter: function (converter) {\n return init(assign({}, this.converter, converter), this.attributes)\n }\n },\n {\n attributes: { value: Object.freeze(defaultAttributes) },\n converter: { value: Object.freeze(converter) }\n }\n )\n}\n\nvar api = init(defaultConverter, { path: '/' });\n/* eslint-enable no-var */\n\nexport default api;\n","import Debug from 'debug';\nconst debug = Debug(`proc:${process.pid}:storage.ts`);\n\nimport Cookies from 'js-cookie'\nimport type { JSONObject } from \"@nsshunt/stsutils\";\n\nlet PREFIX = '_ststra_';\n\nexport interface IStsStorage<T> {\n\tget(key: string): T | null\n\tset(key: string, value: T, options?: JSONObject): void\n\tremove(key: string): void\n}\n\nexport enum ClientStorageType {\n\tLOCAL_STORAGE = 'LocalStorage', //@@ todo\n\tSESSION_STORAGE = 'SessionStorage',\n\tCOOKIE_STORAGE = 'CookieStorage',\n\tMEMORY_STORAGE = 'MemoryStorage' //@@ todo\n}\n\nclass CookieStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const raw = Cookies.get(PREFIX + key);\n if (raw) {\n return JSON.parse(raw);\n } else {\n return null;\n }\n }\n\n set = (key: string, value: T, options: JSONObject = { }) => {\n let cookieAttributes: Cookies.CookieAttributes = { };\n if ('https:' === window.location.protocol) {\n cookieAttributes = {\n secure: true,\n sameSite: 'none'\n };\n }\n\t\n if (options && options.daysUntilExpire) {\n cookieAttributes.expires = options.daysUntilExpire;\n } else {\n cookieAttributes.expires = 1;\n }\n debug(`CookieStorage.set: key: ${key}, value: [${value}]`);\n Cookies.set(PREFIX + key, JSON.stringify(value), cookieAttributes);\n }\n\n remove = (key: string): void => {\n Cookies.remove(PREFIX + key);\n }\n}\n\nclass SessionStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const value: string | null = sessionStorage.getItem(PREFIX + key);\n if (value) {\n return JSON.parse(value);\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`SessionStorage.set: key: ${key}, value: [${value}]`);\n sessionStorage.setItem(PREFIX + key, JSON.stringify(value));\n }\n \n remove = (key: string): void => {\n sessionStorage.removeItem(PREFIX + key);\n }\n}\n\nclass LocalStorage<T> implements IStsStorage<T>\n{\n get = (key: string): T | null => {\n const value: string | null = localStorage.getItem(PREFIX + key);\n if (value) {\n return JSON.parse(value);\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`LocalStorage.set: key: ${key}, value: [${value}]`);\n localStorage.setItem(PREFIX + key, JSON.stringify(value));\n }\n \n remove = (key: string): void => {\n localStorage.removeItem(PREFIX + key);\n }\n}\n\nclass MemoryStorage<T> implements IStsStorage<T>\n{\n #store: Record<string, T> = { };\n\n get = (key: string): T | null => {\n const value: T = this.#store[PREFIX + key];\n if (value) {\n return value;\n } else {\n return null;\n }\n }\n \n set = (key: string, value: T): void => {\n debug(`MemoryStorage.set: key: ${key}, value: [${value}]`);\n this.#store[PREFIX + key] = value;\n }\n \n remove = (key: string): void => {\n delete this.#store[PREFIX + key];\n }\n}\n\nexport interface IClientStorageOptions {\n\tclientStorageType: ClientStorageType\n\tusePrefix: boolean\n\tstorageOptions?: JSONObject\n}\n\nexport class ClientStorageFactory<T>\n{\n #storage: IStsStorage<T>;\n\n constructor(options: IClientStorageOptions) {\n if (options.usePrefix === false) {\n PREFIX = '';\n }\n switch (options.clientStorageType) {\n case ClientStorageType.SESSION_STORAGE :\n this.#storage = new SessionStorage<T>();\n break;\n case ClientStorageType.LOCAL_STORAGE :\n this.#storage = new LocalStorage<T>();\n break;\n case ClientStorageType.COOKIE_STORAGE :\n this.#storage = new CookieStorage<T>();\n break;\n case ClientStorageType.MEMORY_STORAGE :\n this.#storage = new MemoryStorage<T>();\n break;\n default:\n throw new Error(`Unknown [${options.clientStorageType}] storage type.`);\n }\n return;\n }\n\n GetStorage(): IStsStorage<T>\n {\n return this.#storage;\n }\n}\n","import { inject } from \"vue\";\n\n// Declare STS plugin keys (for provide)\n// https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\nimport { STSStoragePluginKey } from './stsPluginKeys';\n\nimport { ClientStorageType, ClientStorageFactory, type IStsStorage } from './stsStorage'\n\nexport interface ISTSStoragePluginOptions {\n\tclientStorageType: ClientStorageType\n}\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSStoragePlugin = <T>(): IStsStorage<T> => inject(STSStoragePluginKey) as IStsStorage<T>\n\n// https://learnvue.co/2021/06/building-your-own-vue-3-plugin-a-full-guide/\nexport const STSStoragePlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: <T>(app: any, options: ISTSStoragePluginOptions) => {\n const cs = new ClientStorageFactory<T>({clientStorageType: options.clientStorageType, usePrefix: true});\n\n const pluginInstance = cs.GetStorage();\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n // This allows access to the $sts property within templates.\n // Also, outside of script setup or setup(), this.$sts can be used.\n // If access is required within script setup, use the useSTSStoragePlugin composable function. Example;\n // import { useSTSStoragePlugin } from './storage';\n // const STSStorageString = useSTSStoragePlugin<string>();\n //\n // Note: An alternate to get access to this global is to use the hidden API call such as;\n // const app: ComponentInternalInstance | null = getCurrentInstance();\n // Assign the $sts plugin helper (legacy method - see below (injects) for updated usage)\n // let $sts: any\n // if (app) $sts = app.appContext.config.globalProperties.$sts;\n\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSStoragePluginKey] = pluginInstance;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSStoragePluginKey, pluginInstance);\n }\n}\n","import { defineStore } from 'pinia'\n\nimport type { IWorker, IWorkerEx, IRunnerEx, IRunner, ITelemetryStore } from './../plugins/stsTestWorkerDefinitions'\n\n// https://pinia.vuejs.org/\n// https://seb-l.github.io/pinia-plugin-persist/\nexport const TelemetryStore = defineStore('__sts__TelemetryStore', {\n // State\n // https://pinia.vuejs.org/core-concepts/state.html\n state: (): ITelemetryStore => {\n return {\n workers: { }\n }\n },\n\n // Getters\n // https://pinia.vuejs.org/core-concepts/getters.html\n\n // Actions\n // https://pinia.vuejs.org/core-concepts/actions.html\n actions: {\n RemoveWorker(workerEx: IWorkerEx) {\n delete this.workers[workerEx.id];\n },\n\n RemoveRunner(workerEx: IWorkerEx, runnerEx: IRunnerEx) {\n const worker: IWorker = this.workers[workerEx.id];\n if (worker && worker.runners) {\n delete worker.runners[runnerEx.id];\n }\n },\n\n Update(workerEx: IWorkerEx, runnerEx: IRunnerEx) {\n if (!this.workers[workerEx.id]) {\n // Create a new telemetry record\n this.workers[workerEx.id] = {\n id: workerEx.id,\n state: workerEx.state,\n primaryThreadWorkerOptions: { ...workerEx.primaryThreadWorkerOptions },\n workerThreadWorkerOptions: { ...workerEx.workerThreadWorkerOptions },\n runners: { }\n } as IWorker\n }\n const worker: IWorker = this.workers[workerEx.id];\n // Now check for the async runner\n if (worker.runners) {\n if (!worker.runners[runnerEx.id]) {\n // Create a new asyncRunnerInstance telemetry record\n const runner: IRunner = {\n id: runnerEx.id,\n asyncRunnerContext: { ...runnerEx.asyncRunnerContext },\n options: { ...runnerEx.options },\n state: runnerEx.state,\n instrumentData: { ...runnerEx.instrumentData },\n }\n worker.runners[runner.id] = runner;\n } else {\n const runner: IRunner = worker.runners[runnerEx.id];\n runner.instrumentData = { ...runnerEx.instrumentData }\n }\n }\n }\n }\n});\n","import type { IPublishMessagePayloadContentBase, IAsyncRunnerContext, PublishInstrumentController, IPublishMessagePayload } from '@nsshunt/stspublisherserver'\n\nexport interface ISTSAgentWorkerMessagePort extends IPublishMessagePayloadContentBase {\n port: MessagePort\n options: IWorkerOptions\n}\n\nexport enum IRunnerState {\n\tcreated = 'created',\n\trunning = 'running',\n\tstopped = 'stopped',\n\tpaused = 'paused',\n\terror = 'error',\n}\n\nexport interface IRunnerTelemetry {\n\tcount: number\n\tvelocity: number\n\tmessage: string[]\n}\n\nexport interface IRunner {\n\tid: number\n\tasyncRunnerContext: IAsyncRunnerContext\n\toptions: IRunnerOptions\n\tstate: IRunnerState\n\tinstrumentData: IRunnerTelemetry\n}\n\nexport interface IRunnerEx extends IRunner {\n publishInstrumentController: PublishInstrumentController\n Stop: () => Promise<boolean>\n}\n\nexport enum IWorkerState {\n\tstarting = 'starting',\n\tstarted = 'started',\n\tstopped = 'stopped'\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IWorkerOptions {\n hostName: string\n agentId: string\n userAgent: string\n}\n\nexport type Runners = Record<string, IRunner>\n\nexport interface IWorker {\n\tid: number\n\tstate: IWorkerState\n primaryThreadWorkerOptions: IWorkerOptions\n\tworkerThreadWorkerOptions: IWorkerOptions\n\trunners?: Runners // Will be created by utility helper\n}\n\nexport type Workers = Record<string, IWorker>\n\nexport interface IPrimaryWorker {\n ProcessMessageFromWorker(workerPort: MessagePort, publishMessagePayload: IPublishMessagePayload): Promise<void>\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IRunnerOptions {\n\n}\n\nexport interface IWorkerEx extends IWorker {\n\tworker: Worker\n primaryWorker: IPrimaryWorker\n\trunnersEx: Record<string, IRunnerEx>\n\tAddRunner: (runnerOptions: IRunnerOptions) => IRunnerEx\n\tStopRunner: (runner: IRunnerEx) => Promise<boolean>\n\tStop: () => Promise<boolean>\n}\n\nexport interface ISTSTestWorkerOptions {\n messageMod: number\n iterations: number\n}\n\nexport interface ITelemetryStore {\n\tworkers: Workers\n}\n\nexport interface ITestRunnerTelemetryPayload extends IPublishMessagePayloadContentBase {\n\trunner: IRunner\n}\n\nexport interface IWorkerFactory {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n createPrimaryThreadWorker: (app: any, options: IWorkerOptions) => IPrimaryWorker\n\tcreateWorkerThreadWorker: () => Worker // | wt.Worker\n get workerThreadWorkerOptions(): IWorkerOptions // These options will be passed as a message to the thread worker once setup\n get primaryThreadWorkerOptions(): IWorkerOptions // These options will be passed as a message to the thread worker once setup\n}\n\nexport interface IWorkerManagerOptions {\n workerFactory: IWorkerFactory\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}:workerManager`);\n\n//import MyWorker from './sts-worker?worker' // https://vitejs.dev/guide/features.html#web-workers\nimport { type IAsyncRunnerContext, IPublishMessagePayload, IPublishMessagePayloadContentBase, \n type PublishMessageCommand, PublishMessageCommands, type AgentPublishInstrumentController } from '@nsshunt/stspublisherserver' \n \nimport { Gauge, InstrumentGaugeTelemetry } from '@nsshunt/stsinstrumentation'\n\nimport { ModelDelimeter } from '@nsshunt/stsmodels'\n\nimport { TelemetryStore } from './../stores/TelemetryStore'\n//import { ApplicationStore } from './../stores/applicationStore'\n\nimport type { ISTSAgentWorkerMessagePort, IWorkerEx, IRunner, IRunnerEx,\n ITestRunnerTelemetryPayload, IRunnerOptions, IRunnerTelemetry,\n IWorkerManagerOptions, IWorkerFactory } from './stsTestWorkerDefinitions'\n\nimport { IWorkerState, IRunnerState } from './stsTestWorkerDefinitions'\nimport { Sleep } from '@nsshunt/stsutils';\nimport { inject } from 'vue';\n\nimport { STSInstrumentControllerPluginKey, GetSTSInstrumentControllerPluginKey, GetSTSInstrumentController } from '@nsshunt/stspublisherserver'\nimport { STSWorkerManagerPluginKey } from './stsPluginKeys';\n\nexport class STSWorkerManager {\n //#agentSession: string = null;\n #workersEx: Record<string, IWorkerEx> = { };\n #runner = 0;\n #workerId = 0;\n #options: IWorkerManagerOptions;\n #STSInstrumentController: AgentPublishInstrumentController\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n #app: any\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n constructor(app: any, options?: IWorkerManagerOptions) {\n this.#app = app;\n if (options) {\n this.#options = options;\n } else {\n this.#options = { } as IWorkerManagerOptions;\n }\n\n debug(`CompareSTSInstrumentControllerPluginKeyWMEx(): [${CompareSTSInstrumentControllerPluginKeyWMEx()}]`);\n\n debug(`Attempting to get STSInstrumentControllerPlugin using symbol: [${String(STSInstrumentControllerPluginKey)}]`);\n //this.#STSInstrumentController = app.config.globalProperties.$sts[STSInstrumentControllerPluginKey]\n //this.#STSInstrumentController = app.config.globalProperties.$sts[GetSTSInstrumentControllerPluginKey()]\n this.#STSInstrumentController = GetSTSInstrumentController(app);\n //this.#STSInstrumentController = app.config.globalProperties.$sts.aic;\n\n debug(this.#STSInstrumentController);\n debug('keys within app.config.globalProperties.$sts');\n for (const [key, value] of Object.entries(app.config.globalProperties.$sts)) {\n debug(`${key}`);\n }\n\n if (!this.#STSInstrumentController) {\n debug(`Failed to get STSInstrumentControllerPlugin using symbol: [${String(STSInstrumentControllerPluginKey)}]`);\n }\n }\n \n get WorkersEx(): Record<string, IWorkerEx>\n {\n return this.#workersEx;\n }\n\n AddWorker = async (useWorkerFactory?: IWorkerFactory): Promise<IWorkerEx> => {\n let workerFactory: IWorkerFactory;\n if (useWorkerFactory) {\n // Use the supplied workFactory\n workerFactory = useWorkerFactory;\n } else {\n // Use the default workFactory\n workerFactory = this.#options.workerFactory\n }\n const stsWorkerEx: IWorkerEx = {\n id: this.#workerId++, // uuidv4()\n worker: workerFactory.createWorkerThreadWorker(),\n primaryWorker: workerFactory.createPrimaryThreadWorker(this.#app, workerFactory.primaryThreadWorkerOptions),\n state: IWorkerState.starting,\n workerThreadWorkerOptions: workerFactory.workerThreadWorkerOptions,\n primaryThreadWorkerOptions: workerFactory.primaryThreadWorkerOptions,\n runnersEx: { } as Record<string, IRunnerEx>,\n AddRunner: (runnerOptions: IRunnerOptions): IRunnerEx => this.AddRunnerToWorker(stsWorkerEx, runnerOptions),\n StopRunner: (runner: IRunnerEx): Promise<boolean> => this.#StopRunner(stsWorkerEx, runner),\n Stop: async (): Promise<boolean> => this.#StopWorker(stsWorkerEx)\n }\n console.log(`Adding worker: [${stsWorkerEx.id}]`);\n\n stsWorkerEx.worker.onmessage = function(data: MessageEvent) {\n console.log(data.data);\n }\n\n stsWorkerEx.worker.onerror = function(error) {\n console.log(error);\n };\n\n const { \n port1, // process message port\n port2 // collector message port\n } = new MessageChannel();\n\n const workerPort = port1;\n \n console.log(`STSWorkerManager::AddWorker::workerThreadWorkerOptions: [${JSON.stringify(stsWorkerEx.workerThreadWorkerOptions)}]`);\n\n this.#PostMessageToWorker(stsWorkerEx, PublishMessageCommands.MessagePort, {\n port: port2,\n //applicationStoreState: stateCopy,\n options: { ...stsWorkerEx.workerThreadWorkerOptions }\n } as ISTSAgentWorkerMessagePort, port2);\n \n // Process messages received back from the worker\n workerPort.onmessage = async (data: MessageEvent) => {\n const publishMessagePayload: IPublishMessagePayload = data.data as IPublishMessagePayload;\n switch (publishMessagePayload.command) {\n case PublishMessageCommands.MessagePortResponse : \n stsWorkerEx.state = IWorkerState.started;\n break;\n case PublishMessageCommands.InstrumentTelemetry :\n this.#ProcessTelemetry(stsWorkerEx, publishMessagePayload.payload as ITestRunnerTelemetryPayload);\n break;\n default :\n stsWorkerEx.primaryWorker.ProcessMessageFromWorker(workerPort, publishMessagePayload);\n }\n }\n\n this.#workersEx[stsWorkerEx.id] = stsWorkerEx;\n\n console.log(`Added worker: [${stsWorkerEx.id}]`);\n\n return stsWorkerEx;\n }\n\n AddRunnerToWorker = (stsWorkerEx: IWorkerEx, runnerOptions: IRunnerOptions): IRunnerEx => {\n const runnerEx: IRunnerEx = this.#CreateAsyncRunner(stsWorkerEx, runnerOptions);\n stsWorkerEx.runnersEx[runnerEx.id] = runnerEx;\n this.#SetRunnerIntoWorker(stsWorkerEx, runnerEx);\n return runnerEx;\n }\n\n #CreateRunnerCopy(runnerEx: IRunnerEx): IRunner {\n return {\n id: runnerEx.id,\n asyncRunnerContext: { ...runnerEx.asyncRunnerContext },\n options: { ...runnerEx.options },\n state: runnerEx.state,\n instrumentData: { ...runnerEx.instrumentData }\n } as IRunner\n }\n\n #SetRunnerIntoWorker = (workerEx: IWorkerEx, runnerEx: IRunnerEx): void => {\n // Now that the worker is setup, send the options\n //@@ wait until worker in running state\n const payload: ITestRunnerTelemetryPayload = {\n runner: this.#CreateRunnerCopy(runnerEx)\n }\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Add, payload);\n }\n\n #ProcessTelemetry = (workerEx: IWorkerEx, payloadContents: ITestRunnerTelemetryPayload): void => {\n const store = TelemetryStore();\n\n const { runner } = payloadContents;\n\n if (workerEx.runnersEx[runner.id]) {\n const runnerEx: IRunnerEx = workerEx.runnersEx[runner.id];\n let update = false;\n\n // Copy telemetry\n runnerEx.instrumentData.count = runner.instrumentData.count;\n runnerEx.instrumentData.velocity = runner.instrumentData.velocity;\n if (runner.instrumentData.message) {\n runnerEx.instrumentData.message = [...runner.instrumentData.message];\n } else {\n runnerEx.instrumentData.message = [ ];\n }\n\n if (runner.instrumentData.message) {\n runner.instrumentData.message.forEach((message) => {\n runnerEx.publishInstrumentController.LogEx(message);\n });\n update = true;\n }\n\n if (runner.instrumentData.count) {\n runnerEx.publishInstrumentController.UpdateInstrument(Gauge.REQUEST_COUNT_GAUGE, {\n val: runnerEx.instrumentData.count\n } as InstrumentGaugeTelemetry);\n runnerEx.publishInstrumentController.UpdateInstrument(Gauge.VELOCITY_GAUGE, {\n Inc: runnerEx.instrumentData.velocity\n } as InstrumentGaugeTelemetry);\n update = true;\n }\n\n if (update) {\n store.Update(workerEx, runnerEx);\n }\n }\n }\n\n #CreateAsyncRunner = (workerEx: IWorkerEx, runnerOptions: IRunnerOptions): IRunnerEx => {\n //const applicationStore = ApplicationStore();\n\n \n\n this.#runner++; // The runner number always increases\n const asyncRunnerContext: IAsyncRunnerContext = {\n nid: `\\\n${workerEx.workerThreadWorkerOptions.hostName}${ModelDelimeter.COMPONENT_SEPERATOR}${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}\\\n${ModelDelimeter.NID_SEPERATOR}\\\nworker${workerEx.id}\\\n${ModelDelimeter.SEPERATOR}\\\n${this.#runner}`,\n id: this.#runner.toString(),\n hostName: (workerEx.workerThreadWorkerOptions.hostName ? workerEx.workerThreadWorkerOptions.hostName : 'host'),\n agentName: `${workerEx.workerThreadWorkerOptions.agentId}-${workerEx.workerThreadWorkerOptions.userAgent}`,\n threadId: `worker${workerEx.id}`,\n asyncRunnerId: this.#runner\n }\n const runnerEx: IRunnerEx = {\n id: this.#runner,\n publishInstrumentController: this.#STSInstrumentController.AddPublishInstrumentController(asyncRunnerContext),\n asyncRunnerContext: asyncRunnerContext,\n state: IRunnerState.created,\n options: runnerOptions,\n instrumentData: {\n count: 0,\n velocity: 0,\n message: [ ]\n } as IRunnerTelemetry,\n Stop: async (): Promise<boolean> => this.#StopRunner(workerEx, runnerEx)\n }\n return runnerEx;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n #PostMessageToWorker = (workerEx: IWorkerEx, command: PublishMessageCommand, payload: IPublishMessagePayloadContentBase | null, transferObject?: any) => {\n if (transferObject) {\n console.log(`#PostMessageToWorker with transfer object`);\n workerEx.worker.postMessage({ command, payload }, [transferObject]);\n console.log(`#PostMessageToWorker with transfer object - done...`);\n } else {\n console.log(`#PostMessageToWorker`);\n workerEx.worker.postMessage({ command, payload });\n }\n }\n\n #TerminateWorker = (workerEx: IWorkerEx) => {\n if (workerEx.worker) {\n const store = TelemetryStore();\n\n workerEx.worker.terminate();\n //@@workerEx.worker = null;\n console.log(`Terminated worker: [${workerEx.id}]`);\n store.RemoveWorker(workerEx);\n delete this.#workersEx[workerEx.id];\n } else {\n // Some other runner has already removed the parent worker, do nothing\n // console.log(`WORKER ALREADY NULL`);\n }\n }\n\n #StopRunner = async (workerEx: IWorkerEx, runnerEx: IRunnerEx | null = null): Promise<boolean> => {\n // If runnerEx not provided, Remove the first runner in the collection\n if (runnerEx === null) {\n const ids: string[] = Object.keys(workerEx.runnersEx);\n if (ids.length > 0) {\n const id = ids[0];\n runnerEx = workerEx.runnersEx[id];\n }\n }\n if (runnerEx !== null) {\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Stop, {\n runner: this.#CreateRunnerCopy(runnerEx)\n } as ITestRunnerTelemetryPayload);\n\n runnerEx.publishInstrumentController.LogEx(`Terminating runner: [${runnerEx.id}]`);\n \n const promArray: Promise<boolean[]>[] = [ ];\n\n promArray.push((async (): Promise<boolean[]> => {\n await Sleep(100);\n return runnerEx.publishInstrumentController.InstrumentTerminate();\n })());\n\n const store = TelemetryStore();\n store.RemoveRunner(workerEx, runnerEx);\n\n delete workerEx.runnersEx[runnerEx.id];\n\n const retVal = await Promise.all(promArray);\n console.log(`Removed instrument workers: [${retVal}]`);\n\n /*\n // If the removed runner was the last runner, remove the worker\n if (Object.keys(workerEx.runnersEx).length === 0) {\n this.#TerminateWorker(workerEx);\n }\n */\n }\n return true;\n }\n\n #StopWorker = async (workerEx: IWorkerEx): Promise<boolean> => {\n try {\n if (workerEx.state !== IWorkerState.stopped) {\n this.#PostMessageToWorker(workerEx, PublishMessageCommands.Stop, null);\n \n //@@ Now wait until we get an ack back from the worker\n // This is because we may be trying to stop BEFORE the worker has had a chance to startup ...\n \n console.log(`Terminating worker: [${workerEx.id}]`);\n const promArray: Promise<boolean>[] = [ ];\n \n // Terminate only those that are currently running...\n const ids: string[] = Object.keys(workerEx.runnersEx);\n\n ids.forEach((id) => {\n const runnerEx: IRunnerEx = workerEx.runnersEx[id];\n promArray.push(this.#StopRunner(workerEx, runnerEx));\n });\n await Promise.all(promArray);\n\n this.#TerminateWorker(workerEx);\n }\n return true;\n } catch (error) {\n console.log(`Error in STSTestWorker:StopWorker: [${error}]`);\n return false;\n }\n }\n\n GetNextAvailableWorker = (): IWorkerEx | null => {\n // Calculate the worker with the least runners\n let leastRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (leastRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length < Object.keys(leastRunnerWorker.runnersEx).length) {\n leastRunnerWorker = stsWorker;\n }\n } else {\n leastRunnerWorker = stsWorker;\n }\n }\n return leastRunnerWorker;\n }\n\n GetBusyWorker = (): IWorkerEx | null => {\n // Calculate the worker with the least runners\n let busyWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (busyWorker) {\n if (Object.keys(stsWorker.runnersEx).length > Object.keys(busyWorker.runnersEx).length) {\n busyWorker = stsWorker;\n }\n } else {\n busyWorker = stsWorker;\n }\n }\n return busyWorker;\n }\n\n get Options(): IWorkerManagerOptions {\n return this.#options;\n }\n\n set Options(options: IWorkerManagerOptions) {\n this.#options = options;\n }\n\n /*\n StopRunner = async () => {\n // Calculate the worker with the most runners\n let largestRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (largestRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length > Object.keys(largestRunnerWorker.runnersEx).length) {\n largestRunnerWorker = stsWorker;\n }\n } else {\n largestRunnerWorker = stsWorker;\n }\n }\n if (largestRunnerWorker) largestRunnerWorker.StopRunner();\n }\n */\n\n /*\n StopWorker = async () => {\n // Calculate the worker with the least runners\n let largestRunnerWorker: IWorkerEx | null = null;\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n if (largestRunnerWorker) {\n if (Object.keys(stsWorker.runnersEx).length < Object.keys(largestRunnerWorker.runnersEx).length) {\n largestRunnerWorker = stsWorker;\n }\n } else {\n largestRunnerWorker = stsWorker;\n }\n }\n if (largestRunnerWorker) largestRunnerWorker.Stop();\n }\n */\n\n StopAllWorkers = async () => {\n const promArray = [ ];\n for (const [, stsWorker] of Object.entries(this.WorkersEx)) {\n promArray.push(stsWorker.Stop());\n }\n\n await Promise.all(promArray);\n }\n}\n\nexport const GetSTSInstrumentControllerPluginKeyWM = (): symbol => STSInstrumentControllerPluginKey\n\nexport const CompareSTSInstrumentControllerPluginKeyWM = (val: symbol): boolean => val === STSInstrumentControllerPluginKey\n\nexport const CompareSTSInstrumentControllerPluginKeyWMEx = (): boolean => STSInstrumentControllerPluginKey === GetSTSInstrumentControllerPluginKey()\n\n// Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.\n// https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject\nexport const useSTSWorkerManager = (): STSWorkerManager => inject(STSWorkerManagerPluginKey) as STSWorkerManager\n\nexport const STSWorkerManagerPlugin = {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n install: (app: any, options?: IWorkerManagerOptions) => {\n const wm = new STSWorkerManager(app, options);\n\n // Assign plugin instance to global $sts object (legacy method - see below)\n if (!app.config.globalProperties.$sts) {\n app.config.globalProperties.$sts = { };\n }\n app.config.globalProperties.$sts[STSWorkerManagerPluginKey] = wm;\n\n // Assign App level provide for this STS plugin using symbol keys\n // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys\n app.provide(STSWorkerManagerPluginKey, wm);\n }\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}`);\n\nimport type { IPublishMessagePayload } from '@nsshunt/stspublisherserver';\n\ndeclare interface RequestResponseMessage {\n\tpublishMessagePayload: IPublishMessagePayload\n\tpublishMessagePayloadResponse?: IPublishMessagePayload\n\tcb: () => void,\n\ttimeout: NodeJS.Timeout\n}\n\ndeclare type RequestResponseMessages = Record<string, RequestResponseMessage>;\n\nexport class RequestResponseHelper\n{\n #requestResponseMessages: RequestResponseMessages = { }\n #requestResponseMessageTimeout = 10000; //@@ config\n #port: MessagePort\n\n constructor(port: MessagePort) {\n this.#port = port\n this.#SetupListener();\n }\n\n PostMessage = (message: IPublishMessagePayload): Promise<IPublishMessagePayload> => {\n return new Promise((resolve, reject) => {\n const { messageId } = message.payload;\n if (messageId) {\n if (this.#requestResponseMessages[messageId]) {\n reject(`RequestResponseHelper: Message with id: [${messageId}] already exists within the Request/Response record structure`);\n } else {\n this.#requestResponseMessages[messageId] = {\n publishMessagePayload: { ...message },\n cb: () => {\n const detail = this.#requestResponseMessages[messageId].publishMessagePayloadResponse;\n clearTimeout(this.#requestResponseMessages[messageId].timeout);\n setTimeout(() => {\n delete this.#requestResponseMessages[messageId];\n }, 0);\n if (detail) {\n debug(`RequestResponseHelper: Resolving response message with id: [${messageId}] from target worker port. Details: [${JSON.stringify(detail)}]`);\n resolve(detail);\n } else {\n const msg = `Could not get detail from this.#requestResponseMessages[messageId].publishMessagePayloadResponse`;\n debug(msg);\n reject(msg);\n }\n },\n timeout: setTimeout(() => {\n setTimeout(() => {\n delete this.#requestResponseMessages[messageId];\n }, 0);\n debug(`RequestResponseHelper: Timeout has occurred after: [${this.#requestResponseMessageTimeout}]ms with message id: [${messageId}]. Details: [${JSON.stringify(this.#requestResponseMessages[messageId].publishMessagePayload)}]`);\n reject('RequestResponseHelper: Did not receive response form parent process.');\n }, this.#requestResponseMessageTimeout) // max message timeout allowed\n }\n debug(`RequestResponseHelper: Sending message with id: [${messageId}] to target worker port. Details: [${JSON.stringify(this.#requestResponseMessages[messageId].publishMessagePayload)}]`);\n this.#port.postMessage(message);\n }\n } else {\n const msg = `RequestResponseHelper: Response did not include a message id`;\n debug(msg);\n reject(msg);\n }\n });\n }\n\n #SetupListener = () => {\n this.#port.onmessage = async (msg: MessageEvent) => {\n const publishMessagePayload: IPublishMessagePayload = msg.data as IPublishMessagePayload;\n if (publishMessagePayload.payload.messageId) {\n const messageId = publishMessagePayload.payload.messageId;\n if (messageId && messageId !== '') {\n if (this.#requestResponseMessages[messageId]) {\n const requestResponseMessage: RequestResponseMessage = this.#requestResponseMessages[messageId];\n requestResponseMessage.publishMessagePayloadResponse = { ...publishMessagePayload };\n requestResponseMessage.cb();\n } else {\n throw new Error(`RequestResponseHelper: Could not find Request/Response message with id: [${messageId}]`);\n }\n }\n }\n }\n }\n}\n","import debugModule from 'debug'\nconst debug = debugModule(`proc:${process.pid}:workerInstance`);\n\nimport { IPublishMessagePayload, PublishMessageCommands, IPublishMessagePayloadContentBase } from '@nsshunt/stspublisherserver' // '@nsshunt/stspublisherserver' //'./plugins/publishers/publisherAgent'\n\nimport type { ISTSAgentWorkerMessagePort, IRunner, ITestRunnerTelemetryPayload } from './stsTestWorkerDefinitions'\nimport { IRunnerState } from './stsTestWorkerDefinitions'\n\nimport { RequestResponseHelper } from './requestResponseHelper'\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface IWorkerInstanceOptions {\n\n}\n\nexport abstract class WorkerInstance {\n #collectorCollectorPort: MessagePort | null = null;\n #requestResponseHelper: RequestResponseHelper | null = null;\n #runners: Record<string, IRunner> = { };\n #options: IWorkerInstanceOptions | null = null;\n\n constructor() {\n debug(`WorkerInstance::constructor`)\n }\n\n GetRandomInt = (max: number) => {\n debug(`WorkerInstance::GetRandomInt`)\n return Math.floor(Math.random() * Math.floor(max));\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n StartWork = async (runner: IRunner): Promise<void> => {\n debug(`WorkerInstance::StartWork`)\n return;\n }\n\n PostTelemetry = (runner: IRunner) => {\n //debug(`WorkerInstance::PostTelemetry`)\n if (this.#collectorCollectorPort) {\n const message: IPublishMessagePayload = {\n command: PublishMessageCommands.InstrumentTelemetry,\n payload: {\n runner\n } as ITestRunnerTelemetryPayload\n }\n this.#collectorCollectorPort.postMessage(message);\n }\n }\n\n get RequestResponseHelper(): RequestResponseHelper | null {\n return this.#requestResponseHelper;\n }\n\n get CollectorCollectorPort(): MessagePort | null {\n return this.#collectorCollectorPort;\n }\n\n get Options(): IWorkerInstanceOptions | null {\n return this.#options;\n }\n\n #SetMessagePort = (workerMessagePort: ISTSAgentWorkerMessagePort) => {\n debug(`WorkerInstance::SetMessagePort`)\n this.#collectorCollectorPort = workerMessagePort.port as MessagePort;\n this.#collectorCollectorPort.onmessage = function(data: MessageEvent) {\n console.log(`collectorCollectorPort onmessage: ${data.data}`);\n }\n\n this.#requestResponseHelper = new RequestResponseHelper(this.#collectorCollectorPort);\n\n const response: IPublishMessagePayload = {\n command: PublishMessageCommands.MessagePortResponse,\n payload: { } as IPublishMessagePayloadContentBase\n }\n\n this.#collectorCollectorPort.postMessage(response);\n }\n\n StartRunner = async (runner: IRunner) => {\n debug(`WorkerInstance::StartRunner`)\n console.log(`StartTests: [${JSON.stringify(runner)}]`);\n runner.state = IRunnerState.running;\n this.StartWork(runner);\n }\n\n #AddAsyncRunner = (testRunnerTelemetryPayload: ITestRunnerTelemetryPayload) => {\n debug(`WorkerInstance::AddAsyncRunner`)\n const { runner } = testRunnerTelemetryPayload;\n this.#runners[runner.id] = runner;\n this.StartRunner(runner);\n }\n\n #StopRunners = (testRunnerTelemetryPayload: ITestRunnerTelemetryPayload) => {\n debug(`WorkerInstance::StopRunners`)\n if (testRunnerTelemetryPayload === null) {\n for (const [, testRunner] of Object.entries(this.#runners)) {\n testRunner.state = IRunnerState.stopped;\n }\n } else {\n const runner: IRunner = this.#runners[testRunnerTelemetryPayload.runner.id];\n if (runner) {\n runner.state = IRunnerState.stopped;\n }\n }\n }\n\n ProcessMessage = async(data: MessageEvent) => {\n debug(`WorkerInstance::ProcessMessage`)\n try {\n const payloadMessage: IPublishMessagePayload = data.data as IPublishMessagePayload;\n switch (payloadMessage.command) {\n case PublishMessageCommands.MessagePort :\n this.#SetMessagePort(payloadMessage.payload as ISTSAgentWorkerMessagePort);\n this.#options = (payloadMessage.payload as ISTSAgentWorkerMessagePort).options;\n debug(`WorkerInstance::ProcessMessage::#options: [${JSON.stringify(this.#options)}]`)\n break;\n case PublishMessageCommands.Add :\n this.#AddAsyncRunner(payloadMessage.payload as ITestRunnerTelemetryPayload);\n break;\n case PublishMessageCommands.Stop :\n this.#StopRunners(payloadMessage.payload as ITestRunnerTelemetryPayload);\n break;\n default :\n debug(`Invalid payloadMessage.command: [${payloadMessage.command}] - Ignoring`);\n }\n } catch (error) {\n console.log(error);\n }\n }\n}"],"names":["STSStoragePluginKey","STSEmitterPluginKey","STSWorkerManagerPluginKey","E","name","callback","ctx","e","self","listener","data","evtArr","i","len","evts","liveEvents","tinyEmitterModule","TinyEmitter","tinyEmitter","useSTSEmitterPlugin","inject","STSEmitterPlugin","app","te.TinyEmitter","assign","target","source","key","defaultConverter","value","init","converter","defaultAttributes","set","attributes","stringifiedAttributes","attributeName","get","cookies","jar","parts","foundKey","api","debug","Debug","PREFIX","ClientStorageType","CookieStorage","__publicField","raw","Cookies","options","cookieAttributes","SessionStorage","LocalStorage","MemoryStorage","__privateAdd","_store","__privateGet","ClientStorageFactory","_storage","__privateSet","useSTSStoragePlugin","STSStoragePlugin","pluginInstance","TelemetryStore","defineStore","workerEx","runnerEx","worker","runner","IRunnerState","IWorkerState","debugModule","STSWorkerManager","_CreateRunnerCopy","_workersEx","_runner","_workerId","_options","_STSInstrumentController","_app","useWorkerFactory","workerFactory","stsWorkerEx","__privateWrapper","runnerOptions","_StopRunner","_StopWorker","error","port1","port2","workerPort","_PostMessageToWorker","PublishMessageCommands","publishMessagePayload","_ProcessTelemetry","_CreateAsyncRunner","_SetRunnerIntoWorker","payload","__privateMethod","CreateRunnerCopy_fn","payloadContents","store","update","message","Gauge","asyncRunnerContext","ModelDelimeter","command","transferObject","_TerminateWorker","ids","id","promArray","Sleep","retVal","leastRunnerWorker","stsWorker","busyWorker","CompareSTSInstrumentControllerPluginKeyWMEx","STSInstrumentControllerPluginKey","GetSTSInstrumentController","GetSTSInstrumentControllerPluginKeyWM","CompareSTSInstrumentControllerPluginKeyWM","val","GetSTSInstrumentControllerPluginKey","useSTSWorkerManager","STSWorkerManagerPlugin","wm","RequestResponseHelper","port","_requestResponseMessages","_requestResponseMessageTimeout","_port","resolve","reject","messageId","detail","msg","_SetupListener","requestResponseMessage","WorkerInstance","_collectorCollectorPort","_requestResponseHelper","_runners","max","_SetMessagePort","workerMessagePort","response","_AddAsyncRunner","testRunnerTelemetryPayload","_StopRunners","testRunner","payloadMessage"],"mappings":"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","x_google_ignoreList":[1,3]}
package/package.json CHANGED
@@ -1,26 +1,35 @@
1
1
  {
2
2
  "name": "@nsshunt/stsvueutils",
3
- "version": "1.0.15",
3
+ "version": "1.0.17",
4
4
  "description": "Vue 3 framework utilities and plugins",
5
- "main": "dist/index.js",
5
+ "main": "./dist/stsvueutils.umd.js",
6
+ "module": "./dist/stsvueutils.mjs",
7
+ "type": "commonjs",
6
8
  "types": "./types/index.d.ts",
9
+ "exports": {
10
+ ".": {
11
+ "import": "./dist/stsvueutils.mjs",
12
+ "require": "./dist/stsvueutils.umd.js"
13
+ }
14
+ },
15
+ "files": [
16
+ "dist",
17
+ "types",
18
+ "LICENSE",
19
+ "README.md"
20
+ ],
7
21
  "scripts": {
8
22
  "lint": "eslint . --ext js,jsx,ts,tsx",
9
23
  "lintex": "eslint . --ext js,jsx,ts,tsx --fix",
10
24
  "test": "jest --detectOpenHandles --no-cache",
11
25
  "testwatch": "jest --watchAll --detectOpenHandles --no-cache",
12
- "build": "tsc"
26
+ "build": "tsc && vite build",
27
+ "build2": "tsc"
13
28
  },
14
29
  "repository": {
15
30
  "type": "git",
16
31
  "url": "git+https://github.com/nsshunt/stsvueutils.git"
17
32
  },
18
- "files": [
19
- "dist/*",
20
- "types/*",
21
- "LICENSE",
22
- "README.md"
23
- ],
24
33
  "author": "STS",
25
34
  "license": "MIT",
26
35
  "bugs": {
@@ -39,19 +48,20 @@
39
48
  "eslint": "^8.37.0",
40
49
  "jest": "^29.5.0",
41
50
  "prettier": "^2.8.7",
51
+ "rollup-plugin-visualizer": "^5.9.0",
42
52
  "supertest": "^6.3.3",
43
53
  "ts-loader": "^9.4.2",
44
54
  "typescript": "^5.0.3",
55
+ "vite": "^4.2.1",
45
56
  "vue": "^3.2.47"
46
57
  },
47
58
  "dependencies": {
48
59
  "@nsshunt/stsinstrumentation": "^6.11.71",
49
60
  "@nsshunt/stsmodels": "^1.12.67",
50
- "@nsshunt/stspublisherserver": "^1.15.25",
61
+ "@nsshunt/stspublisherserver": "^1.15.27",
51
62
  "@nsshunt/stsutils": "^1.15.28",
52
63
  "js-cookie": "^3.0.1",
53
64
  "pinia": "^2.0.33",
54
- "tiny-emitter": "^2.1.0",
55
- "vue-demi": "^0.13.11"
65
+ "tiny-emitter": "^2.1.0"
56
66
  }
57
67
  }
@@ -1 +1 @@
1
- {"version":3,"file":"workerManager.d.ts","sourceRoot":"","sources":["../../src/plugins/workerManager.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAA8B,SAAS,EAAW,SAAS,EACtC,cAAc,EAC3C,qBAAqB,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAS7E,qBAAa,gBAAgB;;gBAWb,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,qBAAqB;IAuBrD,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAGzC;IAED,SAAS,sBAA6B,cAAc,KAAG,QAAQ,SAAS,CAAC,CAkExE;IAED,iBAAiB,gBAAiB,SAAS,iBAAiB,cAAc,KAAG,SAAS,CAKrF;IAkMD,sBAAsB,QAAO,SAAS,GAAG,IAAI,CAa5C;IAED,aAAa,QAAO,SAAS,GAAG,IAAI,CAanC;IAED,IAAI,OAAO,IAAI,qBAAqB,CAEnC;IAED,IAAI,OAAO,CAAC,OAAO,EAAE,qBAAqB,EAEzC;IAoCD,cAAc,sBAOb;CACJ;AAED,eAAO,MAAM,qCAAqC,QAAO,MAA0C,CAAA;AAEnG,eAAO,MAAM,yCAAyC,QAAS,MAAM,KAAG,OAAmD,CAAA;AAE3H,eAAO,MAAM,2CAA2C,QAAO,OAAqF,CAAA;AAIpJ,eAAO,MAAM,mBAAmB,QAAO,gBAAyE,CAAA;AAEhH,eAAO,MAAM,sBAAsB;mBAEhB,GAAG,YAAY,qBAAqB;CAatD,CAAA"}
1
+ {"version":3,"file":"workerManager.d.ts","sourceRoot":"","sources":["../../src/plugins/workerManager.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAA8B,SAAS,EAAW,SAAS,EACtC,cAAc,EAC3C,qBAAqB,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAS7E,qBAAa,gBAAgB;;gBAWb,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,qBAAqB;IA2BrD,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAGzC;IAED,SAAS,sBAA6B,cAAc,KAAG,QAAQ,SAAS,CAAC,CAkExE;IAED,iBAAiB,gBAAiB,SAAS,iBAAiB,cAAc,KAAG,SAAS,CAKrF;IAkMD,sBAAsB,QAAO,SAAS,GAAG,IAAI,CAa5C;IAED,aAAa,QAAO,SAAS,GAAG,IAAI,CAanC;IAED,IAAI,OAAO,IAAI,qBAAqB,CAEnC;IAED,IAAI,OAAO,CAAC,OAAO,EAAE,qBAAqB,EAEzC;IAoCD,cAAc,sBAOb;CACJ;AAED,eAAO,MAAM,qCAAqC,QAAO,MAA0C,CAAA;AAEnG,eAAO,MAAM,yCAAyC,QAAS,MAAM,KAAG,OAAmD,CAAA;AAE3H,eAAO,MAAM,2CAA2C,QAAO,OAAqF,CAAA;AAIpJ,eAAO,MAAM,mBAAmB,QAAO,gBAAyE,CAAA;AAEhH,eAAO,MAAM,sBAAsB;mBAEhB,GAAG,YAAY,qBAAqB;CAatD,CAAA"}
package/dist/index.js DELETED
@@ -1,26 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./plugins/stsPluginKeys"), exports);
18
- __exportStar(require("./plugins/emitter"), exports);
19
- __exportStar(require("./plugins/storage"), exports);
20
- __exportStar(require("./plugins/stsStorage"), exports);
21
- __exportStar(require("./plugins/workerManager"), exports);
22
- __exportStar(require("./plugins/requestResponseHelper"), exports);
23
- __exportStar(require("./plugins/stsTestWorkerDefinitions"), exports);
24
- __exportStar(require("./plugins/workerInstance"), exports);
25
- __exportStar(require("./stores/TelemetryStore"), exports);
26
- //# sourceMappingURL=index.js.map
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,0DAAuC;AAEvC,oDAAiC;AACjC,oDAAiC;AACjC,uDAAoC;AAEpC,0DAAuC;AACvC,kEAA+C;AAC/C,qEAAkD;AAClD,2DAAwC;AAExC,0DAAuC"}
@@ -1,8 +0,0 @@
1
- "use strict";
2
- describe("Test Latency Controller", () => {
3
- test('Testing Module', async () => {
4
- expect.assertions(1);
5
- expect(1).toEqual(1);
6
- });
7
- });
8
- //# sourceMappingURL=index.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.test.js","sourceRoot":"","sources":["../src/index.test.ts"],"names":[],"mappings":";AACA,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IAErC,IAAI,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;QAE9B,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACrB,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
@@ -1,49 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.STSEmitterPlugin = exports.useSTSEmitterPlugin = void 0;
27
- const vue_1 = require("vue");
28
- const stsPluginKeys_1 = require("./stsPluginKeys");
29
- const te = __importStar(require("tiny-emitter"));
30
- // Create our use composable. This pattern is also used by vue router library with the useRoute and useRouter composables.
31
- // https://skirtles-code.github.io/vue-examples/patterns/global-properties.html#application-level-provide-inject
32
- const useSTSEmitterPlugin = () => (0, vue_1.inject)(stsPluginKeys_1.STSEmitterPluginKey);
33
- exports.useSTSEmitterPlugin = useSTSEmitterPlugin;
34
- // https://learnvue.co/2021/06/building-your-own-vue-3-plugin-a-full-guide/
35
- exports.STSEmitterPlugin = {
36
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
37
- install: (app) => {
38
- const tinyEmitter = new te.TinyEmitter();
39
- // Assign plugin instance to global $sts object (legacy method - see below)
40
- if (!app.config.globalProperties.$sts) {
41
- app.config.globalProperties.$sts = {};
42
- }
43
- app.config.globalProperties.$sts[stsPluginKeys_1.STSEmitterPluginKey] = tinyEmitter;
44
- // Assign App level provide for this STS plugin using symbol keys
45
- // https://vuejs.org/guide/components/provide-inject.html#working-with-symbol-keys
46
- app.provide(stsPluginKeys_1.STSEmitterPluginKey, tinyEmitter);
47
- }
48
- };
49
- //# sourceMappingURL=emitter.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"emitter.js","sourceRoot":"","sources":["../../src/plugins/emitter.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6BAA4B;AAE5B,mDAAsD;AAEtD,iDAAmC;AAEnC,0HAA0H;AAC1H,gHAAgH;AACzG,MAAM,mBAAmB,GAAG,GAAmB,EAAE,CAAC,IAAA,YAAM,EAAC,mCAAmB,CAAmB,CAAA;AAAzF,QAAA,mBAAmB,uBAAsE;AAEtG,2EAA2E;AAC9D,QAAA,gBAAgB,GAAG;IAC5B,+DAA+D;IAC/D,OAAO,EAAE,CAAC,GAAQ,EAAE,EAAE;QAClB,MAAM,WAAW,GAAmB,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAEzD,2EAA2E;QAC3E,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,EAAE;YACnC,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,GAAG,EAAG,CAAC;SAC1C;QACD,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,mCAAmB,CAAC,GAAG,WAAW,CAAC;QAEpE,iEAAiE;QACjE,kFAAkF;QAClF,GAAG,CAAC,OAAO,CAAC,mCAAmB,EAAE,WAAW,CAAC,CAAC;IAClD,CAAC;CACJ,CAAA"}