feat: add pool and worker readyness tracking infrastructure
[poolifier.git] / tests / worker / thread-worker.test.js
CommitLineData
a61a0724 1const { expect } = require('expect')
fd027a65
S
2const { ThreadWorker } = require('../../lib')
3
e1ffb94f
JB
4describe('Thread worker test suite', () => {
5 let numberOfMessagesPosted = 0
6 const postMessage = function () {
ffcbbad8 7 ++numberOfMessagesPosted
e1ffb94f
JB
8 }
9 class SpyWorker extends ThreadWorker {
10 getMainWorker () {
11 return { postMessage }
12 }
74a2a194 13 }
74a2a194 14
fd027a65
S
15 it('Verify worker has default maxInactiveTime', () => {
16 const worker = new ThreadWorker(() => {})
e1ffb94f 17 expect(worker.opts.maxInactiveTime).toStrictEqual(60000)
fd027a65 18 })
74a2a194 19
2431bdb4
JB
20 it('Verify that handleError() method is working properly', () => {
21 const error = new Error('Error as an error')
22 const worker = new ThreadWorker(() => {})
23 expect(worker.handleError(error)).toStrictEqual(error)
24 const errorMessage = 'Error as a string'
25 expect(worker.handleError(errorMessage)).toStrictEqual(errorMessage)
26 })
27
28 it('Verify worker invokes the getMainWorker() and postMessage() methods', () => {
74a2a194
APA
29 const worker = new SpyWorker(() => {})
30 worker.sendToMainWorker({ ok: 1 })
31 expect(numberOfMessagesPosted).toBe(1)
32 })
fd027a65 33})