mirror of
https://github.com/mauiaaron/apple2.git
synced 2025-01-15 09:30:16 +00:00
Ensure that Apple2ix handles invalid gzipped files
This commit is contained in:
parent
55cba116e4
commit
5102706441
@ -798,6 +798,7 @@ const char *disk6_eject(int drive) {
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
off_t compressed_size = -1;
|
off_t compressed_size = -1;
|
||||||
|
|
||||||
|
if (disk6.disk[drive].raw_image_data != MAP_FAILED) {
|
||||||
if (is_gz(disk6.disk[drive].file_name)) {
|
if (is_gz(disk6.disk[drive].file_name)) {
|
||||||
|
|
||||||
// backup uncompressed data ...
|
// backup uncompressed data ...
|
||||||
@ -826,6 +827,7 @@ const char *disk6_eject(int drive) {
|
|||||||
if (ret) {
|
if (ret) {
|
||||||
ERRLOG("Error munmap()ping file %s", disk6.disk[drive].file_name);
|
ERRLOG("Error munmap()ping file %s", disk6.disk[drive].file_name);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (compressed_size > 0) {
|
if (compressed_size > 0) {
|
||||||
TEMP_FAILURE_RETRY(ret = ftruncate(disk6.disk[drive].fd, compressed_size));
|
TEMP_FAILURE_RETRY(ret = ftruncate(disk6.disk[drive].fd, compressed_size));
|
||||||
|
@ -207,6 +207,14 @@ char **_copy_paths_main(const char *fileName) {
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
char **test_copy_disk_paths(const char *fileName) {
|
||||||
|
#if defined(__APPLE__)
|
||||||
|
return _copy_paths_mac(fileName);
|
||||||
|
#else
|
||||||
|
return _copy_paths_main(fileName);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
int test_setup_boot_disk(const char *fileName, int readonly) {
|
int test_setup_boot_disk(const char *fileName, int readonly) {
|
||||||
|
|
||||||
#if defined(__APPLE__)
|
#if defined(__APPLE__)
|
||||||
|
@ -39,6 +39,7 @@ void test_common_init(void);
|
|||||||
void test_common_setup(void);
|
void test_common_setup(void);
|
||||||
void test_type_input(const char *input);
|
void test_type_input(const char *input);
|
||||||
void test_type_input_deterministically(const char *input);
|
void test_type_input_deterministically(const char *input);
|
||||||
|
char **test_copy_disk_paths(const char *fileName);
|
||||||
int test_setup_boot_disk(const char *fileName, int readonly);
|
int test_setup_boot_disk(const char *fileName, int readonly);
|
||||||
void sha1_to_str(const uint8_t * const md, char *buf);
|
void sha1_to_str(const uint8_t * const md, char *buf);
|
||||||
|
|
||||||
|
@ -1416,6 +1416,67 @@ TEST test_disk_image_with_gzip_header_rw() {
|
|||||||
return _test_disk_image_with_gzip_header(/*readonly:*/0);
|
return _test_disk_image_with_gzip_header(/*readonly:*/0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define GZINVALID_DSK "CorruptedGzipped.dsk.gz"
|
||||||
|
static int _test_disk_invalid_gzipped(int readonly) {
|
||||||
|
|
||||||
|
int found_disk_image_file = 0;
|
||||||
|
{
|
||||||
|
char **paths = test_copy_disk_paths(GZINVALID_DSK);
|
||||||
|
|
||||||
|
char **path = &paths[0];
|
||||||
|
while (*path) {
|
||||||
|
char *diskPath = *path;
|
||||||
|
++path;
|
||||||
|
|
||||||
|
int fd = -1;
|
||||||
|
TEMP_FAILURE_RETRY(fd = open(diskPath, readonly ? O_RDONLY : O_RDWR));
|
||||||
|
if (fd != -1) {
|
||||||
|
|
||||||
|
++found_disk_image_file;
|
||||||
|
|
||||||
|
int err = disk6_insert(fd, /*drive:*/0, diskPath, readonly) != NULL;
|
||||||
|
TEMP_FAILURE_RETRY(close(fd));
|
||||||
|
ASSERT(err);
|
||||||
|
|
||||||
|
// did not actually insert corruped disk image and did not crash
|
||||||
|
ASSERT(disk6.disk[0].file_name == NULL);
|
||||||
|
ASSERT(disk6.disk[0].fd == -1);
|
||||||
|
|
||||||
|
ASSERT(disk6.disk[0].raw_image_data == (void *)-1/*MAP_FAILED*/);
|
||||||
|
ASSERT(disk6.disk[0].whole_len == 0);
|
||||||
|
ASSERT(disk6.disk[0].nib_image_data == NULL);
|
||||||
|
ASSERT(disk6.disk[0].nibblized == false);
|
||||||
|
ASSERT(disk6.disk[0].is_protected == false);
|
||||||
|
ASSERT(disk6.disk[0].track_valid == false);
|
||||||
|
ASSERT(disk6.disk[0].track_dirty == false);
|
||||||
|
ASSERT(disk6.disk[0].skew_table == NULL);
|
||||||
|
ASSERT(disk6.disk[0].track_width == 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
path = &paths[0];
|
||||||
|
while (*path) {
|
||||||
|
char *diskPath = *path;
|
||||||
|
++path;
|
||||||
|
FREE(diskPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
FREE(paths);
|
||||||
|
}
|
||||||
|
|
||||||
|
ASSERT(found_disk_image_file > 0);
|
||||||
|
|
||||||
|
PASS();
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST test_disk_invalid_gzipped_ro() {
|
||||||
|
return _test_disk_invalid_gzipped(/*readonly:*/1);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST test_disk_invalid_gzipped_rw() {
|
||||||
|
return _test_disk_invalid_gzipped(/*readonly:*/0);
|
||||||
|
}
|
||||||
|
|
||||||
#if TEST_DISK_EDGE_CASES
|
#if TEST_DISK_EDGE_CASES
|
||||||
#define DROL_DSK "Drol.dsk.gz"
|
#define DROL_DSK "Drol.dsk.gz"
|
||||||
#define DROL_CRACK_SCREEN_SHA "FD7332529E117F14DA3880BB36FE8E23C3704799"
|
#define DROL_CRACK_SCREEN_SHA "FD7332529E117F14DA3880BB36FE8E23C3704799"
|
||||||
@ -1506,6 +1567,9 @@ GREATEST_SUITE(test_suite_disk) {
|
|||||||
RUN_TESTp(test_disk_image_with_gzip_header_ro);
|
RUN_TESTp(test_disk_image_with_gzip_header_ro);
|
||||||
RUN_TESTp(test_disk_image_with_gzip_header_rw);
|
RUN_TESTp(test_disk_image_with_gzip_header_rw);
|
||||||
|
|
||||||
|
RUN_TESTp(test_disk_invalid_gzipped_ro);
|
||||||
|
RUN_TESTp(test_disk_invalid_gzipped_rw);
|
||||||
|
|
||||||
// edge-case tests may require testing copyrighted images (which I have in my possession by legally owning the
|
// edge-case tests may require testing copyrighted images (which I have in my possession by legally owning the
|
||||||
// original disk image (yep, I do ;-)
|
// original disk image (yep, I do ;-)
|
||||||
#if TEST_DISK_EDGE_CASES
|
#if TEST_DISK_EDGE_CASES
|
||||||
|
Loading…
x
Reference in New Issue
Block a user