annotate SMART/Java/Python/test/Test_F_CombineTags.py @ 31:0ab839023fe4

Uploaded
author m-zytnicki
date Tue, 30 Apr 2013 14:33:21 -0400
parents 94ab73e8a190
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
18
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
1 import unittest
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
2 import os
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
3 from optparse import OptionParser
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
4 from SMART.Java.Python.structure.Transcript import Transcript
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
5 from commons.core.parsing.ParserChooser import ParserChooser
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
6 from commons.core.parsing.GffParser import GffParser
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
7 from commons.core.writer.Gff3Writer import Gff3Writer
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
8 from SMART.Java.Python.CombineTags import CombineTags
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
9
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
10 class Test_F_CombineTags(unittest.TestCase):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
11
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
12 def setUp(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
13 self._inputFileName = "inputFileTest.gff3"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
14 self._outputFileName = "outputFileTest.gff3"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
15 self._tag1 = "tag1"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
16 self._tag2 = "tag2"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
17 self._outputTag = "outputTag"
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
18
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
19 def tearDown(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
20 os.remove(self._inputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
21 os.remove(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
22
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
23 def test_plus(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
24 transcript = self._createDummyTranscript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
25 transcript.setTagValue(self._tag1, 1)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
26 transcript.setTagValue(self._tag2, 2)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
27 self._writeTranscript(transcript)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
28 combiner = CombineTags(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
29 combiner.setInputFile(self._inputFileName, "gff3")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
30 combiner.setOutputFile(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
31 combiner.setTags(self._tag1, self._tag2, self._outputTag, None)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
32 combiner.setOperation("plus")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
33 combiner.run()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
34 self._testOutputTag(3)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
35
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
36 def test_minus(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
37 transcript = self._createDummyTranscript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
38 transcript.setTagValue(self._tag1, 2)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
39 transcript.setTagValue(self._tag2, 1)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
40 self._writeTranscript(transcript)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
41 combiner = CombineTags(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
42 combiner.setInputFile(self._inputFileName, "gff3")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
43 combiner.setOutputFile(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
44 combiner.setTags(self._tag1, self._tag2, self._outputTag, None)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
45 combiner.setOperation("minus")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
46 combiner.run()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
47 self._testOutputTag(1)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
48
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
49 def test_times(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
50 transcript = self._createDummyTranscript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
51 transcript.setTagValue(self._tag1, 6)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
52 transcript.setTagValue(self._tag2, 3)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
53 self._writeTranscript(transcript)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
54 combiner = CombineTags(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
55 combiner.setInputFile(self._inputFileName, "gff3")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
56 combiner.setOutputFile(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
57 combiner.setTags(self._tag1, self._tag2, self._outputTag, None)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
58 combiner.setOperation("times")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
59 combiner.run()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
60 self._testOutputTag(18)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
61
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
62 def test_div(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
63 transcript = self._createDummyTranscript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
64 transcript.setTagValue(self._tag1, 6)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
65 transcript.setTagValue(self._tag2, 3)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
66 self._writeTranscript(transcript)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
67 combiner = CombineTags(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
68 combiner.setInputFile(self._inputFileName, "gff3")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
69 combiner.setOutputFile(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
70 combiner.setTags(self._tag1, self._tag2, self._outputTag, None)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
71 combiner.setOperation("div")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
72 combiner.run()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
73 self._testOutputTag(2)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
74
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
75 def test_default(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
76 transcript = self._createDummyTranscript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
77 transcript.setTagValue(self._tag1, 1)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
78 self._writeTranscript(transcript)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
79 combiner = CombineTags(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
80 combiner.setInputFile(self._inputFileName, "gff3")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
81 combiner.setOutputFile(self._outputFileName)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
82 combiner.setTags(self._tag1, self._tag2, self._outputTag, 0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
83 combiner.setOperation("plus")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
84 combiner.run()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
85 self._testOutputTag(0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
86
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
87 def _createDummyTranscript(self):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
88 transcript = Transcript()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
89 transcript.setChromosome("chr1")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
90 transcript.setName("test1")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
91 transcript.setEnd(200)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
92 transcript.setStart(100)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
93 transcript.setDirection("+")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
94 return transcript
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
95
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
96 def _testOutputTag(self, value):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
97 parser = GffParser(self._outputFileName, 0)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
98 for transcript in parser.getIterator():
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
99 self.assertEquals(float(transcript.getTagValue(self._outputTag)), value)
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
100 parser.close()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
101
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
102 def _writeTranscript(self, transcript):
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
103 f = open(self._inputFileName, "w")
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
104 f.write(transcript.printGff3("test"))
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
105 f.close()
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
106
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
107
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
108 if __name__ == "__main__":
94ab73e8a190 Uploaded
m-zytnicki
parents:
diff changeset
109 unittest.main()