X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=tests%2Futils.test.js;h=93e9e5c2e9b17f99165beb29e028239c7328dfa9;hb=b4c2a50df77a5f3110d228436ce9f3008cbd8297;hp=76abf04645ef4fa6e70b7e88e97ea25a611dde89;hpb=970b38d6f87c7d0d29498f13af934c8ff6d472f5;p=poolifier.git diff --git a/tests/utils.test.js b/tests/utils.test.js index 76abf046..93e9e5c2 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -1,26 +1,98 @@ +const { randomInt } = require('crypto') +const { Worker } = require('worker_threads') +const cluster = require('cluster') +const os = require('os') const { expect } = require('expect') const { CircularArray, DEFAULT_CIRCULAR_ARRAY_SIZE } = require('../lib/circular-array') const { + DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS, + DEFAULT_TASK_NAME, + DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS, + EMPTY_FUNCTION, availableParallelism, average, + exponentialDelay, + getWorkerType, + getWorkerId, isAsyncFunction, isKillBehavior, isPlainObject, median, round, secureRandom, + sleep, updateMeasurementStatistics } = require('../lib/utils') -const { KillBehaviors } = require('../lib/worker/worker-options') +const { KillBehaviors, WorkerTypes } = require('../lib') describe('Utils test suite', () => { + it('Verify DEFAULT_TASK_NAME value', () => { + expect(DEFAULT_TASK_NAME).toBe('default') + }) + + it('Verify EMPTY_FUNCTION value', () => { + expect(EMPTY_FUNCTION).toStrictEqual(expect.any(Function)) + }) + + it('Verify DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS values', () => { + expect(DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS).toStrictEqual({ + retries: 6, + runTime: { median: false }, + waitTime: { median: false }, + elu: { median: false } + }) + }) + + it('Verify DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS values', () => { + expect(DEFAULT_MEASUREMENT_STATISTICS_REQUIREMENTS).toStrictEqual({ + aggregate: false, + average: false, + median: false + }) + }) + it('Verify availableParallelism() behavior', () => { - expect(typeof availableParallelism() === 'number').toBe(true) - expect(availableParallelism()).toBeGreaterThan(0) - expect(Number.isSafeInteger(availableParallelism())).toBe(true) + const parallelism = availableParallelism() + expect(typeof parallelism === 'number').toBe(true) + expect(Number.isSafeInteger(parallelism)).toBe(true) + let expectedParallelism = 1 + try { + expectedParallelism = os.availableParallelism() + } catch { + expectedParallelism = os.cpus().length + } + expect(parallelism).toBe(expectedParallelism) + }) + + it('Verify getWorkerType() behavior', () => { + expect( + getWorkerType(new Worker('./tests/worker-files/thread/testWorker.js')) + ).toBe(WorkerTypes.thread) + expect(getWorkerType(cluster.fork())).toBe(WorkerTypes.cluster) + }) + + it('Verify getWorkerId() behavior', () => { + const threadWorker = new Worker('./tests/worker-files/thread/testWorker.js') + const clusterWorker = cluster.fork() + expect(getWorkerId(threadWorker)).toBe(threadWorker.threadId) + expect(getWorkerId(clusterWorker)).toBe(clusterWorker.id) + }) + + it('Verify sleep() behavior', async () => { + const start = performance.now() + await sleep(1000) + const elapsed = performance.now() - start + expect(elapsed).toBeGreaterThanOrEqual(999) + }) + + it('Verify exponentialDelay() behavior', () => { + const delay = exponentialDelay(randomInt(1000)) + expect(typeof delay === 'number').toBe(true) + expect(delay).toBeGreaterThanOrEqual(Number.MIN_VALUE) + expect(delay).toBeLessThanOrEqual(Number.MAX_VALUE) }) it('Verify average() computation', () => { @@ -196,6 +268,41 @@ describe('Utils test suite', () => { average: 0.002, history: new CircularArray(DEFAULT_CIRCULAR_ARRAY_SIZE, 0.001, 0.003) }) + updateMeasurementStatistics( + measurementStatistics, + { aggregate: true, average: false, median: true }, + 0.006 + ) + expect(measurementStatistics).toStrictEqual({ + aggregate: 0.04, + maximum: 0.02, + minimum: 0.001, + median: 0.003, + history: new CircularArray( + DEFAULT_CIRCULAR_ARRAY_SIZE, + 0.001, + 0.003, + 0.006 + ) + }) + updateMeasurementStatistics( + measurementStatistics, + { aggregate: true, average: true, median: false }, + 0.01 + ) + expect(measurementStatistics).toStrictEqual({ + aggregate: 0.05, + maximum: 0.02, + minimum: 0.001, + average: 0.005, + history: new CircularArray( + DEFAULT_CIRCULAR_ARRAY_SIZE, + 0.001, + 0.003, + 0.006, + 0.01 + ) + }) }) it('Verify secureRandom() behavior', () => {