1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-18 13:15:27 +00:00
actix-web/actix-web-codegen/tests/test_macro.rs

158 lines
4.6 KiB
Rust
Raw Normal View History

2019-12-12 17:08:38 +00:00
use actix_web::{http, test, web::Path, App, HttpResponse, Responder};
2019-06-05 02:43:13 +00:00
use actix_web_codegen::{connect, delete, get, head, options, patch, post, put, trace};
use futures::{future, Future};
2019-03-17 20:55:03 +00:00
// Make sure that we can name function as 'config'
#[get("/config")]
async fn config() -> impl Responder {
HttpResponse::Ok()
}
2019-03-17 20:55:03 +00:00
#[get("/test")]
2019-12-12 17:08:38 +00:00
async fn test_handler() -> impl Responder {
2019-03-17 20:55:03 +00:00
HttpResponse::Ok()
}
2019-05-02 16:49:10 +00:00
#[put("/test")]
2019-11-22 05:49:35 +00:00
async fn put_test() -> impl Responder {
2019-05-02 16:49:10 +00:00
HttpResponse::Created()
}
#[patch("/test")]
2019-11-22 05:49:35 +00:00
async fn patch_test() -> impl Responder {
HttpResponse::Ok()
}
2019-05-02 16:49:10 +00:00
#[post("/test")]
2019-11-22 05:49:35 +00:00
async fn post_test() -> impl Responder {
2019-05-02 16:49:10 +00:00
HttpResponse::NoContent()
}
#[head("/test")]
2019-11-22 05:49:35 +00:00
async fn head_test() -> impl Responder {
HttpResponse::Ok()
}
#[connect("/test")]
2019-11-22 05:49:35 +00:00
async fn connect_test() -> impl Responder {
HttpResponse::Ok()
}
#[options("/test")]
2019-11-22 05:49:35 +00:00
async fn options_test() -> impl Responder {
HttpResponse::Ok()
}
#[trace("/test")]
2019-11-22 05:49:35 +00:00
async fn trace_test() -> impl Responder {
HttpResponse::Ok()
}
#[get("/test")]
2019-11-21 07:01:07 +00:00
fn auto_async() -> impl Future<Output = Result<HttpResponse, actix_web::Error>> {
future::ok(HttpResponse::Ok().finish())
}
#[get("/test")]
2019-11-21 07:01:07 +00:00
fn auto_sync() -> impl Future<Output = Result<HttpResponse, actix_web::Error>> {
future::ok(HttpResponse::Ok().finish())
}
#[put("/test/{param}")]
2019-11-22 05:49:35 +00:00
async fn put_param_test(_: Path<String>) -> impl Responder {
HttpResponse::Created()
}
#[delete("/test/{param}")]
2019-11-22 05:49:35 +00:00
async fn delete_param_test(_: Path<String>) -> impl Responder {
HttpResponse::NoContent()
}
#[get("/test/{param}")]
2019-11-22 05:49:35 +00:00
async fn get_param_test(_: Path<String>) -> impl Responder {
HttpResponse::Ok()
}
2019-11-26 05:25:50 +00:00
#[actix_rt::test]
async fn test_params() {
2019-12-12 17:08:38 +00:00
let srv = test::start(|| {
App::new()
.service(get_param_test)
.service(put_param_test)
.service(delete_param_test)
2019-11-26 05:25:50 +00:00
});
let request = srv.request(http::Method::GET, srv.url("/test/it"));
let response = request.send().await.unwrap();
assert_eq!(response.status(), http::StatusCode::OK);
let request = srv.request(http::Method::PUT, srv.url("/test/it"));
let response = request.send().await.unwrap();
assert_eq!(response.status(), http::StatusCode::CREATED);
let request = srv.request(http::Method::DELETE, srv.url("/test/it"));
let response = request.send().await.unwrap();
assert_eq!(response.status(), http::StatusCode::NO_CONTENT);
}
#[actix_rt::test]
async fn test_body() {
2019-12-12 17:08:38 +00:00
let srv = test::start(|| {
App::new()
.service(post_test)
.service(put_test)
.service(head_test)
.service(connect_test)
.service(options_test)
.service(trace_test)
.service(patch_test)
.service(test_handler)
2019-11-26 05:25:50 +00:00
});
let request = srv.request(http::Method::GET, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::HEAD, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::CONNECT, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::OPTIONS, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::TRACE, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::PATCH, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
let request = srv.request(http::Method::PUT, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
assert_eq!(response.status(), http::StatusCode::CREATED);
let request = srv.request(http::Method::POST, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
assert_eq!(response.status(), http::StatusCode::NO_CONTENT);
let request = srv.request(http::Method::GET, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
}
#[actix_rt::test]
async fn test_auto_async() {
2019-12-12 17:08:38 +00:00
let srv = test::start(|| App::new().service(auto_async));
2019-11-26 05:25:50 +00:00
let request = srv.request(http::Method::GET, srv.url("/test"));
let response = request.send().await.unwrap();
assert!(response.status().is_success());
2019-03-17 20:55:03 +00:00
}