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
///
/// This is just a wrapper around Vec
///
pub struct BasicList<T> {
    vec: Vec<T>,
}

impl<T> BasicList<T> {
    fn new() -> Self {
        BasicList { vec: vec![] }
    }

    fn add(&mut self, data: T) {
        self.vec.push(data)
    }

    fn get(&self, index: usize) -> Option<&T> {
        self.vec.get(index)
    }
}

#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn add_one() {
        let mut lst: BasicList<u32> = BasicList::new();

        let input = 25;
        lst.add(input);

        let result = lst.get(0);

        match result {
            None => {
                panic!()
            }
            Some(output) => {
                assert_eq!(*output, input)
            }
        }
    }

    #[test]
    fn add_multiple() {
        let mut lst: BasicList<u32> = BasicList::new();

        let vec: Vec<u32> = (0..100).collect();

        for num in &vec {
            lst.add(*num)
        }

        for i in 0..vec.len() {
            let expected = vec.get(i);
            let actual = lst.get(i);

            match (expected, actual) {
                (Some(a), Some(b)) => {
                    assert_eq!(a, b)
                }
                (_, _) => {
                    panic!()
                }
            }
        }
    }
}