mirror of
https://github.com/robmcmullen/atrcopy.git
synced 2025-01-17 09:29:46 +00:00
67 lines
1.9 KiB
Python
67 lines
1.9 KiB
Python
from __future__ import print_function
|
|
from builtins import range
|
|
from builtins import object
|
|
from builtins import str
|
|
import os
|
|
|
|
import numpy as np
|
|
import pytest
|
|
|
|
from atrcopy import DefaultSegment, SegmentData, get_xex, interleave_segments
|
|
|
|
|
|
class TestSegment(object):
|
|
def setup(self):
|
|
data = np.ones([4000], dtype=np.uint8)
|
|
r = SegmentData(data)
|
|
self.segment = DefaultSegment(r, 0)
|
|
|
|
def test_getstate(self):
|
|
state = self.segment.__getstate__()
|
|
for k, v in state.items():
|
|
print("k=%s v=%s type=%s" % (k, v, type(v)))
|
|
byte_type = type(str(u' ').encode('utf-8')) # py2 and py3
|
|
try:
|
|
u = unicode(" ")
|
|
except:
|
|
u = str(" ")
|
|
assert type(state['uuid']) == type(u)
|
|
|
|
def test_extra(self):
|
|
s = self.segment
|
|
s.set_comment([[4,5]], "test1")
|
|
s.set_comment([[40,50]], "test2")
|
|
s.set_style_ranges([[2,100]], comment=True)
|
|
s.set_style_ranges([[200, 299]], data=True)
|
|
for i in range(1,4):
|
|
for j in range(1, 4):
|
|
# create some with overlapping regions, some without
|
|
r = [500*j, 500*j + 200*i + 200]
|
|
s.set_style_ranges([r], user=i)
|
|
s.set_user_data([r], i, i*10 + j)
|
|
r = [100, 200]
|
|
s.set_style_ranges([r], user=4)
|
|
s.set_user_data([r], 4, 99)
|
|
r = [3100, 3200]
|
|
s.set_style_ranges([r], user=4)
|
|
s.set_user_data([r], 4, 99)
|
|
|
|
out = dict()
|
|
s.serialize_extra_to_dict(out)
|
|
print("saved", out)
|
|
|
|
data = np.ones([4000], dtype=np.uint8)
|
|
r = SegmentData(data)
|
|
s2 = DefaultSegment(r, 0)
|
|
s2.restore_extra_from_dict(out)
|
|
out2 = dict()
|
|
s2.serialize_extra_to_dict(out2)
|
|
print("loaded", out2)
|
|
assert out == out2
|
|
|
|
|
|
if __name__ == "__main__":
|
|
t = TestSegment()
|
|
t.setup()
|
|
t.test_getstate()
|