gpt4 book ai didi

jestjs - 如何在多个文件中运行 Jest-Puppeteer 测试

转载 作者:行者123 更新时间:2023-12-04 02:28:56 25 4
gpt4 key购买 nike

我正在使用 jest-puppeteer 来运行我的网络测试。如果我在一个文件中运行所有定义的测试,则一切正常。

describe('user', () => {

jest.setTimeout(12000);

beforeEach(async () => {
await page.setViewport({width: 1200, height: 2000});
await page.goTo('http://localhost:3000');
});

it('test 1', async () => {
//my test steps
});

it('test 2', async () => {
//my test steps
});

});

但是,如果我在自己的文件中运行每个测试,则会出现错误。
UnhandledPromiseRejectionWarning: TypeError: Cannot read property 'addExpectationResult' of undefined

文件 1
describe('user', () => {

jest.setTimeout(12000);

beforeEach(async () => {
await page.setViewport({width: 1200, height: 2000});
await page.goTo('http://localhost:3000');
});

it('test 1', async () => {
//my test steps
});

});

文件 2
describe('user', () => {

jest.setTimeout(12000);

beforeEach(async () => {
await page.setViewport({width: 1200, height: 2000});
await page.goTo('http://localhost:3000');
});

it('test 2', async () => {
//my test steps
});

});

有趣的是,如果我在 test2 中添加一个 console.log('some statement') 作为第一步,一切都会再次运行。这就是为什么我认为这可能是一个时间问题。我正在按顺序运行我的测试,即 jest --runInBand
任何人都可以帮忙吗?

最佳答案

正如您所说,我同意问题是顺序异步,如 that github bugreport 中所述在帕特里克·休尔斯的回答中:

FWIW I also ran into this and was led to this issue. Only happened in CI when an async test timed out but the underlying action continued until after the test suite finished (and I'm guessing the callback tried to add the result of the expectation). I could never get it to happen locally though.



所以可能您的错误在“//我的测试步骤”中,您可以在运行异步进程之前操作您可以/需要操作的测试中的某些内容。

关于jestjs - 如何在多个文件中运行 Jest-Puppeteer 测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51441385/

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