summaryrefslogtreecommitdiffstats
path: root/tests/log.rs
blob: 5f18bd79c6a95f08ee5563a0ad19ddccbdda4c05 (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
extern crate config;
extern crate log;

#[macro_use]
extern crate serde_derive;
extern crate serde_json;

use config::*;

#[derive(Debug, Deserialize)]
struct Settings {
    log: log::Level,
}

fn config(s: &str) -> Config {
    Config::default()
        .merge(File::from_str(s, FileFormat::Json))
        .unwrap()
        .clone()
}

#[test]
fn test_load_level_uppercase() {
    let s = r#"{ "log": "ERROR" }"#;
    let c = config(s);
    let l = c.get::<log::Level>("log").unwrap();
    assert_eq!(l, log::Level::Error);
}

#[test]
fn test_load_level_lowercase() {
    // to verify that this works
    {
        use std::str::FromStr;
        let l = log::Level::from_str("error").unwrap();
        assert_eq!(l, log::Level::Error);
    }

    let s = r#"{ "log": "error" }"#;

    // to confirm serde_json works as expected
    {
        let j: Settings = serde_json::from_str(s).unwrap();
        assert_eq!(j.log, log::Level::Error);
    }

    let c = config(s);
    assert_eq!(c.get_str("log").unwrap(), "error");
    let l = c.get::<log::Level>("log");
    assert!(l.is_ok(), "Expected Ok(_) for {:?}", l);
    assert_eq!(l.unwrap(), log::Level::Error);
}