annotate commons/core/tree/test/Test_Tree.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 import unittest
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
2 import os
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
3 import time
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
4 from commons.core.tree.Tree import Tree
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
5 from commons.core.utils.FileUtils import FileUtils
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
6
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
7
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
8 class Test_Tree( unittest.TestCase ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
9
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
10 def setUp( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
11 self._tree = Tree()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
12 self._uniqId = "%s_%s" % ( time.strftime("%Y%m%d%H%M%S") , os.getpid() )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
13
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
14
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
15 def test_parseTree_oneLeaf( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
16 inString = "seq1:0.0023"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
17 obs = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
18 exp = { "left":None, "right":None, "name":"seq1", "length":0.0023 }
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
19 self.assertEqual( obs, exp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
20
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
21
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
22 def test_parseTree_twoLeaves( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
23 inString = "(seq1:0.0023,seq2:0.0017)"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
24 obs = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
25 exp = {'length':0, 'right':{'length':0.0016999999999999999, 'right':None, 'name':'seq2', 'left':None}, 'name':'internal', 'left':{'length':0.0023, 'right':None, 'name':'seq1', 'left':None}}
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
26 self.assertEqual( obs, exp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
27
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
28 ## def test_parseTree_threeLeaves( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
29 ## inString = "(seq1:0.0023,(seq2:0.0017,seq3:0.0009))"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
30 ## obs = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
31 ## print obs
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
32 ## exp = {'length':0, 'right':{'length':0.0016999999999999999, 'right':None, 'name':'seq2', 'left':None}, 'name':'internal', 'left':{'length':0.0023, 'right':None, 'name':'seq1', 'left':None}}
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
33 ## self.assertEqual( obs, exp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
34
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
35
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
36 def test_parseSubTree( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
37 inString = "(seq1:0.0023,seq2:0.0017)"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
38 lExp = [ "seq1:0.0023", "seq2:0.0017" ]
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
39 lObs = self._tree.parseSubTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
40 self.assertEqual( lObs, lExp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
41
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
42
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
43 def test_saveTree( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
44 inFileName = "dummyInFile_%s" % ( self._uniqId )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
45 inF = open( inFileName, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
46 inF.write( "(seq4:0.012511,(seq3:0.005340,seq2:0.002201))" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
47 inF.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
48 self._tree = Tree( inFileName )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
49 obsFileName = "dummyObsFile_%s" % ( self._uniqId )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
50 self._tree.saveTree( obsFileName )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
51 self.assertTrue( FileUtils.are2FilesIdentical( obsFileName, inFileName ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
52 for f in [ inFileName, obsFileName ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
53 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
54
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
55
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
56 def test_retrieveInitialSequenceHeaders( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
57 inString = "(seq4:0.012511,(seq3:0.005340,seq2:0.002201))"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
58 self._tree.tree = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
59 dNew2Init = { "seq2":"consensus524::215 dmel_chr4 142..765", "seq3":"DmelChr4-B-G387-MAP16", "seq4":"1360|1cl-3gr" }
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
60 expFileName = "dummyExpFile_%s" % ( self._uniqId )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
61 expF = open( expFileName, "w" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
62 expF.write( "(1360|1cl-3gr:0.012511,(DmelChr4-B-G387-MAP16:0.005340,consensus524-215_dmel_chr4_142..765:0.002201))" )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
63 expF.close()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
64 obsFileName = "dummyObsFile_%s" % ( self._uniqId )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
65 self._tree.retrieveInitialSequenceHeaders( dNew2Init, obsFileName )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
66 self.assertTrue( FileUtils.are2FilesIdentical( obsFileName, expFileName ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
67 for f in [ expFileName, obsFileName ]:
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
68 os.remove( f )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
69
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
70
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
71 def test_getNbOfLeaves( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
72 inString = "(seq4:0.012511,(seq3:0.005340,seq2:0.002201))"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
73 self._tree.tree = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
74 exp = 3
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
75 obs = self._tree.getNbOfLeaves()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
76 self.assertEqual( obs, exp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
77
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
78
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
79 def test_getNbOfNodes( self ):
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
80 inString = "(seq4:0.012511,(seq3:0.005340,seq2:0.002201))"
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
81 self._tree.tree = self._tree.parseTree( inString )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
82 exp = 4
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
83 obs = self._tree.getNbOfNodes()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
84 self.assertEqual( obs, exp )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
85
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
86
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
87 test_suite = unittest.TestSuite()
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
88 test_suite.addTest( unittest.makeSuite( Test_Tree ) )
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
89 if __name__ == "__main__":
769e306b7933 Change the repository level.
yufei-luo
parents:
diff changeset
90 unittest.TextTestRunner(verbosity=2).run( test_suite )