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
|
import gfapy
import unittest
class TestLinePath(unittest.TestCase):
def test_from_string(self):
fields = ["P","4","1+,2-,3+","9M2I3D1M,12M","ab:Z:abcd"]
string = "\t".join(fields)
gfapy.Line(string)
self.assertIsInstance(gfapy.Line(string), gfapy.line.group.Path)
self.assertEqual(str(fields[0]), gfapy.Line(string).record_type)
self.assertEqual(str(fields[1]), gfapy.Line(string).path_name)
self.assertEqual([gfapy.OrientedLine("1","+"),
gfapy.OrientedLine("2","-"),
gfapy.OrientedLine("3","+")],
gfapy.Line(string).segment_names)
self.assertEqual([[gfapy.alignment.cigar.Operation(9,"M"),
gfapy.alignment.cigar.Operation(2,"I"),
gfapy.alignment.cigar.Operation(3,"D"),
gfapy.alignment.cigar.Operation(1,"M")],
[gfapy.alignment.cigar.Operation(12,"M")]],
gfapy.Line(string).overlaps)
self.assertEqual("abcd", gfapy.Line(string).ab)
with self.assertRaises(gfapy.FormatError):
gfapy.Line(string+"\tH1")
with self.assertRaises(gfapy.FormatError):
gfapy.Line("P\tH")
with self.assertRaises(gfapy.FormatError):
f=fields[:]
f[2]="1,2,3"
gfapy.Line("\t".join(f), vlevel = 2)
with self.assertRaises(gfapy.InconsistencyError):
f=fields[:]
f[2]="1+,2+"
f[3]="9M,12M,3M"
gfapy.Line("\t".join(f), vlevel = 2)
f=fields[:]
f[3]="*,*"
gfapy.Line("\t".join(f), vlevel = 2)
f=fields[:]
f[3]="9M2I3D1M,12M,12M"
gfapy.Line("\t".join(f), vlevel = 2)
f=fields[:]
f[3]="*"
gfapy.Line("\t".join(f), vlevel = 2)
with self.assertRaises(gfapy.FormatError):
f=fields[:]
f[3]="12,12"
gfapy.Line("\t".join(f), vlevel = 2)
with self.assertRaises(gfapy.FormatError):
f=fields[:]
f[3]="12M|12M"
gfapy.Line("\t".join(f), vlevel = 2)
|