gpt4 book ai didi

node.js - 用 Jest 模拟自定义事件发射器

转载 作者:行者123 更新时间:2023-12-04 10:40:30 25 4
gpt4 key购买 nike

我想断言 EventEmitter 类的发射是通过使用 Jest 使用特定参数调用的。我有一个单独的文件,在其中创建要使用的 eventEmitter 实例,并在另一个类上导入它,并在某些时候发出事件。

// commonEmitter.ts
const events = require('events');
export const commonEmitter = new events.EventEmitter();

// class.ts
import { commonEmitter } from (..)

export class MyClass {
(...)

method(){
commonEmitter.emit('eventName', { data: true});
}
}

// class.spec.ts

let commonEmitterMock: any

beforeEach(() => {
commonEmitterMock = createMock('emit');
});


it('testMyClass', async () => {
const method = new MyClass().method();
expect(commonEmitterMock).toHaveBeenCalledWith('eventName', { data: true})
}

使用此实现,永远不会调用发出事件..
不知道为什么,有什么想法吗?

最佳答案

要在不放弃过度设计的代码的情况下测试 http 请求事件的不同分支,您可以执行以下操作。
这是我打算使用 Jest 测试的函数的 stub 版本:



function myRequest(resolve, reject) {
http.request(url, options, (res: IncomingMessage) => {
response.on('data', (chunk) => {
// On data event code
})
response.on('end', () => {
// On end event code
resolve()
})
response.on('error', (err) => {
reject(err)
})
}
}

首先,我们需要模拟 http 库并覆盖请求实现以手动触发回调并注入(inject)我们模拟的响应对象:


...
const mockRes = {
write: jest.fn(),
on: jest.fn(),
end: jest.fn()
}

jest.mock('http', () => ({
request: jest.fn().mockImplementation((url, options, cb) => {
cb(mockRes)
})
})

然后,我们的每个 Jest 测试单元,我们手动触发我们希望测试的每个事件的回调,将数据传递给每个特定的回调:


it('should call request callback and reject for invalid content response', async () => {
const resolve = jest.fn()
const reject = jest.fn()

mockRes.on.mockImplementation((event, cb) => {
if (event === 'end') {
cb()
} else if (event === 'data') {
cb(new Error('invalid_json_string'))
}
})

// @ts-ignore
myRequest(resolve, reject)

// @ts-ignore
expect(mockRes.on).toHaveBeenCalledWith('data', expect.any(Function))
expect(mockRes.on).toHaveBeenCalledWith('end', expect.any(Function))
expect(reject).toHaveBeenCalledWith(expect.any(Error))
})

关于node.js - 用 Jest 模拟自定义事件发射器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59957285/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com