-
Notifications
You must be signed in to change notification settings - Fork 2.4k
Expand file tree
/
Copy pathlogger.rs
More file actions
126 lines (113 loc) · 3.43 KB
/
logger.rs
File metadata and controls
126 lines (113 loc) · 3.43 KB
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
use std::result;
use futures::sync::oneshot;
use hyper::{Response, StatusCode};
use http_service::{empty_response, json_fault_message, json_response};
use request::{ParsedRequest, SyncRequest};
use request::sync::GenerateResponse;
#[derive(Clone, Debug, Deserialize, PartialEq, Serialize)]
pub enum APILoggerLevel {
Error,
Warning,
Info,
Debug,
}
#[derive(Clone, Debug, Deserialize, PartialEq, Serialize)]
pub struct APILoggerDescription {
pub path: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub level: Option<APILoggerLevel>,
#[serde(skip_serializing_if = "Option::is_none")]
pub show_level: Option<bool>,
#[serde(skip_serializing_if = "Option::is_none")]
pub show_log_origin: Option<bool>,
}
#[derive(Debug)]
pub enum APILoggerError {
InitializationFailure(String),
}
impl GenerateResponse for APILoggerError {
fn generate_response(&self) -> Response {
use self::APILoggerError::*;
match *self {
InitializationFailure(ref e) => json_response(
StatusCode::BadRequest,
json_fault_message(format!{"Cannot initialize logging system! {}", e}),
),
}
}
}
pub enum PutLoggerOutcome {
Initialized,
Error(APILoggerError),
}
impl GenerateResponse for PutLoggerOutcome {
fn generate_response(&self) -> Response {
use self::PutLoggerOutcome::*;
match *self {
Initialized => empty_response(StatusCode::Created),
Error(ref e) => e.generate_response(),
}
}
}
impl APILoggerDescription {
pub fn into_parsed_request(self) -> result::Result<ParsedRequest, String> {
let (sender, receiver) = oneshot::channel();
Ok(ParsedRequest::Sync(
SyncRequest::PutLogger(self, sender),
receiver,
))
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_generate_response_logger_error() {
assert_eq!(
APILoggerError::InitializationFailure("Could not initialize log system".to_string())
.generate_response()
.status(),
StatusCode::BadRequest
);
assert!(
format!(
"{:?}",
APILoggerError::InitializationFailure(
"Could not initialize log system".to_string()
)
).contains("InitializationFailure")
);
}
#[test]
fn test_generate_response_put_logger_outcome() {
assert_eq!(
PutLoggerOutcome::Initialized.generate_response().status(),
StatusCode::Created
);
assert_eq!(
PutLoggerOutcome::Error(APILoggerError::InitializationFailure(
"Could not initialize log system".to_string()
)).generate_response()
.status(),
StatusCode::BadRequest
);
}
#[test]
fn test_into_parsed_request() {
let desc = APILoggerDescription {
path: String::from(""),
level: None,
show_level: None,
show_log_origin: None,
};
format!("{:?}", desc);
assert!(&desc.clone().into_parsed_request().is_ok());
let (sender, receiver) = oneshot::channel();
assert!(&desc.clone()
.into_parsed_request()
.eq(&Ok(ParsedRequest::Sync(
SyncRequest::PutLogger(desc, sender),
receiver
))));
}
}