2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
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.
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.
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.
21 package jalview.datamodel;
23 import static org.testng.AssertJUnit.assertEquals;
25 import java.util.ArrayList;
26 import java.util.List;
28 import org.testng.annotations.Test;
30 public class HiddenColumnsCursorTest
33 * Test the method which finds the corresponding region given a column
35 @Test(groups = { "Functional" })
36 public void testFindRegionForColumn()
38 HiddenColumnsCursor cursor = new HiddenColumnsCursor();
40 int regionIndex = cursor.findRegionForColumn(20);
41 assertEquals(-1, regionIndex);
43 List<int[]> hidden = new ArrayList<>();
44 hidden.add(new int[] { 53, 76 });
45 hidden.add(new int[] { 104, 125 });
46 cursor.resetCursor(hidden);
48 regionIndex = cursor.findRegionForColumn(126);
49 assertEquals(2, regionIndex);
51 regionIndex = cursor.findRegionForColumn(125);
52 assertEquals(1, regionIndex);
54 regionIndex = cursor.findRegionForColumn(108);
55 assertEquals(1, regionIndex);
57 regionIndex = cursor.findRegionForColumn(104);
58 assertEquals(1, regionIndex);
60 regionIndex = cursor.findRegionForColumn(103);
61 assertEquals(1, regionIndex);
63 regionIndex = cursor.findRegionForColumn(77);
64 assertEquals(1, regionIndex);
66 regionIndex = cursor.findRegionForColumn(76);
67 assertEquals(0, regionIndex);
69 regionIndex = cursor.findRegionForColumn(53);
70 assertEquals(0, regionIndex);
72 regionIndex = cursor.findRegionForColumn(52);
73 assertEquals(0, regionIndex);
75 regionIndex = cursor.findRegionForColumn(0);
76 assertEquals(0, regionIndex);
80 * Test the method which counts the number of hidden columns before a column
82 @Test(groups = { "Functional" })
83 public void testGetHiddenOffset()
85 HiddenColumnsCursor cursor = new HiddenColumnsCursor();
87 int offset = cursor.getHiddenOffset(20);
88 assertEquals(-1, offset);
90 List<int[]> hidden = new ArrayList<>();
91 hidden.add(new int[] { 53, 76 });
92 hidden.add(new int[] { 104, 125 });
93 cursor.resetCursor(hidden);
95 offset = cursor.getHiddenOffset(80);
96 assertEquals(46, offset);
98 offset = cursor.getHiddenOffset(79);
99 assertEquals(24, offset);
101 offset = cursor.getHiddenOffset(53);
102 assertEquals(24, offset);
104 offset = cursor.getHiddenOffset(52);
105 assertEquals(0, offset);
107 offset = cursor.getHiddenOffset(10);
108 assertEquals(0, offset);
110 offset = cursor.getHiddenOffset(0);
111 assertEquals(0, offset);