annotate commons/core/coord/test/Test_Range.py @ 18:94ab73e8a190

Uploaded
author m-zytnicki
date Mon, 29 Apr 2013 03:20:15 -0400
parents 769e306b7933
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
1 # Copyright INRA (Institut National de la Recherche Agronomique)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
2 # http://www.inra.fr
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
3 # http://urgi.versailles.inra.fr
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
4 #
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
5 # This software is governed by the CeCILL license under French law and
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
6 # abiding by the rules of distribution of free software. You can use,
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
7 # modify and/ or redistribute the software under the terms of the CeCILL
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
8 # license as circulated by CEA, CNRS and INRIA at the following URL
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
9 # "http://www.cecill.info".
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
10 #
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
11 # As a counterpart to the access to the source code and rights to copy,
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
12 # modify and redistribute granted by the license, users are provided only
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
13 # with a limited warranty and the software's author, the holder of the
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
14 # economic rights, and the successive licensors have only limited
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
15 # liability.
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
16 #
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
17 # In this respect, the user's attention is drawn to the risks associated
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
18 # with loading, using, modifying and/or developing or reproducing the
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
19 # software by the user in light of its specific status of free software,
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
20 # that may mean that it is complicated to manipulate, and that also
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
21 # therefore means that it is reserved for developers and experienced
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
22 # professionals having in-depth computer knowledge. Users are therefore
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
23 # encouraged to load and test the software's suitability as regards their
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
24 # requirements in conditions enabling the security of their systems and/or
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
25 # data to be ensured and, more generally, to use and operate it in the
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
26 # same conditions as regards security.
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
27 #
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
28 # The fact that you are presently reading this means that you have had
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
29 # knowledge of the CeCILL license and that you accept its terms.
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
30
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
31
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
32 import unittest
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
33 from commons.core.coord.Range import Range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
34 from commons.core.coord.Range import getBin, getIdx
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
35
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
36
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
37 class Test_Range( unittest.TestCase ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
38
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
39 def setUp(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
40 self._range = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
41
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
42 def test_setFromString(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
43 line = "chunk1\t190000\t390000"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
44 self._range.setFromString( line )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
45 self.assertEqual( self._range.seqname, "chunk1" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
46 self.assertEqual( self._range.start, 190000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
47 self.assertEqual( self._range.end, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
48
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
49 line = "chunk1\t190000\t390000\n"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
50 self._range.setFromString( line )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
51 self.assertEqual( self._range.seqname, "chunk1" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
52 self.assertEqual( self._range.start, 190000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
53 self.assertEqual( self._range.end, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
54
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
55 line = "chunk1;190000;390000"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
56 self._range.setFromString( line, ";" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
57 self.assertEqual( self._range.seqname, "chunk1" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
58 self.assertEqual( self._range.start, 190000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
59 self.assertEqual( self._range.end, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
60
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
61 def test_setFromTuple(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
62 tuple = ("chunk1","190000","390000")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
63 self._range.setFromTuple( tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
64
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
65 self.assertEqual( self._range.seqname, "chunk1" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
66 self.assertEqual( self._range.start, 190000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
67 self.assertEqual( self._range.end, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
68
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
69 def test___eq__(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
70 self._range.setFromString( "chunk1\t190000\t390000\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
71 o = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
72 o.setFromString( "chunk1\t190000\t390000\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
73 self.assertEqual( self._range, o )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
74
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
75 o.setFromString( "chunk1\t190000\t39" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
76 self.assertNotEquals( self._range, o )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
77
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
78 o.setFromString( "chromosome1\t190000\t390000" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
79 self.assertNotEquals( self._range, o )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
80
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
81 o.setFromString( "chunk1\t390000\t190000" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
82 self.assertNotEquals( self._range, o )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
83
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
84 o.setFromString( "chromosome1\t390000\t190000" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
85 self.assertNotEquals( self._range, o )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
86
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
87 def test_getMin(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
88 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
89 expMin = 190000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
90 obsMin = self._range.getMin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
91 self.assertTrue(expMin, obsMin)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
92
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
93 def test_getMax(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
94 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
95 expMax = 390000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
96 obsMax = self._range.getMax()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
97 self.assertTrue(expMax, obsMax)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
98
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
99 def test_isOnDirectStrand_true(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
100 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
101 self.assertTrue(self._range.isOnDirectStrand())
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
102
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
103 def test_isOnDirectStrand_false(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
104 self._range.setFromTuple( ("chunk1", 390000, 190000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
105 self.assertFalse(self._range.isOnDirectStrand())
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
106
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
107 def test_isOnReverseStrand_true(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
108 self._range.setFromTuple( ("chunk1", 390000, 190000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
109 self.assertTrue(self._range.isOnReverseStrand())
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
110
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
111 def test_isOnReverseStrand_false(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
112 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
113 self.assertFalse(self._range.isOnReverseStrand())
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
114
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
115 def test_getStrand_direct(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
116 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
117 expStrand = '+'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
118 obsStrand = self._range.getStrand()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
119 self.assertEqual(expStrand, obsStrand)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
120
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
121 def test_getStrand_reverse(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
122 self._range.setFromTuple( ("chunk1", 390000, 190000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
123 expStrand = '-'
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
124 obsStrand = self._range.getStrand()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
125 self.assertEqual(expStrand, obsStrand)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
126
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
127 def test_reverse(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
128 obsRange = Range("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
129 expRange = Range("chunk1", 390000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
130 obsRange.reverse()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
131 self.assertEquals(expRange, obsRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
132
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
133 def test_getLength(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
134 self._range.setFromTuple( ("chunk1", 190000, 390000) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
135 expLength = 200001
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
136 obsLength = self._range.getLength()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
137 self.assertEquals(expLength, obsLength)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
138
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
139 def test_isEmpty_true( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
140 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
141 obs = self._range.isEmpty()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
142 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
143
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
144 def test_isEmpty_false( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
145 self._range.setFromTuple( ( "seq1", 1, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
146 exp = False
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
147 obs = self._range.isEmpty()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
148 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
149
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
150 def test_merge_diff_sequences( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
151 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
152 range2 = Range( "seq2", 6, 12 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
153 expReturn = None
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
154 expRange = Range( "seq1", 6, 10 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
155 obsReturn = self._range.merge( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
156 obsRange = self._range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
157 self.assertEquals( expReturn, obsReturn )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
158 self.assertEquals( expRange, obsRange )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
159
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
160 def test_merge_no_overlapping_ranges( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
161 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
162 range2 = Range( "seq1", 12, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
163 expReturn = None
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
164 expRange = Range( "seq1", 6, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
165 obsReturn = self._range.merge( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
166 obsRange = self._range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
167 self.assertEquals( expReturn, obsReturn )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
168 self.assertEquals( expRange, obsRange )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
169
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
170 def test_merge_no_overlapping_ranges_range1_on_neg_strand( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
171 self._range.setFromTuple( ( "seq1", 10, 6 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
172 range2 = Range( "seq1", 12, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
173 expReturn = None
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
174 expRange = Range( "seq1", 20, 6 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
175 obsReturn = self._range.merge( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
176 obsRange = self._range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
177 self.assertEquals( expReturn, obsReturn )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
178 self.assertEquals( expRange, obsRange )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
179
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
180 def test_merge_overlapping_ranges_range1_and_range2_on_neg_strand( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
181 self._range.setFromTuple( ( "seq1", 10, 6 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
182 range2 = Range( "seq1", 20, 12 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
183 expReturn = None
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
184 expRange = Range( "seq1", 20, 6 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
185 obsReturn = self._range.merge( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
186 obsRange = self._range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
187 self.assertEquals( expReturn, obsReturn )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
188 self.assertEquals( expRange, obsRange )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
189
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
190 def test_merge_on_overlapping_ranges_range1_and_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
191 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
192 range2 = Range( "seq1", 8, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
193 expReturn = None
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
194 expRange = Range( "seq1", 6, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
195 obsReturn = self._range.merge( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
196 obsRange = self._range
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
197 self.assertEquals( expReturn, obsReturn )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
198 self.assertEquals( expRange, obsRange )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
199
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
200 def test_isOverlapping_diff_sequences( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
201 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
202 r2 = Range( "seq2", 6, 10 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
203 exp = False
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
204 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
205 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
206
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
207 def test_isOverlapping_no( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
208 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
209 r2 = Range( "seq1", 16, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
210 exp = False
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
211 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
212 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
213
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
214 def test_isOverlapping_yes( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
215 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
216 r2 = Range( "seq1", 1, 15 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
217 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
218 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
219 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
220
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
221 def test_isOverlapping_yes_range2_on_neg_strand( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
222 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
223 r2 = Range( "seq1", 15, 1 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
224 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
225 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
226 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
227
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
228 def test_isOverlapping_range1_before_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
229 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
230 r2 = Range( "seq1", 8, 15 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
231 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
232 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
233 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
234
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
235 def test_isOverlapping_range1_after_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
236 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
237 r2 = Range( "seq1", 1, 8 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
238 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
239 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
240 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
241
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
242 def test_isOverlapping_range1_equal_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
243 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
244 r2 = Range( "seq1", 6, 10 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
245 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
246 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
247 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
248
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
249 def test_isOverlapping_yes_edges_left( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
250 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
251 r2 = Range( "seq1", 1, 6 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
252 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
253 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
254 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
255
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
256 def test_isOverlapping_yes_edges_right( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
257 self._range.setFromTuple( ( "seq1", 6, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
258 r2 = Range( "seq1", 10, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
259 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
260 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
261 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
262
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
263 def test_isOverlapping_yes_one_nt( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
264 self._range.setFromTuple( ( "seq1", 10, 10 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
265 r2 = Range( "seq1", 10, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
266 exp = True
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
267 obs = self._range.isOverlapping( r2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
268 self.assertEquals( exp, obs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
269
18
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
270 def test_isOverlapping_yes_span_1( self ):
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
271 self._range.setFromTuple( ( "seq1", 10, 100 ) )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
272 r2 = Range( "seq1", 5, 110 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
273 exp = True
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
274 obs = self._range.isOverlapping( r2 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
275 self.assertEquals( exp, obs )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
276
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
277 def test_isOverlapping_yes_span_2( self ):
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
278 self._range.setFromTuple( ( "seq1", 5, 110 ) )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
279 r2 = Range( "seq1", 10, 100 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
280 exp = True
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
281 obs = self._range.isOverlapping( r2 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
282 self.assertEquals( exp, obs )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
283
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
284 def test_isOverlapping_yes_include_1( self ):
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
285 self._range.setFromTuple( ( "seq1", 10, 100 ) )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
286 r2 = Range( "seq1", 15, 90 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
287 exp = True
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
288 obs = self._range.isOverlapping( r2 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
289 self.assertEquals( exp, obs )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
290
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
291 def test_isOverlapping_yes_include_2( self ):
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
292 self._range.setFromTuple( ( "seq1", 15, 90 ) )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
293 r2 = Range( "seq1", 10, 100 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
294 exp = True
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
295 obs = self._range.isOverlapping( r2 )
94ab73e8a190 Uploaded
m-zytnicki
parents: 6
diff changeset
296 self.assertEquals( exp, obs )
6
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
297
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
298 def test_getOverlapLength_on_different_range( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
299 range1 = Range( "chunk1", 190000, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
300 range2 = Range( "chunk2", 290000, 590000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
301 expSize = 0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
302 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
303 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
304
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
305
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
306 def test_getOverlapLength_on_no_overalping_range( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
307 range1 =Range( "chunk1", 190000, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
308 range2 =Range( "chunk1", 490000, 590000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
309 expSize = 0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
310 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
311 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
312
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
313
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
314 def test_getOverlapLength_range2_included_in_range1( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
315 range1 = Range( "chunk1", 19, 39 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
316 range2 = Range( "chunk1", 22, 25 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
317 expSize = 4
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
318 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
319 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
320 obsSize = range2.getOverlapLength( range1 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
321 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
322
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
323
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
324 def test_getOverlapLength_range1_included_in_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
325 range1 = Range( "chunk1", 220000, 250000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
326 range2 = Range( "chunk1", 190000, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
327 expSize = 30001
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
328 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
329 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
330
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
331
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
332 def test_getOverlapLength_range1_before_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
333 range1 = Range( "chunk1", 190000, 390000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
334 range2 = Range( "chunk1", 290000, 590000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
335 expSize = 100001
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
336 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
337 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
338
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
339
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
340 def test_getOverlapLength_range1_after_range2( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
341 range1 = Range( "chunk1", 390000, 790000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
342 range2 = Range( "chunk1", 290000, 590000 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
343 expSize = 200001
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
344 obsSize = range1.getOverlapLength( range2 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
345 self.assertEquals( expSize, obsSize )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
346
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
347
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
348 def test_isIncludedIn( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
349 iRange1 = Range( "chunk1", 21, 30 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
350 iRange2 = Range( "chunk1", 11, 40 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
351 self.assertTrue( iRange1.isIncludedIn( iRange2 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
352
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
353
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
354 def test_isIncludedIn_diffStrand( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
355 iRange1 = Range( "chunk1", 21, 30 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
356 iRange2 = Range( "chunk1", 40, 11 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
357 self.assertTrue( iRange1.isIncludedIn( iRange2 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
358
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
359
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
360 def test_isIncludedIn_onlyOverlap( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
361 iRange1 = Range( "chunk1", 21, 50 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
362 iRange2 = Range( "chunk1", 11, 40 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
363 self.assertFalse( iRange1.isIncludedIn( iRange2 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
364
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
365
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
366 def test_isIncludedIn_diffSeqname( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
367 iRange1 = Range( "chunk1", 21, 30 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
368 iRange2 = Range( "chunk2", 11, 40 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
369 self.assertFalse( iRange1.isIncludedIn( iRange2 ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
370
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
371
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
372 def test_getDistance_on_overlapping_range(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
373 overlapTuple1 = ("chunk1", 220000, 250000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
374 overlapRange1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
375 overlapRange1.setFromTuple(overlapTuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
376
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
377 overlapTuple2 = ("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
378 overlapRange2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
379 overlapRange2.setFromTuple(overlapTuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
380
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
381 expDistance = 0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
382 obsDistance = overlapRange1.getDistance(overlapRange2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
383
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
384 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
385
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
386 def test_getDistance_on_range1_on_plus_strand_included_in_range2_on_neg_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
387 tuple1 = ("chunk1", 220000, 250000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
388 range1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
389 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
390
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
391 tuple2 = ("chunk1", 390000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
392 range2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
393 range1.setFromTuple(tuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
394
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
395 expDistance = -1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
396 obsDistance = range1.getDistance(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
397
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
398 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
399
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
400 def test_getDistance_range1_after_range2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
401 tuple1 = ("chunk1", 390000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
402 range1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
403 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
404
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
405 tuple2 = ("chunk1", 190000, 290000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
406 range2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
407 range2.setFromTuple(tuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
408
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
409 expDistance = 100000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
410 obsDistance = range1.getDistance(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
411
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
412 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
413
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
414 def test_getDistance_range1_before_range2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
415 tuple1 = ("chunk1", 190000, 290000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
416 range1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
417 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
418
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
419 tuple2 = ("chunk1", 390000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
420 range2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
421 range2.setFromTuple(tuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
422
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
423 expDistance = 100000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
424 obsDistance = range1.getDistance(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
425
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
426 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
427
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
428 def test_getDistance_range1_after_range2_both_on_neg_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
429 tuple1 = ("chunk1", 590000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
430 range1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
431 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
432
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
433 tuple2 = ("chunk1", 290000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
434 range2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
435 range2.setFromTuple(tuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
436
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
437 expDistance = 100000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
438 obsDistance = range1.getDistance(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
439
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
440 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
441
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
442 def test_getDistance_range1_before_range2_both_on_neg_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
443 tuple1 = ("chunk1", 290000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
444 range1 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
445 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
446
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
447 tuple2 = ("chunk1", 590000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
448 range2 = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
449 range2.setFromTuple(tuple2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
450
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
451 expDistance = 100000
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
452 obsDistance = range1.getDistance(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
453
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
454 self.assertEquals(expDistance, obsDistance)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
455
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
456 def test_diff_on_no_overlapping_range(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
457 range1 = Range("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
458 range2 = Range("chunk1", 490000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
459
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
460 expRange1 = Range("chunk1",190000,390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
461 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
462
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
463 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
464 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
465
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
466 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
467 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
468
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
469 def test_diff_on_different_chunks(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
470 range1 = Range("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
471 range2 = Range("chunk2", 290000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
472
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
473 expRange1 = Range("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
474 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
475
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
476 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
477 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
478
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
479 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
480 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
481
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
482 def test_diff_range1_before_range2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
483 range1 = Range("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
484 range2 = Range("chunk1", 290000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
485
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
486 expRange1 = Range("chunk1", 190000, 289999)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
487 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
488
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
489 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
490 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
491
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
492 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
493 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
494
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
495 def test_diff_range1_before_range2_range1_on_neg_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
496 range1 = Range("chunk1", 390000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
497 range2 = Range("chunk1", 290000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
498
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
499 expRange1 = Range("chunk1", 289999, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
500 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
501
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
502 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
503 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
504
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
505 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
506 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
507
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
508 def test_diff_range2_included_in_range1(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
509 range1 = Range("chunk1", 190000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
510 range2 = Range("chunk1", 290000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
511
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
512 expRange1 = Range("chunk1", 190000, 289999)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
513 expReturnedRange = Range("chunk1", 390001, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
514
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
515 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
516 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
517
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
518 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
519 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
520
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
521 def test_diff_range2_included_in_range1_range1_on_reverse_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
522 range1 = Range("chunk1", 590000, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
523 range2 = Range("chunk1", 290000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
524
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
525 expRange1 = Range("chunk1", 289999, 190000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
526 expReturnedRange = Range("chunk1", 590000, 390001)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
527
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
528 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
529 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
530
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
531 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
532 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
533
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
534 def test_diff_range1_included_in_range2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
535 range1 = Range("chunk1", 390000, 490000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
536 range2 = Range("chunk1", 290000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
537
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
538 expRange1 = Range("chunk1",0,0)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
539 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
540
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
541 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
542 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
543
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
544 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
545 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
546
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
547 def test_diff_range1_after_range2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
548 range1 = Range("chunk1", 390000, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
549 range2 = Range("chunk1", 290000, 490000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
550
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
551 expRange1 = Range("chunk1", 490001, 590000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
552 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
553
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
554 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
555 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
556
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
557 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
558 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
559
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
560 def test_diff_range1_after_range2_range1_on_neg_strand(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
561 range1 = Range("chunk1", 590000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
562 range2 = Range("chunk1", 290000, 490000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
563
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
564 expRange1 = Range("chunk1", 590000, 490001)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
565 expReturnedRange = Range("chunk1")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
566
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
567 obsReturnedRange = range1.diff(range2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
568 obsRange1 = range1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
569
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
570 self.assertEquals(expRange1, obsRange1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
571 self.assertEquals(expReturnedRange, obsReturnedRange)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
572
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
573 def test_getIdx(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
574 self.assertEqual(getIdx(1000,3),1000001)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
575 self.assertEqual(getIdx(999,3),1000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
576 self.assertEqual(getIdx(2000,3),1000002)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
577 self.assertEqual(getIdx(2000,4),2000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
578 self.assertEqual(getIdx(2000,5),3000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
579 self.assertEqual(getIdx(20000000,6),4000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
580 self.assertEqual(getIdx(20000000,5),3000200)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
581 self.assertEqual(getIdx(20000000,4),2002000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
582 self.assertEqual(getIdx(20000000,3),1020000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
583
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
584 def test_getBin_bin_level_9(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
585 tuple1 = ("chunk1", 190000000, 390000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
586 range1 =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
587 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
588
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
589 expRes = 100000000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
590 obsRes = range1.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
591
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
592 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
593
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
594 def test_getBin_bin_level_8(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
595 tuple1 = ("chunk1", 19000000, 39000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
596 range1 =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
597 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
598
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
599 expRes = 100000000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
600 obsRes = range1.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
601
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
602 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
603
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
604 def test_getBin_bin_level_7(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
605 tuple1 = ("chunk1", 1900000, 3900000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
606 range1 =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
607 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
608
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
609 expRes = 10000000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
610 obsRes = range1.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
611
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
612 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
613
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
614 def test_getBin_bin_level_6(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
615 tuple1 = ("chunk1", 190000, 390000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
616 range1 =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
617 range1.setFromTuple(tuple1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
618
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
619 expRes = 1000000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
620 obsRes = range1.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
621
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
622 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
623
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
624 def test_getBin_bin_level_5(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
625 tuple = ("chunk1", 19000, 39000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
626 range =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
627 range.setFromTuple(tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
628 expRes = 100000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
629 obsRes = range.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
630
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
631 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
632
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
633 def test_getBin_bin_level_4(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
634 tuple = ("chunk1", 1900, 3900)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
635 range =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
636 range.setFromTuple(tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
637
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
638 expRes = 10000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
639 obsRes = range.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
640
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
641 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
642
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
643 def test_getBin_bin_level_3(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
644 tuple = ("chunk1", 190, 390)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
645 range =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
646 range.setFromTuple(tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
647
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
648 expRes = 1000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
649 obsRes = range.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
650
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
651 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
652
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
653 def test_getBin_bin_level_2(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
654 tuple = ("chunk1", 19, 39)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
655 range =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
656 range.setFromTuple(tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
657
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
658 expRes = 1000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
659 obsRes = range.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
660
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
661 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
662
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
663 def test_getBin_bin_level_1(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
664 tuple = ("chunk1", 1, 3)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
665 range =Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
666 range.setFromTuple(tuple)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
667
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
668 expRes = 1000.0
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
669 obsRes = range.getBin()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
670
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
671 self.assertEquals(expRes, obsRes)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
672
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
673
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
674 def test_getBin_function(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
675 expBin = 2L
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
676 obsBin = getBin(200, 2)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
677
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
678 self.assertEquals(expBin, obsBin)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
679
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
680 def test_findIdx(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
681 o = Range()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
682 o.setFromString( "chunk1\t1000\t2000\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
683 self.assertEqual(o.findIdx(),2000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
684
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
685 o.setFromString( "chunk1\t2000\t1000\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
686 self.assertEqual(o.findIdx(),2000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
687
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
688 o.setFromString( "chunk1\t200\t999\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
689 self.assertEqual(o.findIdx(),1000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
690
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
691 o.setFromString( "chunk1\t1\t20000000\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
692 self.assertEqual(o.findIdx(),4000000)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
693
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
694
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
695 test_suite = unittest.TestSuite()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
696 test_suite.addTest( unittest.makeSuite( Test_Range ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
697 if __name__ == "__main__":
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
698 unittest.TextTestRunner(verbosity=2).run( test_suite )