#axum #test-framework #http-client #test

axum-test-helpers

🧪 Test client for axum copied from axum

4 releases

0.8.0 Oct 14, 2024
0.7.6 Sep 25, 2024
0.7.5 Feb 10, 2024
0.7.4 Feb 10, 2024

#290 in Testing

Download history 33/week @ 2024-09-29 14/week @ 2024-10-06 188/week @ 2024-10-13 9/week @ 2024-10-20 8/week @ 2024-10-27 23/week @ 2024-11-03 1/week @ 2024-11-10 11/week @ 2024-11-17 10/week @ 2024-11-24 1/week @ 2024-12-01 26/week @ 2024-12-08 5/week @ 2024-12-15

367 downloads per month
Used in 2 crates

GPL-3.0-only

17KB
258 lines

axum-test-helpers

axum-test-helpers exposes axum original TestClient, which is private to the axum crate

More information about this crate can be found in the crate documentation.

High level features

  • Provide an easy to use interface
  • Start a server in a different port for each call
  • Deal with JSON, text and files response/requests

Usage example

Add this crate as a dev-dependency:

[dev-dependencies]
axum-test-helpers = "0.7.4"

Use the TestClient on your own Router:

use axum::Router;
use axum::http::StatusCode;
use axum_test_helper::TestClient;

// you can replace this Router with your own app
let app = Router::new().route("/", get(|| async {}));

// initiate the TestClient with the previous declared Router
let client = TestClient::new(app);
let res = client.get("/").await;
assert_eq!(res.status(), StatusCode::OK);

You can find examples like this in the example directory.

See the crate documentation for way more examples.

Disable trace

By default axum-test-helpers print trace like Listening on 127.0.0.1:36457. You can disable trace with axum-test-helpers = { version = "0.*", default-features = false, features = ["withouttrace"] }.

Contributing

Before submitting a pull request or after pulling from the main repository, ensure all tests pass:

# Run axum-test-helpers tests
cargo test

# Test the hello-world example project
(cd examples/hello-world && cargo test)

License

This project is licensed under the GPL-3.0-only.

Dependencies

~9–25MB
~309K SLoC