summaryrefslogtreecommitdiffstats
path: root/third_party/rust/warp/tests/method.rs
blob: d03126cabdb9d236dbea423f33aeef95042e0e86 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#![deny(warnings)]
use warp::Filter;

#[tokio::test]
async fn method() {
    let _ = pretty_env_logger::try_init();
    let get = warp::get().map(warp::reply);

    let req = warp::test::request();
    assert!(req.matches(&get).await);

    let req = warp::test::request().method("POST");
    assert!(!req.matches(&get).await);

    let req = warp::test::request().method("POST");
    let resp = req.reply(&get).await;
    assert_eq!(resp.status(), 405);
}

#[tokio::test]
async fn method_not_allowed_trumps_not_found() {
    let _ = pretty_env_logger::try_init();
    let get = warp::get().and(warp::path("hello").map(warp::reply));
    let post = warp::post().and(warp::path("bye").map(warp::reply));

    let routes = get.or(post);

    let req = warp::test::request().method("GET").path("/bye");

    let resp = req.reply(&routes).await;
    // GET was allowed, but only for /hello, so POST returning 405 is fine.
    assert_eq!(resp.status(), 405);
}

#[tokio::test]
async fn bad_request_trumps_method_not_allowed() {
    let _ = pretty_env_logger::try_init();
    let get = warp::get()
        .and(warp::path("hello"))
        .and(warp::header::exact("foo", "bar"))
        .map(warp::reply);
    let post = warp::post().and(warp::path("bye")).map(warp::reply);

    let routes = get.or(post);

    let req = warp::test::request().method("GET").path("/hello");

    let resp = req.reply(&routes).await;
    // GET was allowed, but header rejects with 400, should not
    // assume POST was the appropriate method.
    assert_eq!(resp.status(), 400);
}