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
use std::collections::HashMap;
use rand;
use frame::*;
use types::to_short;
const CQL_VERSION: &'static str = "CQL_VERSION";
const CQL_VERSION_VAL: &'static str = "3.0.0";
const COMPRESSION: &'static str = "COMPRESSION";
#[derive(Debug)]
pub struct BodyReqStartup<'a> {
pub map: HashMap<&'static str, &'a str>,
}
impl<'a> BodyReqStartup<'a> {
pub fn new<'b>(compression: Option<&'b str>) -> BodyReqStartup<'b> {
let mut map = HashMap::new();
map.insert(CQL_VERSION, CQL_VERSION_VAL);
if let Some(c) = compression {
map.insert(COMPRESSION, c);
}
BodyReqStartup { map: map }
}
fn num(&self) -> Vec<u8> {
to_short(self.map.len() as i16)
}
}
impl<'a> IntoBytes for BodyReqStartup<'a> {
fn into_cbytes(&self) -> Vec<u8> {
let mut v = vec![];
v.extend_from_slice(&self.num().as_slice());
for (key, val) in self.map.iter() {
v.extend_from_slice(to_short(key.len() as i16).as_slice());
v.extend_from_slice(key.as_bytes());
v.extend_from_slice(to_short(val.len() as i16).as_slice());
v.extend_from_slice(val.as_bytes());
}
v
}
}
impl Frame {
pub fn new_req_startup(compression: Option<&str>) -> Frame {
let version = Version::Request;
let flag = Flag::Ignore;
let stream = rand::random::<u16>();
let opcode = Opcode::Startup;
let body = BodyReqStartup::new(compression);
Frame { version: version,
flags: vec![flag],
stream: stream,
opcode: opcode,
body: body.into_cbytes(),
tracing_id: None,
warnings: vec![], }
}
}
#[cfg(test)]
mod test {
use super::*;
use frame::{Flag, Frame, Opcode, Version};
#[test]
fn new_body_req_startup_some_compression() {
let compression = "test_compression";
let body = BodyReqStartup::new(Some(compression));
assert_eq!(body.map.get("CQL_VERSION"), Some(&"3.0.0"));
assert_eq!(body.map.get("COMPRESSION"), Some(&compression));
assert_eq!(body.map.len(), 2);
}
#[test]
fn new_body_req_startup_none_compression() {
let body = BodyReqStartup::new(None);
assert_eq!(body.map.get("CQL_VERSION"), Some(&"3.0.0"));
assert_eq!(body.map.len(), 1);
}
#[test]
fn new_req_startup() {
let compression = Some("test_compression");
let frame = Frame::new_req_startup(compression);
assert_eq!(frame.version, Version::Request);
assert_eq!(frame.flags, vec![Flag::Ignore]);
assert_eq!(frame.opcode, Opcode::Startup);
assert_eq!(frame.tracing_id, None);
assert_eq!(frame.warnings, vec![] as Vec<String>);
}
}