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
use std::fs::File;
use std::path::Path;
use super::header::{Header, read_header};
use super::metadata;
use super::archive_info;
use super::write_op::{WriteOp};
use whisper::point;
#[derive(Debug)]
pub struct WhisperFile<'a> {
pub path: &'a str,
pub header: Header
}
pub fn open(path:& str) -> Result<WhisperFile, &'static str> {
let file_handle = File::open(Path::new(path));
match file_handle {
Ok(f) => {
let header = try!(read_header(f));
Ok(
WhisperFile {
path: path,
header: header
}
)
},
Err(_) => {
Err("generic file error")
}
}
}
impl<'a> WhisperFile<'a> {
pub fn write(&self, point: point::Point){
println!("file: {:?}\npoint: {:?}", self, point);
}
pub fn calculate_write_ops(&self, point: point::Point) -> Vec<WriteOp> {
return self.header.archive_infos.iter().map(|ai| ai.write(&point) ).collect();
}
pub fn read(&self, timestamp: u32) -> point::Point {
point::Point{value: 10.0, time: 10}
}
}
#[test]
fn has_write_ops(){
let whisper_file = WhisperFile{
path: "/a/nonsense/path",
header: Header {
metadata: metadata::Metadata {
aggregation_type: metadata::AggregationType::Average,
max_retention: 86400,
x_files_factor: 1056964608,
archive_count: 1
},
archive_infos: vec![
archive_info::ArchiveInfo {
offset: 28,
seconds_per_point: 60,
points: 1440
},
archive_info::ArchiveInfo {
offset: 56,
seconds_per_point: 60,
points: 1440
}
]
}
};
let write_ops = whisper_file.calculate_write_ops(
point::Point{value: 0.0, time: 10}
);
let expected = vec![
WriteOp{offset: 28, value: 0.0},
WriteOp{offset: 56, value: 0.0}
];
assert_eq!(write_ops, expected);
return;
}