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
use std::collections::btree_map:: { BTreeMap };
use merger::ops:: { TryMerge, MergeResult, TestError };
use report::test:: { Test, Tests };
use report::summary:: { Summary };
use report::attribute:: { SourceFile };
#[derive(Debug, Clone)]
pub struct File {
tests: Tests
}
impl File {
pub fn new(tests: Tests) -> Self {
File {
tests: tests
}
}
pub fn tests(&self) -> &Tests {
&self.tests
}
pub fn get_test(&self, name: &String) -> Option<&Test> {
self.tests.get(name)
}
}
impl<'a> TryMerge<&'a File> for File {
type Err = TestError;
fn try_merge(&mut self, file: &'a File) -> MergeResult<Self::Err> {
self.tests.try_merge(file.tests())
}
}
#[derive(Debug, Clone)]
pub struct Files {
files: BTreeMap<SourceFile, File>
}
impl Files {
pub fn new() -> Self {
Files {
files: BTreeMap::new()
}
}
}
impl_summary!(Files, files<SourceFile, File>);
impl<'a> TryMerge<(&'a SourceFile, &'a File)> for Files {
type Err = TestError;
fn try_merge(&mut self, source_file: (&'a SourceFile, &'a File)) -> MergeResult<Self::Err> {
if !self.files.contains_key(source_file.0) {
self.files.insert(source_file.0.clone(), source_file.1.clone());
return Ok(());
}
let file = self.files.get_mut(source_file.0).unwrap();
file.try_merge(source_file.1)
}
}
impl_try_merge_self_summary!(Files:files, TestError);