aboutsummaryrefslogtreecommitdiffstats
path: root/tests/zotapi.rs
blob: 1030b19fa124a7a169930ea2b322c398f1c52ff5 (plain) (blame)
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
extern crate zotapi;
extern crate mockito;

use mockito::{mock, Matcher};

#[test]
fn get_channel_stream() {
    let m = mock("GET", "/api/z/1.0/channel/stream")
        .match_header("Authorization", Matcher::Regex(r"Basic \w+".into()))
        .with_status(200)
        .with_header("content-type", "application/json")
        .with_body("{}")
        .create();

    let z = zotapi::client(&format!("http://{}", mockito::SERVER_ADDRESS), "testuser", "test1234");
    let data = z.channel_stream();
    m.assert();
    assert_eq!(data.unwrap(), "{}");
}

#[test]
fn get_network_stream() {
    let m = mock("GET", "/api/z/1.0/network/stream")
        .match_header("Authorization", Matcher::Regex(r"Basic \w+".into()))
        .with_status(200)
        .with_header("content-type", "application/json")
        .with_body("{}")
        .create();

    let z = zotapi::client(&format!("http://{}", mockito::SERVER_ADDRESS), "testuser", "test1234");
    let data = z.network_stream();
    m.assert();
    assert_eq!(data.unwrap(), "{}");
}

#[test]
fn return_error_if_invalid_auth_provided() {
    let m = mock("GET", "/api/z/1.0/channel/stream")
        .with_status(401)
        .with_header("content-type", "text")
        .with_body("This api requires login")
        .create();

    let z = zotapi::client(&format!("http://{}", mockito::SERVER_ADDRESS), "nouser", "wrongpassword");
    let data = z.channel_stream();
    m.assert();
    assert!(data.is_err());
    assert_eq!(format!("{:?}", data), "Err(Unauthorized)");
}