actix-web/actix-test
Rob Ede 4c4c279938
docs(test): intrgrate cargo-rdme
2024-06-10 23:23:38 +01:00
..
src docs(test): intrgrate cargo-rdme 2024-06-10 23:23:38 +01:00
CHANGES.md
Cargo.toml
LICENSE-APACHE
LICENSE-MIT
README.md docs(test): intrgrate cargo-rdme 2024-06-10 23:23:38 +01:00

README.md

actix-test

crates.io Documentation Version MIT or Apache 2.0 licensed
dependency status Download Chat on Discord

Integration testing tools for Actix Web applications.

The main integration testing tool is [TestServer]. It spawns a real HTTP server on an unused port and provides methods that use a real HTTP client. Therefore, it is much closer to real-world cases than using init_service, which skips HTTP encoding and decoding.

Examples

use actix_web::{get, web, test, App, HttpResponse, Error, Responder};

#[get("/")]
async fn my_handler() -> Result<impl Responder, Error> {
    Ok(HttpResponse::Ok())
}

#[actix_rt::test]
async fn test_example() {
    let srv = actix_test::start(||
        App::new().service(my_handler)
    );

    let req = srv.get("/");
    let res = req.send().await.unwrap();

    assert!(res.status().is_success());
}