summaryrefslogtreecommitdiff
path: root/src/oauth2.rs
blob: 0c5f1520ee953a83c70ddb346ff6c3b50e26cb5e (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
53
use rustc_serialize::json;

use datatype::{AccessToken, Error, Url};
use http::Client;


/// Authenticate with the specified OAuth2 server to retrieve a new `AccessToken`.
pub fn authenticate(server: Url, client: &Client) -> Result<AccessToken, Error> {
    debug!("authenticating at {}", server);
    let resp_rx = client.post(server, None);
    let resp    = resp_rx.recv().expect("no authenticate response received");
    let data    = try!(resp);
    let body    = try!(String::from_utf8(data));
    Ok(try!(json::decode(&body)))
}


#[cfg(test)]
mod tests {
    use super::*;
    use datatype::{AccessToken, Url};
    use http::TestClient;


    fn test_server() -> Url {
        "http://localhost:8000".parse().unwrap()
    }

    #[test]
    fn test_authenticate() {
        let token = r#"{
            "access_token": "token",
            "token_type": "type",
            "expires_in": 10,
            "scope": "scope1 scope2"
        }"#;
        let client = TestClient::from(vec![token.to_string()]);
        let expect = AccessToken {
            access_token: "token".to_string(),
            token_type:   "type".to_string(),
            expires_in:   10,
            scope:        "scope1 scope2".to_string()
        };
        assert_eq!(expect, authenticate(test_server(), &client).unwrap());
    }

    #[test]
    fn test_authenticate_bad_json() {
        let client = TestClient::from(vec![r#"{"apa": 1}"#.to_string()]);
        let expect = r#"Failed to decode JSON: MissingFieldError("access_token")"#;
        assert_eq!(expect, format!("{}", authenticate(test_server(), &client).unwrap_err()));
    }
}