2017-05-07 13:28:15 -07:00
|
|
|
from __future__ import print_function
|
2017-05-07 18:58:10 -07:00
|
|
|
from builtins import object
|
2017-02-21 19:25:47 -08:00
|
|
|
import numpy as np
|
|
|
|
|
|
|
|
from mock import *
|
|
|
|
|
2017-02-22 12:11:56 -08:00
|
|
|
from atrcopy import SegmentData, AtariDosDiskImage, Dos33DiskImage,InvalidBinaryFile
|
2017-02-21 20:08:37 -08:00
|
|
|
from atrcopy.errors import *
|
2017-02-21 19:25:47 -08:00
|
|
|
|
|
|
|
|
2017-02-22 12:11:56 -08:00
|
|
|
class BaseFilesystemModifyTest(object):
|
|
|
|
diskimage_type = None
|
2017-05-07 09:58:29 -07:00
|
|
|
sample_data = None
|
2017-02-22 12:11:56 -08:00
|
|
|
num_files_in_sample = 0
|
|
|
|
|
2017-02-21 19:25:47 -08:00
|
|
|
def setup(self):
|
2017-05-07 09:58:29 -07:00
|
|
|
rawdata = SegmentData(self.sample_data.copy())
|
2017-02-22 12:11:56 -08:00
|
|
|
self.image = self.diskimage_type(rawdata)
|
2017-02-21 19:25:47 -08:00
|
|
|
|
2017-05-07 18:58:10 -07:00
|
|
|
def check_entries(self, entries, prefix=b"TEST", save=None):
|
2017-02-21 20:08:37 -08:00
|
|
|
orig_num_files = len(self.image.files)
|
2017-02-21 23:07:24 -08:00
|
|
|
filenames = []
|
2017-02-21 20:08:37 -08:00
|
|
|
count = 1
|
|
|
|
for data in entries:
|
2017-05-07 18:58:10 -07:00
|
|
|
filename = b"%s%d.BIN" % (prefix, count)
|
2017-02-21 20:08:37 -08:00
|
|
|
self.image.write_file(filename, None, data)
|
|
|
|
assert len(self.image.files) == orig_num_files + count
|
2017-02-23 22:15:20 -08:00
|
|
|
data2 = np.fromstring(self.image.find_file(filename), dtype=np.uint8)
|
|
|
|
assert np.array_equal(data, data2[0:len(data)])
|
2017-02-21 20:08:37 -08:00
|
|
|
count += 1
|
|
|
|
|
|
|
|
# loop over them again to make sure data wasn't overwritten
|
|
|
|
count = 1
|
|
|
|
for data in entries:
|
2017-05-07 18:58:10 -07:00
|
|
|
filename = b"%s%d.BIN" % (prefix, count)
|
2017-02-23 22:15:20 -08:00
|
|
|
data2 = np.fromstring(self.image.find_file(filename), dtype=np.uint8)
|
|
|
|
assert np.array_equal(data, data2[0:len(data)])
|
2017-02-21 20:08:37 -08:00
|
|
|
count += 1
|
2017-02-21 23:07:24 -08:00
|
|
|
filenames.append(filename)
|
2017-02-21 20:08:37 -08:00
|
|
|
|
2017-02-21 23:07:24 -08:00
|
|
|
if save is not None:
|
|
|
|
self.image.save(save)
|
|
|
|
|
|
|
|
return filenames
|
2017-02-21 20:08:37 -08:00
|
|
|
|
2017-02-21 19:25:47 -08:00
|
|
|
def test_small(self):
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample
|
2017-02-21 19:25:47 -08:00
|
|
|
|
2017-02-21 19:49:03 -08:00
|
|
|
data = np.asarray([0xff, 0xff, 0x00, 0x60, 0x01, 0x60, 1, 2], dtype=np.uint8)
|
2017-05-07 18:58:10 -07:00
|
|
|
self.image.write_file(b"TEST.XEX", None, data)
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 1
|
2017-02-21 19:25:47 -08:00
|
|
|
|
2017-05-07 18:58:10 -07:00
|
|
|
data2 = np.fromstring(self.image.find_file(b"TEST.XEX"), dtype=np.uint8)
|
2017-02-23 22:15:20 -08:00
|
|
|
assert np.array_equal(data, data2[0:len(data)])
|
2017-02-21 19:49:03 -08:00
|
|
|
|
2017-02-21 20:08:37 -08:00
|
|
|
def test_50k(self):
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample
|
2017-02-21 20:08:37 -08:00
|
|
|
|
|
|
|
data = np.arange(50*1024, dtype=np.uint8)
|
2017-05-07 18:58:10 -07:00
|
|
|
self.image.write_file(b"RAMP50K.BIN", None, data)
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 1
|
2017-02-21 20:08:37 -08:00
|
|
|
|
2017-05-07 18:58:10 -07:00
|
|
|
data2 = self.image.find_file(b"RAMP50K.BIN")
|
2017-02-21 20:08:37 -08:00
|
|
|
assert data.tostring() == data2
|
|
|
|
|
|
|
|
def test_many_small(self):
|
|
|
|
entries = [
|
|
|
|
np.asarray([0xff, 0xff, 0x00, 0x60, 0x01, 0x60, 1, 2], dtype=np.uint8),
|
|
|
|
np.arange(1*1024, dtype=np.uint8),
|
|
|
|
np.arange(2*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(4*1024, dtype=np.uint8),
|
|
|
|
np.arange(5*1024, dtype=np.uint8),
|
|
|
|
np.arange(6*1024, dtype=np.uint8),
|
|
|
|
np.arange(7*1024, dtype=np.uint8),
|
|
|
|
np.arange(8*1024, dtype=np.uint8),
|
|
|
|
np.arange(9*1024, dtype=np.uint8),
|
|
|
|
np.arange(10*1024, dtype=np.uint8),
|
|
|
|
]
|
2017-05-07 18:58:10 -07:00
|
|
|
self.check_entries(entries, save=b"many_small.atr")
|
2017-02-21 20:08:37 -08:00
|
|
|
|
|
|
|
def test_big_failure(self):
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample
|
2017-02-21 20:08:37 -08:00
|
|
|
|
|
|
|
data = np.arange(50*1024, dtype=np.uint8)
|
2017-05-07 18:58:10 -07:00
|
|
|
self.image.write_file(b"RAMP50K.BIN", None, data)
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 1
|
2017-02-21 20:08:37 -08:00
|
|
|
with pytest.raises(NotEnoughSpaceOnDisk):
|
2017-05-02 19:08:40 -07:00
|
|
|
huge = np.arange(500*1024, dtype=np.uint8)
|
2017-05-07 18:58:10 -07:00
|
|
|
self.image.write_file(b"RAMP500K.BIN", None, huge)
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 1
|
2017-02-21 20:08:37 -08:00
|
|
|
|
2017-02-21 23:07:24 -08:00
|
|
|
def test_delete(self):
|
|
|
|
entries1 = [
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(10*1024, dtype=np.uint8),
|
|
|
|
np.arange(10*1024, dtype=np.uint8),
|
|
|
|
]
|
|
|
|
entries2 = [
|
|
|
|
np.arange(10*1024, dtype=np.uint8),
|
2017-02-24 08:24:34 -08:00
|
|
|
np.arange(5*1024, dtype=np.uint8),
|
2017-02-21 23:07:24 -08:00
|
|
|
]
|
|
|
|
|
|
|
|
filenames = self.check_entries(entries1, "FIRST")
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 11
|
2017-02-21 23:07:24 -08:00
|
|
|
self.image.delete_file(filenames[2])
|
|
|
|
self.image.delete_file(filenames[5])
|
|
|
|
self.image.delete_file(filenames[0])
|
|
|
|
self.image.delete_file(filenames[8])
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 7
|
2017-02-21 23:07:24 -08:00
|
|
|
|
2017-05-07 18:58:10 -07:00
|
|
|
filename = self.check_entries(entries2, b"SECOND", save="test_delete.atr")
|
2017-02-22 12:11:56 -08:00
|
|
|
assert len(self.image.files) == self.num_files_in_sample + 9
|
|
|
|
|
2017-02-24 10:13:31 -08:00
|
|
|
def test_delete_all(self):
|
|
|
|
entries1 = [
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(3*1024, dtype=np.uint8),
|
|
|
|
np.arange(10*1024, dtype=np.uint8),
|
|
|
|
np.arange(11*1024, dtype=np.uint8),
|
|
|
|
np.arange(12*1024, dtype=np.uint8),
|
|
|
|
]
|
|
|
|
for dirent in self.image.files:
|
|
|
|
self.image.delete_file(dirent.filename)
|
|
|
|
assert len(self.image.files) == 0
|
|
|
|
|
2017-02-23 22:15:20 -08:00
|
|
|
class TestAtariDosSDImage(BaseFilesystemModifyTest):
|
|
|
|
diskimage_type = AtariDosDiskImage
|
2017-05-07 09:58:29 -07:00
|
|
|
sample_data = np.fromfile("../test_data/dos_sd_test1.atr", dtype=np.uint8)
|
2017-02-23 22:15:20 -08:00
|
|
|
num_files_in_sample = 5
|
2017-02-22 12:11:56 -08:00
|
|
|
|
2017-05-02 19:08:40 -07:00
|
|
|
class TestAtariDosEDImage(BaseFilesystemModifyTest):
|
|
|
|
diskimage_type = AtariDosDiskImage
|
2017-05-07 09:58:29 -07:00
|
|
|
sample_data = np.fromfile("../test_data/dos_ed_test1.atr", dtype=np.uint8)
|
2017-05-02 19:08:40 -07:00
|
|
|
num_files_in_sample = 5
|
|
|
|
|
|
|
|
class TestAtariDosDDImage(BaseFilesystemModifyTest):
|
|
|
|
diskimage_type = AtariDosDiskImage
|
2017-05-07 09:58:29 -07:00
|
|
|
sample_data = np.fromfile("../test_data/dos_dd_test1.atr", dtype=np.uint8)
|
2017-05-02 19:08:40 -07:00
|
|
|
num_files_in_sample = 5
|
|
|
|
|
2017-02-22 12:11:56 -08:00
|
|
|
class TestDos33Image(BaseFilesystemModifyTest):
|
|
|
|
diskimage_type = Dos33DiskImage
|
2017-05-07 09:58:29 -07:00
|
|
|
sample_data = np.fromfile("../test_data/dos33_master.dsk", dtype=np.uint8)
|
2017-02-22 12:11:56 -08:00
|
|
|
num_files_in_sample = 19
|
2017-02-21 23:07:24 -08:00
|
|
|
|
2017-02-21 19:25:47 -08:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2017-05-07 09:58:29 -07:00
|
|
|
t = TestAtariDosSDImage()
|
|
|
|
for name in dir(t):
|
2017-05-07 13:28:15 -07:00
|
|
|
print(name)
|
2017-05-07 09:58:29 -07:00
|
|
|
if name.startswith("test_"):
|
|
|
|
t.setup()
|
|
|
|
getattr(t, name)()
|