JAL-2759 HiddenColumnsCursor tests
[jalview.git] / test / jalview / datamodel / HiddenColumnsCursorTest.java
1 /*
2  * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3  * Copyright (C) $$Year-Rel$$ The Jalview Authors
4  * 
5  * This file is part of Jalview.
6  * 
7  * Jalview is free software: you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License 
9  * as published by the Free Software Foundation, either version 3
10  * of the License, or (at your option) any later version.
11  *  
12  * Jalview is distributed in the hope that it will be useful, but 
13  * WITHOUT ANY WARRANTY; without even the implied warranty 
14  * of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
15  * PURPOSE.  See the GNU General Public License for more details.
16  * 
17  * You should have received a copy of the GNU General Public License
18  * along with Jalview.  If not, see <http://www.gnu.org/licenses/>.
19  * The Jalview Authors are detailed in the 'AUTHORS' file.
20  */
21 package jalview.datamodel;
22
23 import static org.testng.AssertJUnit.assertEquals;
24
25 import java.util.ArrayList;
26 import java.util.List;
27
28 import org.testng.annotations.Test;
29
30 public class HiddenColumnsCursorTest
31 {
32   /**
33    * Test the method which finds the corresponding region given a column
34    */
35   @Test(groups = { "Functional" })
36   public void testFindRegionForColumn()
37   {
38     HiddenColumnsCursor cursor = new HiddenColumnsCursor();
39     
40     int regionIndex = cursor.findRegionForColumn(20);
41     assertEquals(-1, regionIndex);
42     
43     List<int[]> hidden = new ArrayList<>();
44     hidden.add(new int[] { 53, 76 });
45     hidden.add(new int[] { 104, 125 });
46     cursor.resetCursor(hidden);
47
48     regionIndex = cursor.findRegionForColumn(126);
49     assertEquals(2, regionIndex);
50
51     regionIndex = cursor.findRegionForColumn(125);
52     assertEquals(1, regionIndex);
53
54     regionIndex = cursor.findRegionForColumn(108);
55     assertEquals(1, regionIndex);
56
57     regionIndex = cursor.findRegionForColumn(104);
58     assertEquals(1, regionIndex);
59
60     regionIndex = cursor.findRegionForColumn(103);
61     assertEquals(1, regionIndex);
62
63     regionIndex = cursor.findRegionForColumn(77);
64     assertEquals(1, regionIndex);
65
66     regionIndex = cursor.findRegionForColumn(76);
67     assertEquals(0, regionIndex);
68
69     regionIndex = cursor.findRegionForColumn(53);
70     assertEquals(0, regionIndex);
71
72     regionIndex = cursor.findRegionForColumn(52);
73     assertEquals(0, regionIndex);
74
75     regionIndex = cursor.findRegionForColumn(0);
76     assertEquals(0, regionIndex);
77   }
78
79   /**
80    * Test the method which counts the number of hidden columns before a column
81    */
82   @Test(groups = { "Functional" })
83   public void testGetHiddenOffset()
84   {
85     HiddenColumnsCursor cursor = new HiddenColumnsCursor();
86
87     int offset = cursor.getHiddenOffset(20);
88     assertEquals(-1, offset);
89
90     List<int[]> hidden = new ArrayList<>();
91     hidden.add(new int[] { 53, 76 });
92     hidden.add(new int[] { 104, 125 });
93     cursor.resetCursor(hidden);
94
95     offset = cursor.getHiddenOffset(80);
96     assertEquals(46, offset);
97
98     offset = cursor.getHiddenOffset(79);
99     assertEquals(24, offset);
100
101     offset = cursor.getHiddenOffset(53);
102     assertEquals(24, offset);
103
104     offset = cursor.getHiddenOffset(52);
105     assertEquals(0, offset);
106
107     offset = cursor.getHiddenOffset(10);
108     assertEquals(0, offset);
109
110     offset = cursor.getHiddenOffset(0);
111     assertEquals(0, offset);
112   }
113
114 }