|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+extern crate task3;
|
|
|
2
|
+
|
|
|
3
|
+use task3::*;
|
|
|
4
|
+
|
|
|
5
|
+#[test]
|
|
|
6
|
+fn no_rows() {
|
|
|
7
|
+ let pt = PascalsTriangle::new(0);
|
|
|
8
|
+ let expected: Vec<Vec<u32>> = Vec::new();
|
|
|
9
|
+ assert_eq!(expected, pt.rows());
|
|
|
10
|
+}
|
|
|
11
|
+
|
|
|
12
|
+
|
|
|
13
|
+#[test]
|
|
|
14
|
+fn one_row() {
|
|
|
15
|
+ let pt = PascalsTriangle::new(1);
|
|
|
16
|
+ let expected: Vec<Vec<u32>> = vec![vec![1]];
|
|
|
17
|
+ assert_eq!(expected, pt.rows());
|
|
|
18
|
+}
|
|
|
19
|
+
|
|
|
20
|
+#[test]
|
|
|
21
|
+fn two_rows() {
|
|
|
22
|
+ let pt = PascalsTriangle::new(2);
|
|
|
23
|
+ let expected: Vec<Vec<u32>> = vec![vec![1], vec![1, 1]];
|
|
|
24
|
+ assert_eq!(expected, pt.rows());
|
|
|
25
|
+}
|
|
|
26
|
+
|
|
|
27
|
+#[test]
|
|
|
28
|
+fn three_rows() {
|
|
|
29
|
+ let pt = PascalsTriangle::new(3);
|
|
|
30
|
+ let expected: Vec<Vec<u32>> = vec![vec![1], vec![1, 1], vec![1, 2, 1]];
|
|
|
31
|
+ assert_eq!(expected, pt.rows());
|
|
|
32
|
+}
|
|
|
33
|
+
|
|
|
34
|
+#[test]
|
|
|
35
|
+fn last_of_four_rows() {
|
|
|
36
|
+ let pt = PascalsTriangle::new(4);
|
|
|
37
|
+ let expected: Vec<u32> = vec![1, 3, 3, 1];
|
|
|
38
|
+ assert_eq!(expected, pt.rows().pop().unwrap());
|
|
|
39
|
+}
|