Commit bd7f6c35a9802c44cad7658b5b3e99836f25376e
maks
Showing
6 changed files
with
203 additions
and
165 deletions
Show diff stats
src/ihm/TablooProto.java
@@ -36,7 +36,7 @@ public class TablooProto extends JPanel { | @@ -36,7 +36,7 @@ public class TablooProto extends JPanel { | ||
36 | private static Grid grid; | 36 | private static Grid grid; |
37 | 37 | ||
38 | // Fourni: ne rien changer. | 38 | // Fourni: ne rien changer. |
39 | - public TablooProto(Grid grid) throws ClassNotFoundException, IOException { | 39 | + public TablooProto(Grid grid) { |
40 | super(new GridLayout(1, 0)); | 40 | super(new GridLayout(1, 0)); |
41 | 41 | ||
42 | // modele de donnees | 42 | // modele de donnees |
@@ -61,7 +61,6 @@ public class TablooProto extends JPanel { | @@ -61,7 +61,6 @@ public class TablooProto extends JPanel { | ||
61 | TableColumn tm = table.getColumnModel().getColumn(0); | 61 | TableColumn tm = table.getColumnModel().getColumn(0); |
62 | tm.setPreferredWidth(tm.getPreferredWidth() * 2 / 3); | 62 | tm.setPreferredWidth(tm.getPreferredWidth() * 2 / 3); |
63 | tm.setCellRenderer(new PremiereColonneSpecificRenderer(Color.LIGHT_GRAY)); | 63 | tm.setCellRenderer(new PremiereColonneSpecificRenderer(Color.LIGHT_GRAY)); |
64 | - | ||
65 | } | 64 | } |
66 | 65 | ||
67 | // Inner class pour changer l'aspect de la premiere colonne consacree a la numerotation des lignes | 66 | // Inner class pour changer l'aspect de la premiere colonne consacree a la numerotation des lignes |
src/kernel/Cell.java
1 | package kernel; | 1 | package kernel; |
2 | 2 | ||
3 | import kernel.exception.CreateCycleException; | 3 | import kernel.exception.CreateCycleException; |
4 | -import kernel.exception.InvalidIntervalException; | ||
5 | 4 | ||
6 | import java.io.Serializable; | 5 | import java.io.Serializable; |
7 | import java.util.ArrayList; | 6 | import java.util.ArrayList; |
@@ -19,9 +18,6 @@ public class Cell implements Serializable { | @@ -19,9 +18,6 @@ public class Cell implements Serializable { | ||
19 | private List<Cell> usedIn = new ArrayList<>(); | 18 | private List<Cell> usedIn = new ArrayList<>(); |
20 | 19 | ||
21 | public Cell(String column, int line, double value) { | 20 | public Cell(String column, int line, double value) { |
22 | - | ||
23 | - | ||
24 | - | ||
25 | this.column = column; | 21 | this.column = column; |
26 | this.line = line; | 22 | this.line = line; |
27 | this.setValue(value); | 23 | this.setValue(value); |
@@ -29,8 +25,6 @@ public class Cell implements Serializable { | @@ -29,8 +25,6 @@ public class Cell implements Serializable { | ||
29 | 25 | ||
30 | public Cell(String column, int line, Formula formula) | 26 | public Cell(String column, int line, Formula formula) |
31 | throws CreateCycleException { | 27 | throws CreateCycleException { |
32 | - | ||
33 | - | ||
34 | this.column = column; | 28 | this.column = column; |
35 | this.line = line; | 29 | this.line = line; |
36 | this.setFormula(formula); | 30 | this.setFormula(formula); |
@@ -100,5 +94,5 @@ public class Cell implements Serializable { | @@ -100,5 +94,5 @@ public class Cell implements Serializable { | ||
100 | } | 94 | } |
101 | } | 95 | } |
102 | 96 | ||
103 | - | 97 | + |
104 | } | 98 | } |
src/kernel/Grid.java
@@ -19,7 +19,6 @@ public class Grid implements Serializable { | @@ -19,7 +19,6 @@ public class Grid implements Serializable { | ||
19 | private Map<String, Cell> cells = new HashMap<>(); | 19 | private Map<String, Cell> cells = new HashMap<>(); |
20 | public static LanguageEnum language = LanguageEnum.FR; | 20 | public static LanguageEnum language = LanguageEnum.FR; |
21 | 21 | ||
22 | - | ||
23 | public void createCell(String column, int line, double value) throws InvalidIntervalException { | 22 | public void createCell(String column, int line, double value) throws InvalidIntervalException { |
24 | column = column.toUpperCase(); | 23 | column = column.toUpperCase(); |
25 | 24 |
src/kernel/test/CellTest.java
1 | package kernel.test; | 1 | package kernel.test; |
2 | 2 | ||
3 | -import static org.junit.Assert.*; | ||
4 | - | ||
5 | -import java.util.ArrayList; | ||
6 | -import java.util.List; | ||
7 | - | ||
8 | import kernel.Cell; | 3 | import kernel.Cell; |
4 | +import kernel.Grid; | ||
5 | +import kernel.LanguageEnum; | ||
9 | import kernel.exception.CreateCycleException; | 6 | import kernel.exception.CreateCycleException; |
10 | import kernel.exception.InvalidIntervalException; | 7 | import kernel.exception.InvalidIntervalException; |
11 | import kernel.function.Average; | 8 | import kernel.function.Average; |
12 | import kernel.function.Sum; | 9 | import kernel.function.Sum; |
13 | import kernel.operation.Addition; | 10 | import kernel.operation.Addition; |
11 | +import org.junit.Before; | ||
12 | +import org.junit.Test; | ||
14 | 13 | ||
14 | +import java.util.ArrayList; | ||
15 | +import java.util.List; | ||
15 | 16 | ||
16 | -public class CellTest { | 17 | +import static org.junit.Assert.*; |
17 | 18 | ||
18 | - @org.junit.Test | ||
19 | - public void CreateCellValueTest() throws InvalidIntervalException { | ||
20 | - Cell A1= new Cell("A",1,25.); | ||
21 | - assertEquals(A1.getValue(),25.,0); | ||
22 | - assertEquals(A1.containFormula(),false); | ||
23 | - assertEquals(A1.getUsedIn().size(),0); | ||
24 | - assertEquals(A1.getId(),"A1"); | ||
25 | - } | ||
26 | 19 | ||
20 | +public class CellTest { | ||
27 | 21 | ||
28 | - @org.junit.Test | ||
29 | - public void CreateCellBinaryOperationTest() throws CreateCycleException, InvalidIntervalException { | ||
30 | - Cell A1= new Cell("A",1,25.); | ||
31 | - Cell A2= new Cell("A",2,35.); | ||
32 | - | ||
33 | - | ||
34 | - Cell A3= new Cell("A",3,new Addition(A1,A2)); | 22 | + @Before |
23 | + public void initData() { | ||
24 | + Grid.language = LanguageEnum.EN; | ||
25 | + } | ||
26 | + | ||
27 | + @Test | ||
28 | + public void CreateCellValueTest() { | ||
29 | + Cell A1 = new Cell("A", 1, 25.); | ||
30 | + assertEquals(A1.getValue(), 25., 0); | ||
31 | + assertFalse(A1.containFormula()); | ||
32 | + assertEquals(A1.getUsedIn().size(), 0); | ||
33 | + assertEquals(A1.getId(), "A1"); | ||
34 | + } | ||
35 | + | ||
36 | + @Test | ||
37 | + public void CreateCellBinaryOperationTest() throws CreateCycleException { | ||
38 | + Cell A1 = new Cell("A", 1, 25.); | ||
39 | + Cell A2 = new Cell("A", 2, 35.); | ||
40 | + Cell A3 = new Cell("A", 3, new Addition(A1, A2)); | ||
35 | 41 | ||
36 | - assertEquals(A3.getValue(),60.,0); | ||
37 | - assertEquals(A3.containFormula(),true); | ||
38 | - assertEquals(A3.getUsedIn().size(),0); | ||
39 | - assertEquals(A3.getId(),"A3"); | 42 | + assertEquals(A3.getValue(), 60., 0); |
43 | + assertTrue(A3.containFormula()); | ||
44 | + assertEquals(A3.getUsedIn().size(), 0); | ||
45 | + assertEquals(A3.getId(), "A3"); | ||
40 | 46 | ||
41 | - assertEquals(A3.toString(),"A1+A2"); | ||
42 | - assertEquals(A1.getUsedIn().size(),1); | ||
43 | - assertEquals(A2.getUsedIn().size(),1); | ||
44 | - | ||
45 | - | 47 | + assertEquals(A3.toString(), "(A1+A2)"); |
48 | + assertEquals(A1.getUsedIn().size(), 1); | ||
49 | + assertEquals(A2.getUsedIn().size(), 1); | ||
46 | } | 50 | } |
47 | - | ||
48 | 51 | ||
49 | - @org.junit.Test | ||
50 | - public void CreateCellFunctionTest() throws CreateCycleException, InvalidIntervalException { | ||
51 | - Cell A1= new Cell("A",1,25.); | ||
52 | - Cell A2= new Cell("A",2,35.); | ||
53 | - Cell A3= new Cell("A",3,new Addition(A1,A2)); | ||
54 | - Cell A5= new Cell("A",5,45.); | 52 | + @Test |
53 | + public void CreateCellFunctionTest() throws CreateCycleException { | ||
54 | + Cell A1 = new Cell("A", 1, 25.); | ||
55 | + Cell A2 = new Cell("A", 2, 35.); | ||
56 | + Cell A3 = new Cell("A", 3, new Addition(A1, A2)); | ||
57 | + Cell A5 = new Cell("A", 5, 45.); | ||
55 | List<Cell> sumList = new ArrayList<>(); | 58 | List<Cell> sumList = new ArrayList<>(); |
56 | - sumList.add(A1); | ||
57 | - sumList.add(A2); | ||
58 | - sumList.add(A3); | ||
59 | - sumList.add(A5); | ||
60 | - Cell A4= new Cell("A",4,new Sum(sumList)); | ||
61 | - | ||
62 | - assertEquals(A4.getValue(),165.,0); | ||
63 | - assertEquals(A4.containFormula(),true); | ||
64 | - assertEquals(A4.getUsedIn().size(),0); | 59 | + sumList.add(A1); |
60 | + sumList.add(A2); | ||
61 | + sumList.add(A3); | ||
62 | + sumList.add(A5); | ||
63 | + Cell A4 = new Cell("A", 4, new Sum(sumList)); | ||
65 | 64 | ||
65 | + assertEquals(A4.getValue(), 165., 0); | ||
66 | + assertTrue(A4.containFormula()); | ||
67 | + assertEquals(A4.getUsedIn().size(), 0); | ||
66 | 68 | ||
67 | - assertEquals(A4.toString(),"SOMME(A1,A2,A3,A5)"); | ||
68 | - assertEquals(A4.getDevelopedFormula(),"SOMME(A1,A2,(A1+A2),A5)"); | ||
69 | - assertEquals(A1.getUsedIn().size(),2); | ||
70 | - assertEquals(A2.getUsedIn().size(),2); | ||
71 | - assertEquals(A3.getUsedIn().size(),1); | ||
72 | - assertEquals(A5.getUsedIn().size(),1); | ||
73 | - | ||
74 | - | 69 | + assertEquals(A4.toString(), "SUM(A1,A2,A3,A5)"); |
70 | + assertEquals(A4.getDevelopedFormula(), "SUM(A1,A2,(A1+A2),A5)"); | ||
71 | + assertEquals(A1.getUsedIn().size(), 2); | ||
72 | + assertEquals(A2.getUsedIn().size(), 2); | ||
73 | + assertEquals(A3.getUsedIn().size(), 1); | ||
74 | + assertEquals(A5.getUsedIn().size(), 1); | ||
75 | } | 75 | } |
76 | - | ||
77 | 76 | ||
78 | - @org.junit.Test | ||
79 | - public void ModifyCellValueTest() throws CreateCycleException, InvalidIntervalException { | ||
80 | - Cell A1= new Cell("A",1,25.); | ||
81 | - Cell A2= new Cell("A",2,35.); | ||
82 | - Cell A3= new Cell("A",3,new Addition(A1,A2)); | ||
83 | - assertEquals(A1.getValue(),25.,0); | ||
84 | - assertEquals(A2.getValue(),35.,0); | ||
85 | - assertEquals(A3.getValue(),60.,0); | 77 | + @Test |
78 | + public void ModifyCellValueTest() throws CreateCycleException { | ||
79 | + Cell A1 = new Cell("A", 1, 25.); | ||
80 | + Cell A2 = new Cell("A", 2, 35.); | ||
81 | + Cell A3 = new Cell("A", 3, new Addition(A1, A2)); | ||
82 | + assertEquals(A1.getValue(), 25., 0); | ||
83 | + assertEquals(A2.getValue(), 35., 0); | ||
84 | + assertEquals(A3.getValue(), 60., 0); | ||
86 | A1.setValue(45.); | 85 | A1.setValue(45.); |
87 | - assertEquals(A1.getValue(),45.,0); | ||
88 | - assertEquals(A3.getValue(),80.,0); | ||
89 | - | 86 | + assertEquals(A1.getValue(), 45., 0); |
87 | + assertEquals(A3.getValue(), 80., 0); | ||
90 | } | 88 | } |
91 | - | ||
92 | - @org.junit.Test | ||
93 | - public void ModifyCellFormulaTest() throws CreateCycleException, InvalidIntervalException { | ||
94 | - Cell A1= new Cell("A",1,25.); | ||
95 | - Cell A2= new Cell("A",2,35.); | ||
96 | - Cell A3= new Cell("A",3,new Addition(A1,A2)); | ||
97 | - Cell A5= new Cell("A",5,45.); | 89 | + |
90 | + @Test | ||
91 | + public void ModifyCellFormulaTest() throws CreateCycleException { | ||
92 | + Cell A1 = new Cell("A", 1, 25.); | ||
93 | + Cell A2 = new Cell("A", 2, 35.); | ||
94 | + Cell A3 = new Cell("A", 3, new Addition(A1, A2)); | ||
95 | + Cell A5 = new Cell("A", 5, 45.); | ||
98 | List<Cell> sumList = new ArrayList<>(); | 96 | List<Cell> sumList = new ArrayList<>(); |
99 | - sumList.add(A1); | ||
100 | - sumList.add(A2); | ||
101 | - sumList.add(A3); | ||
102 | - sumList.add(A5); | ||
103 | - Cell A4= new Cell("A",4,new Sum(sumList)); | 97 | + sumList.add(A1); |
98 | + sumList.add(A2); | ||
99 | + sumList.add(A3); | ||
100 | + sumList.add(A5); | ||
101 | + Cell A4 = new Cell("A", 4, new Sum(sumList)); | ||
104 | 102 | ||
105 | - assertEquals(A4.getValue(),165.,0); | ||
106 | - assertEquals(A4.containFormula(),true); | ||
107 | - assertEquals(A4.getUsedIn().size(),0); | 103 | + assertEquals(A4.getValue(), 165., 0); |
104 | + assertTrue(A4.containFormula()); | ||
105 | + assertEquals(A4.getUsedIn().size(), 0); | ||
108 | 106 | ||
109 | - assertEquals(A1.getUsedIn().size(),2); | ||
110 | - assertEquals(A2.getUsedIn().size(),2); | ||
111 | - assertEquals(A3.getUsedIn().size(),1); | ||
112 | - assertEquals(A5.getUsedIn().size(),1); | 107 | + assertEquals(A1.getUsedIn().size(), 2); |
108 | + assertEquals(A2.getUsedIn().size(), 2); | ||
109 | + assertEquals(A3.getUsedIn().size(), 1); | ||
110 | + assertEquals(A5.getUsedIn().size(), 1); | ||
113 | 111 | ||
114 | - assertEquals(A1.containFormula(),false); | ||
115 | - A1.setFormula(new Addition(A2,A5)); | ||
116 | - assertEquals(A1.containFormula(),true); | 112 | + assertFalse(A1.containFormula()); |
113 | + A1.setFormula(new Addition(A2, A5)); | ||
114 | + assertTrue(A1.containFormula()); | ||
117 | 115 | ||
118 | - assertEquals(A1.getValue(),80.,0); | ||
119 | - assertEquals(A3.getValue(),115.,0); | ||
120 | - assertEquals(A4.getValue(),275.,0); | ||
121 | - | ||
122 | - | 116 | + assertEquals(A1.getValue(), 80., 0); |
117 | + assertEquals(A3.getValue(), 115., 0); | ||
118 | + assertEquals(A4.getValue(), 275., 0); | ||
123 | 119 | ||
120 | + assertEquals(A1.toString(), "(A2+A5)"); | ||
121 | + assertEquals(A1.getDevelopedFormula(), "(A2+A5)"); | ||
122 | + assertEquals(A4.toString(), "SUM(A1,A2,A3,A5)"); | ||
123 | + assertEquals(A4.getDevelopedFormula(), "SUM((A2+A5),A2,((A2+A5)+A2),A5)"); | ||
124 | 124 | ||
125 | - assertEquals(A1.toString(),"A2+A5"); | ||
126 | - assertEquals(A1.getDevelopedFormula(),"(A2+A5)"); | ||
127 | - assertEquals(A4.toString(),"SOMME(A1,A2,A3,A5)"); | ||
128 | - assertEquals(A4.getDevelopedFormula(),"SOMME((A2+A5),A2,((A2+A5)+A2),A5)"); | ||
129 | - | ||
130 | - | ||
131 | - assertEquals(A1.getUsedIn().size(),2); | ||
132 | - assertEquals(A2.getUsedIn().size(),3); | ||
133 | - assertEquals(A3.getUsedIn().size(),1); | ||
134 | - assertEquals(A5.getUsedIn().size(),2); | ||
135 | - | ||
136 | - | 125 | + assertEquals(A1.getUsedIn().size(), 2); |
126 | + assertEquals(A2.getUsedIn().size(), 3); | ||
127 | + assertEquals(A3.getUsedIn().size(), 1); | ||
128 | + assertEquals(A5.getUsedIn().size(), 2); | ||
137 | } | 129 | } |
138 | 130 | ||
139 | - @org.junit.Test(expected=CreateCycleException.class) | ||
140 | - public void DirectCycleBynaryOperation() throws CreateCycleException, InvalidIntervalException { | ||
141 | - Cell A1= new Cell("A",1,25.); | ||
142 | - Cell A2= new Cell("A",2,35.); | ||
143 | - try{ | ||
144 | - A1.setFormula(new Addition(A1,A2)); | ||
145 | - } | ||
146 | - catch(CreateCycleException ex){ | ||
147 | - throw ex; | ||
148 | - } | 131 | + @Test(expected = CreateCycleException.class) |
132 | + public void DirectCycleBynaryOperation() throws CreateCycleException { | ||
133 | + Cell A1 = new Cell("A", 1, 25.); | ||
134 | + Cell A2 = new Cell("A", 2, 35.); | ||
135 | + A1.setFormula(new Addition(A1, A2)); | ||
149 | } | 136 | } |
150 | 137 | ||
151 | 138 | ||
152 | - @org.junit.Test(expected=CreateCycleException.class) | ||
153 | - public void DirectCycleFunction() throws CreateCycleException, InvalidIntervalException { | ||
154 | - Cell A2= new Cell("A",2,25.); | ||
155 | - Cell B2= new Cell("B",2,35.); | ||
156 | - Cell A3= new Cell("A",3,0.5); | 139 | + @Test(expected = CreateCycleException.class) |
140 | + public void DirectCycleFunction() throws CreateCycleException { | ||
141 | + Cell A2 = new Cell("A", 2, 25.); | ||
142 | + Cell B2 = new Cell("B", 2, 35.); | ||
143 | + Cell A3 = new Cell("A", 3, 0.5); | ||
157 | List<Cell> sumList = new ArrayList<>(); | 144 | List<Cell> sumList = new ArrayList<>(); |
158 | - sumList.add(A2); | ||
159 | - sumList.add(B2); | ||
160 | - sumList.add(A3); | ||
161 | - | ||
162 | - try{ | ||
163 | - B2.setFormula(new Sum(sumList)); | ||
164 | - } | ||
165 | - catch(CreateCycleException ex){ | ||
166 | - throw ex; | ||
167 | - } | 145 | + sumList.add(A2); |
146 | + sumList.add(B2); | ||
147 | + sumList.add(A3); | ||
148 | + | ||
149 | + B2.setFormula(new Sum(sumList)); | ||
168 | } | 150 | } |
169 | 151 | ||
170 | - @org.junit.Test(expected=CreateCycleException.class) | ||
171 | - public void IndirectCycle() throws CreateCycleException, InvalidIntervalException { | ||
172 | - Cell A1= new Cell("A",1,25.); | ||
173 | - Cell A2= new Cell("A",2,5.); | ||
174 | - Cell B4= new Cell("B",4,new Addition(A1,A2)); | ||
175 | - Cell A4= new Cell("A",4,0.); | ||
176 | - Cell A3= new Cell("A",3,0.5); | ||
177 | - Cell B2= new Cell("B",2,12.); | 152 | + @Test(expected = CreateCycleException.class) |
153 | + public void IndirectCycle() throws CreateCycleException { | ||
154 | + Cell A1 = new Cell("A", 1, 25.); | ||
155 | + Cell A2 = new Cell("A", 2, 5.); | ||
156 | + Cell B4 = new Cell("B", 4, new Addition(A1, A2)); | ||
157 | + Cell A4 = new Cell("A", 4, 0.); | ||
158 | + Cell A3 = new Cell("A", 3, 0.5); | ||
159 | + Cell B2 = new Cell("B", 2, 12.); | ||
178 | 160 | ||
179 | List<Cell> sumList = new ArrayList<>(); | 161 | List<Cell> sumList = new ArrayList<>(); |
180 | - sumList.add(A2); | ||
181 | - sumList.add(B2); | ||
182 | - sumList.add(A3); | ||
183 | - Cell B6= new Cell("B",6,new Sum(sumList)); | ||
184 | - | 162 | + sumList.add(A2); |
163 | + sumList.add(B2); | ||
164 | + sumList.add(A3); | ||
165 | + Cell B6 = new Cell("B", 6, new Sum(sumList)); | ||
166 | + | ||
185 | List<Cell> averageList = new ArrayList<>(); | 167 | List<Cell> averageList = new ArrayList<>(); |
186 | averageList.add(B6); | 168 | averageList.add(B6); |
187 | averageList.add(B4); | 169 | averageList.add(B4); |
188 | averageList.add(A4); | 170 | averageList.add(A4); |
189 | - Cell C6= new Cell("C",6,new Average(averageList)); | ||
190 | - | ||
191 | - try{ | ||
192 | - B2.setFormula(new Addition(A1,C6)); | ||
193 | - } | ||
194 | - catch(CreateCycleException ex){ | ||
195 | - throw ex; | ||
196 | - } | 171 | + Cell C6 = new Cell("C", 6, new Average(averageList)); |
172 | + | ||
173 | + B2.setFormula(new Addition(A1, C6)); | ||
197 | } | 174 | } |
198 | - | ||
199 | - | ||
200 | } | 175 | } |
src/kernel/test/FunctionTest.java
@@ -3,7 +3,7 @@ package kernel.test; | @@ -3,7 +3,7 @@ package kernel.test; | ||
3 | import kernel.Cell; | 3 | import kernel.Cell; |
4 | import kernel.Grid; | 4 | import kernel.Grid; |
5 | import kernel.LanguageEnum; | 5 | import kernel.LanguageEnum; |
6 | -import kernel.exception.InvalidIntervalException; | 6 | +import kernel.function.Average; |
7 | import kernel.function.Sum; | 7 | import kernel.function.Sum; |
8 | import org.junit.Before; | 8 | import org.junit.Before; |
9 | import org.junit.Test; | 9 | import org.junit.Test; |
@@ -11,12 +11,15 @@ import org.junit.Test; | @@ -11,12 +11,15 @@ import org.junit.Test; | ||
11 | import java.util.ArrayList; | 11 | import java.util.ArrayList; |
12 | import java.util.List; | 12 | import java.util.List; |
13 | 13 | ||
14 | +import static org.junit.Assert.assertEquals; | ||
15 | +import static org.junit.Assert.assertNotNull; | ||
16 | + | ||
14 | public class FunctionTest { | 17 | public class FunctionTest { |
15 | 18 | ||
16 | private List<Cell> cells; | 19 | private List<Cell> cells; |
17 | 20 | ||
18 | @Before | 21 | @Before |
19 | - public void initData() throws InvalidIntervalException { | 22 | + public void initData() { |
20 | Grid.language = LanguageEnum.EN; | 23 | Grid.language = LanguageEnum.EN; |
21 | this.cells = new ArrayList<>(); | 24 | this.cells = new ArrayList<>(); |
22 | 25 | ||
@@ -32,5 +35,18 @@ public class FunctionTest { | @@ -32,5 +35,18 @@ public class FunctionTest { | ||
32 | @Test | 35 | @Test |
33 | public void testSum() { | 36 | public void testSum() { |
34 | Sum sum = new Sum(this.cells); | 37 | Sum sum = new Sum(this.cells); |
38 | + | ||
39 | + assertNotNull(sum); | ||
40 | + assertEquals(30, sum.eval(), 0); | ||
41 | + assertEquals("SUM(A1,A2,A3)", sum.toString()); | ||
42 | + } | ||
43 | + | ||
44 | + @Test | ||
45 | + public void testAverage() { | ||
46 | + Average average = new Average(this.cells); | ||
47 | + | ||
48 | + assertNotNull(average); | ||
49 | + assertEquals(10, average.eval(), 0); | ||
50 | + assertEquals("AVERAGE(A1,A2,A3)", average.toString()); | ||
35 | } | 51 | } |
36 | } | 52 | } |
src/kernel/test/GridTest.java
@@ -3,6 +3,7 @@ package kernel.test; | @@ -3,6 +3,7 @@ package kernel.test; | ||
3 | import kernel.Cell; | 3 | import kernel.Cell; |
4 | import kernel.Grid; | 4 | import kernel.Grid; |
5 | import kernel.LanguageEnum; | 5 | import kernel.LanguageEnum; |
6 | +import kernel.exception.CannotDeleteCellException; | ||
6 | import kernel.exception.CellNotFoundException; | 7 | import kernel.exception.CellNotFoundException; |
7 | import kernel.exception.CreateCycleException; | 8 | import kernel.exception.CreateCycleException; |
8 | import kernel.exception.InvalidIntervalException; | 9 | import kernel.exception.InvalidIntervalException; |
@@ -13,6 +14,7 @@ import kernel.operation.Multiplication; | @@ -13,6 +14,7 @@ import kernel.operation.Multiplication; | ||
13 | import org.junit.Before; | 14 | import org.junit.Before; |
14 | import org.junit.Test; | 15 | import org.junit.Test; |
15 | 16 | ||
17 | +import java.io.IOException; | ||
16 | import java.util.ArrayList; | 18 | import java.util.ArrayList; |
17 | import java.util.List; | 19 | import java.util.List; |
18 | 20 | ||
@@ -56,6 +58,13 @@ public class GridTest { | @@ -56,6 +58,13 @@ public class GridTest { | ||
56 | this.grid.createCell("AZ", 120, 0.); | 58 | this.grid.createCell("AZ", 120, 0.); |
57 | } | 59 | } |
58 | 60 | ||
61 | + @Test(expected = CellNotFoundException.class) | ||
62 | + public void testGetUnknownCell() throws CellNotFoundException, InvalidIntervalException { | ||
63 | + this.createCellsWithValue(); | ||
64 | + | ||
65 | + this.grid.getCell("B", 5); | ||
66 | + } | ||
67 | + | ||
59 | @Test | 68 | @Test |
60 | public void testGetValue() throws CellNotFoundException, CreateCycleException, InvalidIntervalException { | 69 | public void testGetValue() throws CellNotFoundException, CreateCycleException, InvalidIntervalException { |
61 | this.createCellsWithFormula(); | 70 | this.createCellsWithFormula(); |
@@ -199,6 +208,52 @@ public class GridTest { | @@ -199,6 +208,52 @@ public class GridTest { | ||
199 | assertEquals(3, this.grid.getCells().size()); | 208 | assertEquals(3, this.grid.getCells().size()); |
200 | } | 209 | } |
201 | 210 | ||
211 | + @Test | ||
212 | + public void testSave() throws InvalidIntervalException, IOException, CellNotFoundException, ClassNotFoundException, | ||
213 | + CreateCycleException { | ||
214 | + this.createCellsWithFormula(); | ||
215 | + | ||
216 | + this.grid.save(); | ||
217 | + | ||
218 | + Grid g = Grid.load(); | ||
219 | + | ||
220 | + Cell cell = g.getCell("A", 1); | ||
221 | + | ||
222 | + assertEquals("A1", cell.getId()); | ||
223 | + assertEquals(10, cell.getValue(), 0); | ||
224 | + | ||
225 | + cell = g.getCell("B", 1); | ||
226 | + | ||
227 | + assertEquals("B1", cell.getId()); | ||
228 | + assertTrue(cell.containFormula()); | ||
229 | + assertEquals(10, cell.getValue(), 0); | ||
230 | + } | ||
231 | + | ||
232 | + @Test | ||
233 | + public void testDeleteCell() throws CannotDeleteCellException, InvalidIntervalException { | ||
234 | + this.createCellsWithValue(); | ||
235 | + | ||
236 | + Cell cell = this.grid.getCell("A2"); | ||
237 | + | ||
238 | + assertNotNull(cell); | ||
239 | + assertEquals(0, cell.getValue(), 0); | ||
240 | + assertFalse(cell.containFormula()); | ||
241 | + | ||
242 | + this.grid.deleteCell("A", 2); | ||
243 | + | ||
244 | + cell = this.grid.getCell("A2"); | ||
245 | + | ||
246 | + assertNull(cell); | ||
247 | + } | ||
248 | + | ||
249 | + @Test(expected = CannotDeleteCellException.class) | ||
250 | + public void testDeleteCellUsedInAnother() throws CannotDeleteCellException, InvalidIntervalException, | ||
251 | + CellNotFoundException, CreateCycleException { | ||
252 | + this.createCellsWithFormula(); | ||
253 | + | ||
254 | + this.grid.deleteCell("A", 1); | ||
255 | + } | ||
256 | + | ||
202 | private void createCellsWithValue() throws InvalidIntervalException { | 257 | private void createCellsWithValue() throws InvalidIntervalException { |
203 | this.grid.createCell("A", 1, 10.); | 258 | this.grid.createCell("A", 1, 10.); |
204 | this.grid.createCell("A", 2, 0.); | 259 | this.grid.createCell("A", 2, 0.); |