1
0
mirror of https://github.com/pevans/erc-c.git synced 2025-01-17 19:30:13 +00:00
erc-c/tests/apple2.dd.c
2017-12-14 23:09:32 -06:00

95 lines
2.2 KiB
C

#include <criterion/criterion.h>
#include "apple2.dd.h"
static apple2dd *drive;
static void
setup()
{
drive = apple2dd_create();
}
static void
teardown()
{
apple2dd_free(drive);
}
TestSuite(apple2dd, .init = setup, .fini = teardown);
Test(apple2dd, create)
{
cr_assert_eq(drive->data, NULL);
cr_assert_eq(drive->track_pos, 0);
cr_assert_eq(drive->sector_pos, 0);
cr_assert_eq(drive->online, false);
cr_assert_eq(drive->write_protect, true);
cr_assert_eq(drive->mode, DD_READ);
}
Test(apple2dd, step)
{
// Does step work at all?
apple2dd_step(drive, 5);
cr_assert_eq(drive->track_pos, 5);
apple2dd_step(drive, 3);
cr_assert_eq(drive->track_pos, 8);
apple2dd_step(drive, -2);
cr_assert_eq(drive->track_pos, 6);
// Do we handle going over the maximum track position properly?
apple2dd_step(drive, 100);
cr_assert_eq(drive->track_pos, MAX_DRIVE_STEPS);
// Do we handle going to the 0 track properly if we get a radically
// high number of negative track shifts?
apple2dd_step(drive, -1000);
cr_assert_eq(drive->track_pos, 0);
}
Test(apple2dd, set_mode)
{
apple2dd_set_mode(drive, DD_WRITE);
cr_assert_eq(drive->mode, DD_WRITE);
apple2dd_set_mode(drive, DD_READ);
cr_assert_eq(drive->mode, DD_READ);
// let's try shenanigans
apple2dd_set_mode(drive, 111111111);
cr_assert_eq(drive->mode, DD_READ);
}
Test(apple2dd, turn_on)
{
apple2dd_turn_on(drive, true);
cr_assert(drive->online);
apple2dd_turn_on(drive, false);
cr_assert(!drive->online);
// I mean, ok
apple2dd_turn_on(drive, 1111333);
cr_assert(drive->online);
}
Test(apple2dd, write_protect)
{
apple2dd_write_protect(drive, true);
cr_assert(drive->write_protect);
apple2dd_write_protect(drive, false);
cr_assert(!drive->write_protect);
apple2dd_write_protect(drive, 2222);
cr_assert(drive->write_protect);
}
Test(apple2dd, position)
{
// Without any data, the drive should return a null position
// regardless of track position
drive->track_pos = 3;
drive->sector_pos = 44;
cr_assert_eq(apple2dd_position(drive), 0);
// FIXME: we need some dummy data for the drive...
}