Crates.io | tearup_macro |
lib.rs | tearup_macro |
version | 0.3.0 |
source | src |
created_at | 2023-03-05 20:32:23.844676 |
updated_at | 2023-04-03 19:31:21.567989 |
description | Setup - teardown your tests |
homepage | https://github.com/Greedeuh/tearup |
repository | https://github.com/Greedeuh/tearup |
max_upload_size | |
id | 801707 |
size | 9,520 |
A macro test helper to help you to write integration tests.
Basically:
fn setup()
before your testfn teardown()
after the test endAdd the following to your Cargo.toml
[dependencies]
tearup = "0.2"
The macros #[tearup(MyContext)]
executes the setup
then the method annoted and finally the teardown
.
The #[tearup_test(MyContext)]
act the same + add the #[test]
on the method.
#[tearup_test(WebContext)]
fn it_should_do_this(address: Address) {
// assert something
}
#[tearup_test(DbContext)]
async fn it_should_do_that(mut db: DbConnection, address: Address) {
// assert something
}
To do this you'll need to implement Context
trait with both setup
and teardown
methods.
use async_trait::async_trait;
use tearup::tearup_test;
// Define your context
struct YourContext {
something_you_need_in_teardown: SomethingYouSetup,
}
#[async_trait]
impl Context for YourContext {
async fn setup(shared_context: &mut SharedContext) -> Self {
/* --> do your setup here <-- */
// Register struct that you want to access in your test
shared_context.register(SomethingYouNeedInTest{});
// You still can store things in your struct for the treardown step
Self { something_you_need_in_teardown: SomethingYouSetup{} }
}
async fn teardown(mut self, shared_context: &mut SharedContext) {
/* --> clean your stuff here <-- */
// You still have access to the shared context
shared_context.get::<SomethingYouNeedInTest>();
// Same for self
self.something_you_need_in_teardown;
}
}
/// Type you need to access in test (registered in the SharedContext) must implement `Clone`
#[derive(Clone)]
struct SomethingYouNeedInTest;
struct SomethingYouSetup;
You can also combine your contexts with ContextCombinator
:
type Both = ConcurrentContextCombinator<YourContext, AnotherContext>;
#[tearup_test(Both)]
fn it_should_do_this(mut something_you_need_in_test: DbConnection, something_from_the_other_context: Address) {
// assert something
}
type MoreCombinaison = ConcurrentContextCombinator<YourContext, AnotherContext>;
#[tearup_test(MoreCombinaison)]
fn it_should_do_that(mut something_you_need_in_test: DbConnection, something_from_the_other_context: Address) {
// assert something
}