-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathcigarsTest.py
72 lines (57 loc) · 2.23 KB
/
cigarsTest.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#!/usr/bin/env python3
#Copyright (C) 2006-2012 by Benedict Paten ([email protected])
#
#Released under the MIT license, see LICENSE.txt
import unittest
import os
import sys
import random
from sonLib.bioio import getTempFile
from sonLib.bioio import cigarRead
from sonLib.bioio import cigarWrite
from sonLib.bioio import getRandomPairwiseAlignment
from sonLib.bioio import system
from sonLib.bioio import TestStatus
from sonLib.bioio import logger
class TestCase(unittest.TestCase):
def setUp(self):
self.testNo = TestStatus.getTestSetup()
self.tempFiles = []
unittest.TestCase.setUp(self)
def tearDown(self):
for tempFile in self.tempFiles:
os.remove(tempFile)
unittest.TestCase.tearDown(self)
def testCigarReadWrite(self):
"""Tests the C code for reading and writing cigars against the python parser for cigars.
"""
tempFile = getTempFile()
self.tempFiles.append(tempFile)
for test in range(0, self.testNo):
pairwiseAlignmentNumber = random.choice(range(10))
l = [ getRandomPairwiseAlignment() for i in range(pairwiseAlignmentNumber) ]
fileHandle = open(tempFile, 'w')
keepProbs = random.random() > 0.5
if keepProbs == False:
for pA in l:
for op in pA.operationList:
op.score = 0.0
for pairwiseAlignment in l:
cigarWrite(fileHandle, pairwiseAlignment, keepProbs)
fileHandle.close()
#Now call sonLib_cigarsTest and read and write chains
command = "sonLib_cigarTest %s %s" % (tempFile, keepProbs)
#return
system(command)
#Now check the chain is okay
fileHandle = open(tempFile, 'r')
l.reverse()
for pairwiseAlignment in cigarRead(fileHandle):
pairwiseAlignment2 = l.pop()
cigarWrite(sys.stdout, pairwiseAlignment, keepProbs)
cigarWrite(sys.stdout, pairwiseAlignment2, keepProbs)
assert pairwiseAlignment == pairwiseAlignment2
assert len(l) == 0
fileHandle.close()
if __name__ == '__main__':
unittest.main()