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
127
use std::fmt::{Formatter, Result};
use hyper::error::{self, Error};
use hyper::header::{HeaderFormat, Header};
const NTS_HEADER_NAME: &'static str = "NTS";
const ALIVE_HEADER: &'static str = "ssdp:alive";
const UPDATE_HEADER: &'static str = "ssdp:update";
const BYEBYE_HEADER: &'static str = "ssdp:byebye";
#[derive(Copy, Clone, PartialEq, Eq, Hash, Debug)]
pub enum NTS {
Alive,
Update,
ByeBye,
}
impl Header for NTS {
fn header_name() -> &'static str {
NTS_HEADER_NAME
}
fn parse_header(raw: &[Vec<u8>]) -> error::Result<Self> {
if raw.len() != 1 {
return Err(Error::Header);
}
if &raw[0][..] == ALIVE_HEADER.as_bytes() {
Ok(NTS::Alive)
} else if &raw[0][..] == UPDATE_HEADER.as_bytes() {
Ok(NTS::Update)
} else if &raw[0][..] == BYEBYE_HEADER.as_bytes() {
Ok(NTS::ByeBye)
} else {
Err(Error::Header)
}
}
}
impl HeaderFormat for NTS {
fn fmt_header(&self, fmt: &mut Formatter) -> Result {
match *self {
NTS::Alive => try!(fmt.write_str(ALIVE_HEADER)),
NTS::Update => try!(fmt.write_str(UPDATE_HEADER)),
NTS::ByeBye => try!(fmt.write_str(BYEBYE_HEADER)),
};
Ok(())
}
}
#[cfg(test)]
mod tests {
use hyper::header::Header;
use super::NTS;
#[test]
fn positive_alive() {
let alive_header = &[b"ssdp:alive"[..].to_vec()];
match NTS::parse_header(alive_header) {
Ok(NTS::Alive) => (),
_ => panic!("Didn't Match With NTS::Alive"),
};
}
#[test]
fn positive_update() {
let update_header = &[b"ssdp:update"[..].to_vec()];
match NTS::parse_header(update_header) {
Ok(NTS::Update) => (),
_ => panic!("Didn't Match With NTS::Update"),
};
}
#[test]
fn positive_byebye() {
let byebye_header = &[b"ssdp:byebye"[..].to_vec()];
match NTS::parse_header(byebye_header) {
Ok(NTS::ByeBye) => (),
_ => panic!("Didn't Match With NTS::ByeBye"),
};
}
#[test]
#[should_panic]
fn negative_alive_extra() {
let alive_extra_header = &[b"ssdp:alive_someotherbytes"[..].to_vec()];
NTS::parse_header(alive_extra_header).unwrap();
}
#[test]
#[should_panic]
fn negative_unknown() {
let unknown_header = &[b"ssdp:somestring"[..].to_vec()];
NTS::parse_header(unknown_header).unwrap();
}
#[test]
#[should_panic]
fn negative_empty() {
let empty_header = &[b""[..].to_vec()];
NTS::parse_header(empty_header).unwrap();
}
#[test]
#[should_panic]
fn negative_no_value() {
let no_value_header = &[b"ssdp:"[..].to_vec()];
NTS::parse_header(no_value_header).unwrap();
}
}