annotate commons/core/coord/test/Test_MapUtils.py @ 6:769e306b7933

Change the repository level.
author yufei-luo
date Fri, 18 Jan 2013 04:54:14 -0500
parents
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 import os
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
34 import sys
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
35 from commons.core.coord.MapUtils import MapUtils
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
36 from commons.core.coord.Map import Map
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
37 from commons.core.coord.Set import Set
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
38 from commons.core.utils.FileUtils import FileUtils
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
39
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
40
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
41 class Test_MapUtils( unittest.TestCase ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
42
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
43 def test_getMapListSortedByIncreasingMinThenMax( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
44 iMap1 = Map("name1", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
45 iMap2 = Map("name2", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
46 iMap3 = Map("name3", "chr1", 50, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
47 iMap4 = Map("name4", "chr1", 5, 450)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
48 lMaps = [ iMap1, iMap2, iMap3, iMap4 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
49
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
50 expLMaps = [ iMap2, iMap1, iMap4, iMap3 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
51
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
52 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
53
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
54 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
55
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
56
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
57 def test_getMapListSortedByIncreasingMinThenMax_ordered( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
58 iMap1 = Map("name1", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
59 iMap2 = Map("name2", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
60
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
61 lMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
62 expLMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
63
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
64 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
65
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
66 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
67
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
68
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
69 def test_getMapListSortedByIncreasingMinThenMax_unordered( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
70 iMap1 = Map("name1", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
71 iMap2 = Map("name2", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
72
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
73 lMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
74 expLMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
75
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
76 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
77
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
78 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
79
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
80
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
81 def test_getMapListSortedByIncreasingMinThenMax_nonOverlapping( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
82 iMap1 = Map("name1", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
83 iMap2 = Map("name2", "chr1", 400, 600)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
84
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
85 lMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
86 expLMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
87
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
88 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
89
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
90 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
91
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
92
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
93 def test_getMapListSortedByIncreasingMinThenMax_sameMinThreeMaps( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
94 iMap1 = Map("name1", "chr1", 350, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
95 iMap2 = Map("name2", "chr1", 400, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
96 iMap3 = Map("name3", "chr1", 500, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
97
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
98 lMaps = [ iMap2, iMap1, iMap3 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
99 expLMaps = [ iMap1, iMap2, iMap3 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
100
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
101 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
102
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
103 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
104
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
105
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
106 def test_getMapListSortedByIncreasingMinThenMax_included( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
107 iMap1 = Map("name1", "chr1", 350, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
108 iMap2 = Map("name2", "chr1", 300, 10)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
109
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
110 lMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
111 expLMaps = [ iMap1, iMap2]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
112
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
113 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
114
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
115 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
116
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
117
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
118 def test_getMapListSortedByIncreasingMinThenMax_equal( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
119 iMap1 = Map("name1", "chr1", 350, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
120 iMap2 = Map("name2", "chr1", 350, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
121
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
122 lMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
123 expLMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
124 notExpLMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
125
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
126 obsLMaps = MapUtils.getMapListSortedByIncreasingMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
127
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
128 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
129 self.assertNotEquals( notExpLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
130
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
131
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
132 def test_getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
133 iMap1 = Map("name1", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
134 iMap2 = Map("name4", "chr2", 5, 450)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
135 iMap3 = Map("name4", "chr1", 10, 450)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
136 iMap4 = Map("name4", "chr1", 10, 500)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
137 iMap5 = Map("name4", "chr1", 5, 450)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
138 iMap6 = Map("name3", "chr1", 50, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
139 iMap7 = Map("name2", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
140
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
141 lMaps = [ iMap1, iMap2, iMap3, iMap4, iMap5, iMap6, iMap7 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
142
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
143 expLMaps = [ iMap1, iMap7, iMap6, iMap5, iMap3, iMap4, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
144
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
145 obsLMaps = MapUtils.getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
146
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
147 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
148
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
149
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
150 def test_getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax_ordered( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
151 iMap1 = Map("name1", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
152 iMap2 = Map("name1", "chr2", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
153
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
154 lMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
155 expLMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
156
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
157 obsLMaps = MapUtils.getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
158
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
159 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
160
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
161
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
162 def test_getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax_unordered( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
163 iMap1 = Map("name1", "chr2", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
164 iMap2 = Map("name1", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
165
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
166 lMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
167 expLMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
168
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
169 obsLMaps = MapUtils.getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
170
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
171 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
172
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
173
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
174 def test_getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax_nonOverlapping( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
175 iMap1 = Map("name1", "chr1", 1, 350)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
176 iMap2 = Map("name2", "chr1", 400, 600)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
177
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
178 lMaps = [ iMap2, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
179 expLMaps = [ iMap1, iMap2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
180
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
181 obsLMaps = MapUtils.getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
182
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
183 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
184
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
185
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
186 def test_getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax_sameMinThreeMaps( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
187 iMap1 = Map("name2", "chr1", 150, 10)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
188 iMap2 = Map("name2", "chr1", 1, 100)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
189 iMap3 = Map("name2", "chr1", 100, 1)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
190
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
191 lMaps = [ iMap1, iMap2, iMap3 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
192 expLMaps = [ iMap2, iMap3, iMap1 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
193
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
194 obsLMaps = MapUtils.getMapListSortedByIncreasingNameThenSeqnameThenMinThenMax( lMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
195
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
196 self.assertEquals( expLMaps, obsLMaps )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
197
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
198
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
199 def test_getDictPerNameFromMapFile( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
200 iMap1 = Map( "chunk1", "chromosome1", 1, 100 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
201 iMap2 = Map( "chunk2", "chromosome1", 91, 190 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
202 iMap3 = Map( "chunk3", "chromosome2", 1, 100 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
203 iMap4 = Map( "chunk1", "chromosome1", 1, 100 ) # redundant with iMap1
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
204
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
205 mapFile = "dummyFile.map"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
206 mapFileHandler = open( mapFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
207 for iMap in [ iMap1, iMap2, iMap3, iMap4 ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
208 iMap.write( mapFileHandler )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
209 mapFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
210
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
211 dExp = { "chunk1": iMap1, "chunk2": iMap2, "chunk3": iMap3 }
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
212
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
213 dObs = MapUtils.getDictPerNameFromMapFile( mapFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
214
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
215 self.assertEquals( dExp, dObs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
216
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
217 os.remove( mapFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
218
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
219
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
220 def test_mapList2SetList(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
221 map1 = Map( "name1", "desc1", 1, 120 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
222 map2 = Map( "name2", "desc2", 1, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
223 lMap = [ map1, map2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
224 set1 = Set( 1, "name1", "desc1", 1, 120 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
225 set2 = Set( 2, "name2", "desc2", 1, 20 )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
226 explMapSet = [ set1, set2 ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
227 obslMapSet = MapUtils.mapList2SetList( lMap )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
228
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
229 self.assertEquals( explMapSet, obslMapSet )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
230
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
231
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
232 def test_mergeCoordsInFile( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
233 if sys.modules.has_key( "commons.core.checker.CheckerUtils" ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
234 inFile = "dummyInFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
235 inFileHandler = open( inFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
236 inFileHandler.write( "TE1\tchr1\t1501\t2500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
237 inFileHandler.write( "TE3\tchr1\t4000\t3401\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
238 inFileHandler.write( "TE3\tchr1\t3800\t3601\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
239 inFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
240 expFile = "dummyExpFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
241 expFileHandler = open( expFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
242 expFileHandler.write( "TE1\tchr1\t1501\t2500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
243 expFileHandler.write( "TE3\tchr1\t4000\t3401\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
244 expFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
245 obsFile = "dummyObsFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
246 MapUtils.mergeCoordsInFile( inFile, obsFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
247 self.assertTrue( FileUtils.are2FilesIdentical( expFile, obsFile ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
248 for f in [ inFile, expFile, obsFile ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
249 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
250
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
251
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
252 def test_getDictPerSeqNameFromMapFile( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
253 inFile = "dummyInFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
254 inFileHandler = open( inFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
255 inFileHandler.write( "TE1\tchr1\t1\t10\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
256 inFileHandler.write( "TE2\tchr1\t60\t41\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
257 inFileHandler.write( "TE3\tchr2\t5\t36\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
258 inFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
259 dExp = { "chr1": [ Map( "TE1", "chr1", 1, 10 ), Map( "TE2", "chr1", 60, 41 ) ],
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
260 "chr2": [ Map( "TE3", "chr2", 5, 36 ) ] }
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
261 dObs = MapUtils.getDictPerSeqNameFromMapFile( inFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
262 self.assertEqual( dExp, dObs )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
263 os.remove( inFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
264
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
265 def test_convertMapFileIntoSetFile(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
266 mapInputFile = "dummyExpFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
267 mapFileHandler = open( mapInputFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
268 mapFileHandler.write( "seq31\tchr1\t151\t250\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
269 mapFileHandler.write( "seq27\tchr2\t301\t500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
270 mapFileHandler.write( "seq40\tchr2\t600\t700\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
271 mapFileHandler.write( "seq2\tchr3\t301\t500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
272 mapFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
273
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
274 expSetFile = "dummyexpSetFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
275 expSetFileHandler = open( expSetFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
276 expSetFileHandler.write( "1\tseq31\tchr1\t151\t250\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
277 expSetFileHandler.write( "2\tseq27\tchr2\t301\t500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
278 expSetFileHandler.write( "3\tseq40\tchr2\t600\t700\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
279 expSetFileHandler.write( "4\tseq2\tchr3\t301\t500\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
280 expSetFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
281
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
282 obsFile = "dummyObsFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
283
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
284 MapUtils.convertMapFileIntoSetFile( mapInputFile, obsFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
285
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
286 self.assertTrue( FileUtils.are2FilesIdentical( expSetFile, obsFile ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
287
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
288 for f in [ expSetFile, mapInputFile, obsFile ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
289 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
290
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
291 def test_convertMapFileIntoSetFile_one_line(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
292 mapInputFile = "dummyExpFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
293 mapFileHandler = open( mapInputFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
294 mapFileHandler.write( "seq31\tchr1\t151\t250\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
295 mapFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
296
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
297 expSetFile = "dummyexpSetFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
298 expSetFileHandler = open( expSetFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
299 expSetFileHandler.write( "1\tseq31\tchr1\t151\t250\n" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
300 expSetFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
301
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
302 obsFile = "dummyObsFile"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
303
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
304 MapUtils.convertMapFileIntoSetFile( mapInputFile, obsFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
305
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
306 self.assertTrue( FileUtils.are2FilesIdentical( expSetFile, obsFile ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
307
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
308 for f in [ expSetFile, mapInputFile, obsFile ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
309 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
310
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
311 def test_convertMapFileIntoSetFile_empty_file(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
312 mapInputFile = "dummyFile.map"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
313 mapFileHandler = open( mapInputFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
314 mapFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
315
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
316 expFile = "dummyExpFile.map.set"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
317 expFileHandler = open( expFile, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
318 expFileHandler.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
319
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
320 obsFile = "dummyFile.map.set"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
321
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
322 MapUtils.convertMapFileIntoSetFile( mapInputFile )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
323
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
324 self.assertTrue( FileUtils.are2FilesIdentical( expFile, obsFile ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
325
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
326 for f in [ expFile, mapInputFile, obsFile ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
327 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
328
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
329 def test_writeListInFile_empty_list(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
330 lMaps = [ ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
331 expFileName = "expFileName"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
332 fileHandle = open(expFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
333 fileHandle.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
334
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
335 obsFileName = "obsFileName"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
336 fileHandle = open(obsFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
337 MapUtils.writeListInFile(lMaps, obsFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
338 fileHandle.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
339
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
340 self.assertTrue( FileUtils.are2FilesIdentical( expFileName, obsFileName ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
341
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
342 os.remove(obsFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
343 os.remove(expFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
344
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
345 def test_writeListInFile_list_one_set(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
346 lMaps = [ Map( "map1", "map1seq", 1, 10 ) ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
347 line = "map1\tmap1seq\t1\t10\n"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
348
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
349 expFileName = "expFileName"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
350
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
351 fileHandle = open(expFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
352 fileHandle.write(line)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
353 fileHandle.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
354
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
355 obsFileName = "obsFileName"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
356 fileHandle = open(obsFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
357 MapUtils.writeListInFile(lMaps, obsFileName, "w")
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
358 fileHandle.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
359
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
360 self.assertTrue( FileUtils.are2FilesIdentical( expFileName, obsFileName ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
361
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
362 os.remove(obsFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
363 os.remove(expFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
364
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
365 def test_getMinLengthOfMapFile(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
366 mapFileName = "%s/Gnome_tools/Vein_v4_scaffold_00001.fa.Nstretch.map" % os.environ["REPET_DATA"]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
367 expMinLengthofMapFile = 20
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
368 iMap = MapUtils()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
369 obsMinLengthofMapFile = iMap.getMinLengthOfMapFile(mapFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
370 self.assertEquals(expMinLengthofMapFile, obsMinLengthofMapFile)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
371
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
372 def test_getMaxLengthOfMapFile(self):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
373 mapFileName = "%s/Gnome_tools/Vein_v4_scaffold_00001.fa.Nstretch.map" % os.environ["REPET_DATA"]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
374 expMinLengthofMapFile = 6344
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
375 iMap = MapUtils()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
376 obsMinLengthofMapFile = iMap.getMaxLengthOfMapFile(mapFileName)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
377 self.assertEquals(expMinLengthofMapFile, obsMinLengthofMapFile)
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
378
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
379
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
380
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
381 test_suite = unittest.TestSuite()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
382 test_suite.addTest( unittest.makeSuite( Test_MapUtils ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
383 if __name__ == "__main__":
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
384 unittest.TextTestRunner(verbosity=2).run( test_suite )