我正在编写集成测试来处理数据库.在每个测试开始时,我清除存储并创建一些数据.
我希望测试按顺序运行,以确保使用的是空数据库.但集成测试似乎是并行运行的,因为有时我会在清理数据库后获取现有文档.
我判断了数据库,发现在不同测试中创建的文档具有大致相同的创建时间,即使我 for each 测试添加延迟(std::thread::sleep_ms(10000)
).
您能否澄清集成测试是如何运行的,以及是否可以按顺序运行它们?
我正在编写集成测试来处理数据库.在每个测试开始时,我清除存储并创建一些数据.
我希望测试按顺序运行,以确保使用的是空数据库.但集成测试似乎是并行运行的,因为有时我会在清理数据库后获取现有文档.
我判断了数据库,发现在不同测试中创建的文档具有大致相同的创建时间,即使我 for each 测试添加延迟(std::thread::sleep_ms(10000)
).
您能否澄清集成测试是如何运行的,以及是否可以按顺序运行它们?
默认情况下,内置测试框架同时运行.它旨在为测试提供有用但简单的支持,这涵盖了许多需求,并且许多功能可以在每个测试独立于其他测试的情况下进行测试.(独立意味着它们可以并行运行.)
也就是说,它确实会监听RUST_TEST_THREADS
环境变量,例如RUST_TEST_THREADS=1 cargo test
将在单个线程上运行测试.然而,如果您希望在测试中始终使用此功能,您可能对不使用#[test]
感兴趣,或者至少不直接使用#[test]
感兴趣.
最灵活的方式是通过cargo
对完全定义自己框架的测试的支持,通过Cargo.toml
中的以下内容:
[[test]]
name = "foo"
harness = false
这样,cargo test
将编译并以二进制形式运行tests/foo.rs
.这样可以确保操作顺序正确/复位.
或者,也许像stainless
这样的框架具有您需要的功能.(我没用过,所以我不确定.)