X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=tests%2Fworker%2Fabstract-worker.test.js;h=25e097234f439dc6ec68f18903440c21e95f1c10;hb=a86b6df187001e7e2e5c248ddb828286f985096c;hp=fbc9a06d26082b007d01572e95f02f610dc1f1a5;hpb=78cea37e264d5ca527bc42eb056f3b9579a2b2c4;p=poolifier.git diff --git a/tests/worker/abstract-worker.test.js b/tests/worker/abstract-worker.test.js index fbc9a06d..25e09723 100644 --- a/tests/worker/abstract-worker.test.js +++ b/tests/worker/abstract-worker.test.js @@ -9,18 +9,6 @@ describe('Abstract worker test suite', () => { } } - it('Verify that fn parameter is mandatory', () => { - expect(() => new ClusterWorker()).toThrowError( - new Error('fn parameter is mandatory') - ) - }) - - it('Verify that fn parameter is a function', () => { - expect(() => new ClusterWorker({})).toThrowError( - new TypeError('fn parameter is not a function') - ) - }) - it('Verify worker options default values', () => { const worker = new ThreadWorker(() => {}) expect(worker.opts.maxInactiveTime).toStrictEqual(60000) @@ -39,15 +27,63 @@ describe('Abstract worker test suite', () => { expect(worker.opts.async).toBe(true) }) - it('Verify that handleError function is working properly', () => { + it('Verify that taskFunctions parameter is mandatory', () => { + expect(() => new ClusterWorker()).toThrowError( + 'taskFunctions parameter is mandatory' + ) + }) + + it('Verify that taskFunctions parameter is a function or an object', () => { + expect(() => new ClusterWorker(0)).toThrowError( + new TypeError('taskFunctions parameter is not a function or an object') + ) + expect(() => new ClusterWorker('')).toThrowError( + new TypeError('taskFunctions parameter is not a function or an object') + ) + expect(() => new ClusterWorker(true)).toThrowError( + new TypeError('taskFunctions parameter is not a function or an object') + ) + }) + + it('Verify that taskFunctions parameter is an object literal', () => { + expect(() => new ClusterWorker([])).toThrowError( + new TypeError('taskFunctions parameter is not an object literal') + ) + expect(() => new ClusterWorker(new Map())).toThrowError( + new TypeError('taskFunctions parameter is not an object literal') + ) + expect(() => new ClusterWorker(new Set())).toThrowError( + new TypeError('taskFunctions parameter is not an object literal') + ) + expect(() => new ClusterWorker(new WeakMap())).toThrowError( + new TypeError('taskFunctions parameter is not an object literal') + ) + expect(() => new ClusterWorker(new WeakSet())).toThrowError( + new TypeError('taskFunctions parameter is not an object literal') + ) + }) + + it('Verify that taskFunctions parameter with multiple task functions is taken', () => { + const fn1 = () => { + return 1 + } + const fn2 = () => { + return 2 + } + const worker = new ClusterWorker({ fn1, fn2 }) + expect(typeof worker.taskFunctions.get('fn1') === 'function').toBe(true) + expect(typeof worker.taskFunctions.get('fn2') === 'function').toBe(true) + }) + + it('Verify that handleError() method is working properly', () => { const error = new Error('My error') const worker = new ThreadWorker(() => {}) expect(worker.handleError(error)).toStrictEqual(error) }) - it('Verify that get main worker throw error if main worker is not set', () => { + it('Verify that getMainWorker() throw error if main worker is not set', () => { expect(() => new StubPoolWithIsMainWorker(() => {}).getMainWorker() - ).toThrowError(new Error('Main worker was not set')) + ).toThrowError('Main worker was not set') }) })