-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathtest_aliasor.py
93 lines (76 loc) · 3.49 KB
/
test_aliasor.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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
from __future__ import unicode_literals
import os
from distutils import dir_util
from pango_aliasor.aliasor import Aliasor
from pytest import fixture
@fixture
def datadir(tmpdir, request):
'''
Fixture responsible for searching a folder with the same name of test
module and, if available, moving all contents to a temporary directory so
tests can use them freely.
'''
filename = request.module.__file__
test_dir, _ = os.path.splitext(filename)
if os.path.isdir(test_dir):
dir_util.copy_tree(test_dir,str(tmpdir))
return tmpdir
def test_pango_designation_init():
aliasor = Aliasor()
def test_uncompression():
aliasor = Aliasor()
assert aliasor.uncompress('BA.1') == 'B.1.1.529.1'
assert aliasor.uncompress('AY.4') == 'B.1.617.2.4'
assert aliasor.uncompress('AY.4.3.2') == 'B.1.617.2.4.3.2'
assert aliasor.uncompress('B.1') == 'B.1'
assert aliasor.uncompress('B') == 'B'
assert aliasor.uncompress('') == ''
def test_compression():
aliasor = Aliasor()
assert aliasor.compress('B.1.1.529.1') == 'BA.1'
assert aliasor.compress('B.1.617.2.4') == 'AY.4'
assert aliasor.compress('B.1.617.2.4.3.1') == 'AY.4.3.1'
assert aliasor.compress('B.1.617.2') == 'B.1.617.2'
assert aliasor.compress('B.1') == 'B.1'
assert aliasor.compress('B') == 'B'
assert aliasor.compress('') == ''
def test_except_recombinants():
aliasor = Aliasor()
assert aliasor.uncompress('XA.1') == 'XA.1'
assert aliasor.compress('XA.1') == 'XA.1'
def test_double_alias_compression():
aliasor = Aliasor()
assert aliasor.compress('B.1.1.529.5.3.1.1') == 'BE.1'
def test_double_alias_uncompression():
aliasor = Aliasor()
assert aliasor.uncompress('BE.1') == 'B.1.1.529.5.3.1.1'
def test_read_from_file(datadir):
aliasor = Aliasor(datadir.join('alias_key.json'))
assert aliasor.compress('B.1.1.529.1') == 'BA.1'
def test_partial_alias_up_to():
aliasor = Aliasor()
assert aliasor.partial_compress('B.1.1.529.1.2', up_to = 0) == 'B.1.1.529.1.2'
assert aliasor.partial_compress('B.1.1.529.2.75.1.2', up_to = 1) == 'BA.2.75.1.2'
assert aliasor.partial_compress('B.1.1.529.2.75.1.2', up_to = 2) == 'BL.2'
def test_partial_alias_accepted():
aliasor = Aliasor()
assert aliasor.partial_compress('B.1.1.529.1.2', accepted_aliases={"BA","AZ"}) == "BA.1.2"
assert aliasor.partial_compress('B.1.617.2.3', accepted_aliases={"BA","AZ"}) == "B.1.617.2.3"
assert aliasor.partial_compress('B.1.1.529.2.75.1.2', accepted_aliases={"BA"}) == 'BA.2.75.1.2'
assert aliasor.partial_compress('B', accepted_aliases={"BA"}) == 'B'
def test_partial_alias_combination():
aliasor = Aliasor()
assert aliasor.partial_compress('B.1.1.529.1.2',up_to=1, accepted_aliases={"BA","AZ"}) == "BA.1.2"
assert aliasor.partial_compress('B.1.617.2.3',up_to=1, accepted_aliases={"BA","AZ"}) == "AY.3"
assert aliasor.partial_compress('B.1.1.529.2.75.1.2',up_to=3, accepted_aliases={"BA"}) == 'BL.2'
assert aliasor.partial_compress('B.1.1.529.2.75.1.2',up_to=4, accepted_aliases={"BA"}) == 'BL.2'
assert aliasor.partial_compress('B.1.1.529.2.75.1.2',up_to=1, accepted_aliases={"BA"}) == 'BA.2.75.1.2'
def test_parent():
aliasor = Aliasor()
assert aliasor.parent('B.1.1.529.1') == 'B.1.1.529'
assert aliasor.parent('BQ.1') == 'BE.1.1.1'
assert aliasor.parent('XAA') == ''
assert aliasor.parent('') == ''
assert aliasor.parent('A') == ''
assert aliasor.parent('B') == ''
assert aliasor.parent('C.1') == 'B.1.1.1'