编写单元测试后,我面临集成测试,包括针对数据库测试库(rethinkdb)。
每个测试用例必须彼此独立,每次测试后数据库都会被清除,这样他们就不会给出误报。
由于AVA架构是并行运行测试,我发现我无法以这种方式实现正面测试。例如:
test.beforeEach(async function(t) {
const users = t.context.users = await DB.models.User.save([
{name: 'jhon',username: 'doe'},
{name: 'fabri',username: 'fenos'},
{name: 'will',username: 'red'},
{name: 'smith',username: 'blue'},
{name: 'paul',username: 'orange'},
{name: 'tesla',username: 'ele'},
]);
t.context.tasks = await DB.models.Task.save([
{title: 'My task1', description: 'My duty1', assignee_id: _.sample(users).id},
{title: 'My task2', description: 'My duty2', assignee_id: _.sample(users).id},
{title: 'My task3', description: 'My duty3', assignee_id: _.sample(users).id},
]);
});
test.afterEach(async (t) => {
return await DB.clearDB();
});
我被迫使用串行功能,允许每个测试完成并以串行方式清除数据库。
如果测试同时共享相同的数据,我的测试可能会更新或删除可能导致误报的数据。
如果我正在编写的测试只是在阅读数据,我可以按照问题中提到的pre
和post
脚本执行播种和清理操作{{3并保持测试并行。
我也发现非常好,我可以使用t.context
并将用户/任务对象传递给我的测试。
这是一个,我们被迫使用串行测试执行的罕见情况吗?
您如何使用ava处理此类测试?
答案 0 :(得分:12)
是的,test.serial
就是为了这个。
或者,如果您可以为每个测试使用不同的数据库,以允许您并行运行它们。