正在停止活动的Testcafe运行



我试图在Testcafe运行中添加一个停止函数。我用启动Testcafe

let testcafe = null;
let testcafeprom = null;
testcafeprom = createTestCafe('localhost', 1337, 1338)
.then(tc => {
testcafe     = tc;
const runner = testcafe.createRunner();
return runner
.src([__basedir + '/tests/temp.js'])
.browsers(myBrowser)
//.browsers('browserstack:Chrome')
.screenshots(__basedir +'/allure/screenshots/', true)
.reporter(['uistatusreporter', {name: 'allure',output: 'test/report.json'}])
.run();
})
.then(failedCount => {
testcafe.close();
startReportGenerator();
capcon.stopCapture(process.stdout);
console.log("Testcafe Ende");

if(failedCount>0){
res.sendStatus(400);
console.log('Tests failed: ' + failedCount);
//res.statusCode = 400; //BadRequest 400
/*
res.json({
success: 'failed',
fails: failedCount
});
*/
}else{
//res.statusCode = 200; //BadRequest 400
res.sendStatus(200);
console.log('All success');
/*
res.json({
success: 'ok',
fails: failedCount
});
*/
}
})
.catch(error => {
testcafe.close();
console.log('Tests failed: Testcafe Error');
console.log(error);
res.sendStatus(401);
});

然后我添加了一个停止运行的功能:

router.get('/stopit', async (req, res) => {
testcafeprom.cancel();
res.sendStatus(200);
});

据我所知,createTestCafe将返回一个promise,并且为了停止我调用testcafeprom.cancel();testcafeprom.stop();的promise

但浏览器正在运行。一个简单的testcafe.close();将停止Testcafe完成。但我想阻止它,而不是击落它。

有什么建议可以更好地阻止它吗?

更新:我还测试了让跑步者如愿以偿的方法:


createTestCafe('localhost', 1337, 1338)
.then(tc => {
testcafe     = tc;
const runner = testcafe.createRunner();
testcafeprom =  runner
.src([__basedir + '/tests/temp.js'])
.browsers(myBrowser)
//.browsers('browserstack:Chrome')
.screenshots(__basedir +'/allure/screenshots/', true)
.reporter(['uistatusreporter', {name: 'allure',output: 'test/report.json'}])
.run();
return testcafeprom;
})

还添加

await testcafeprom.cancel();

这将产生与testCafe.close()完全相同的结果,意味着所有东西都被击落,没有任何响应。我很困惑。

最后我尝试了:

let runner = null;
createTestCafe('localhost', 1337, 1338, void 0, true)
.then(testcafe => {
runner = testcafe.createRunner();
})
.then(() => {
return runner
.src([__basedir + '/tests/temp.js'])
.browsers(myBrowser)
//.browsers('browserstack:Chrome')
.screenshots(__basedir +'/allure/screenshots/', true)
.reporter(['uistatusreporter', {name: 'allure',output: 'test/report.json'}])
.run()
.then(failedCount => {
//testcafe.close();
startReportGenerator();
capcon.stopCapture(process.stdout);
console.log(`Finished. Count failed tests:${failedCount}`);
//process.exit(failedCount);
res.sendStatus(200);
});
})
.catch(error => {
startReportGenerator();
capcon.stopCapture(process.stdout);
console.log(error);
//process.exit(1);
res.sendStatus(401);
});

但这里是一样的。如果我调用waitrunner.stop(),看起来该命令将终止整个过程,并且不会返回到promise。

这是如何停止运行的TestCafe实例的秘密吗?还是整个过程被击落的秘密?

由于我无法调试您的项目,因此很难准确说出您面临问题的原因。但是,当您使用cancel停止测试执行时,您是正确的。cancel方法停止测试执行并关闭浏览器,但不会停止TestCafe。这意味着您可以再次使用run方法,它将开始测试执行并再次打开浏览器。

我创建了一个示例来证明这种方法是有效的。

测试代码:

fixture `fixture`
.page `http://example.com`;
for (let i = 0; i < 50; i++) {
test(`test A ${i}`, async t => {
await t.click('h1');
});
}

Testcafe启动代码:

const createTestCafe = require('testcafe');
(async () => {
const testCafe = await createTestCafe();
let timeout;
const runner = testCafe.createRunner();
const runPromise = runner
.src('test.js')
.browsers('chrome')
.run();
const cancelPromise = new Promise(resolve => {
timeout = setTimeout(() => {
runPromise.cancel();
resolve('canceled');
}, 20000);
});
let value = await Promise.race([runPromise, cancelPromise]);
if (value === 'canceled')
console.log('test execution was canceled')
value = await runner.run();
console.log(`${value} failed tests`);
await testCafe.close();
})();

最新更新