root/galaxy-central/eggs/bx_python-0.5.0_dev_f74aec067563-py2.6-macosx-10.6-universal-ucs2.egg/bx/wiggle_tests.py @ 3

リビジョン 3, 3.1 KB (コミッタ: kohda, 14 年 前)

Install Unix tools  http://hannonlab.cshl.edu/galaxy_unix_tools/galaxy.html

行番号 
1"""
2Tests for `bx.wiggle`.
3"""
4
5import unittest
6from bx import wiggle
7from StringIO import StringIO
8
9# A modified version of UCSC's example wiggle, taken from http://genome.ucsc.edu/goldenPath/help/wiggleExample.txt
10test_wig = """browser position chr19:59302001-59311000
11browser hide all
12browser pack refGene encodeRegions
13browser full altGraph
14#       5 base wide bar graph, autoScale is on by default == graphing
15#       limits will dynamically change to always show full range of data
16#       in viewing window, priority = 20 positions this as the second graph
17#       Note, zero-relative, half-open coordinate system in use for bed format
18track type=wiggle_0 name="Bed Format" description="BED format" visibility=full color=200,100,0 altColor=0,100,200 priority=20
19chr19 59302000 59302005 -1.0
20chr19 59302300 59302305 -0.75
21#       4 base wide bar graph at arbitrarily spaced positions,
22#       threshold line drawn at y=11.76
23#       autoScale off viewing range set to [0:25]
24#       priority = 10 positions this as the first graph
25#       Note, one-relative coordinate system in use for this format
26track type=wiggle_0 name="variableStep" description="variableStep format" visibility=full autoScale=off viewLimits=0.0:25.0 color=255,200,0 yLineMark=11.76 yLineOnOff=on priority=10
27variableStep chrom=chr19 span=4
2859304701 10.0
2959304901 12.5
30#       3 base wide points graph at every 300 bases, 50 pixel high graph
31#       autoScale off and viewing range set to [0:1000]
32#       priority = 30 positions this as the third graph
33#       Note, one-relative coordinate system in use for this format
34track type=wiggle_0 name="fixedStep" description="fixed step" visibility=full autoScale=off viewLimits=0:1000 color=0,200,100 maxHeightPixels=100:50:20 graphType=points priority=30
35fixedStep chrom=chr19 start=59307401 step=300 span=3
361000
37 900
38 800
39"""
40
41interval_reader_result = [
42"chr19,59302000,59302005,+,-1.0",
43"chr19,59302300,59302305,+,-0.75",
44"chr19,59304700,59304704,+,10.0",
45"chr19,59304900,59304904,+,12.5",
46"chr19,59307400,59307403,+,1000.0",
47"chr19,59307700,59307703,+,900.0",
48"chr19,59308000,59308003,+,800.0"
49]
50
51position_reader_result = [
52"chr19,59302000,-1.0",
53"chr19,59302001,-1.0",
54"chr19,59302002,-1.0",
55"chr19,59302003,-1.0",
56"chr19,59302004,-1.0",
57"chr19,59302300,-0.75",
58"chr19,59302301,-0.75",
59"chr19,59302302,-0.75",
60"chr19,59302303,-0.75",
61"chr19,59302304,-0.75",
62"chr19,59304700,10.0",
63"chr19,59304701,10.0",
64"chr19,59304702,10.0",
65"chr19,59304703,10.0",
66"chr19,59304900,12.5",
67"chr19,59304901,12.5",
68"chr19,59304902,12.5",
69"chr19,59304903,12.5",
70"chr19,59307400,1000.0",
71"chr19,59307401,1000.0",
72"chr19,59307402,1000.0",
73"chr19,59307700,900.0",
74"chr19,59307701,900.0",
75"chr19,59307702,900.0",
76"chr19,59308000,800.0",
77"chr19,59308001,800.0",
78"chr19,59308002,800.0"
79]
80class TestWiggleReader(unittest.TestCase):
81    def test_reader(self):
82        #Test position reader
83        assert position_reader_result == [ ",".join( map( str, value ) ) for value in wiggle.Reader( StringIO( test_wig ) ) ]
84   
85    def test_interval_reader(self):
86        #Test interval reader reader
87        assert interval_reader_result == [ ",".join( map( str, value ) ) for value in wiggle.IntervalReader( StringIO( test_wig ) ) ]
88   
89if __name__ == '__main__':
90    unittest.main()
Note: リポジトリブラウザについてのヘルプは TracBrowser を参照してください。