refactor another test to not create files.

This commit is contained in:
Enno Rehling 2016-02-12 23:36:17 +01:00
parent ec3839fb9f
commit 775bbe7ea6

View file

@ -45,38 +45,34 @@ static void test_readwrite_data(CuTest * tc)
static void test_readwrite_unit(CuTest * tc) static void test_readwrite_unit(CuTest * tc)
{ {
const char *filename = "test.dat";
char path[MAX_PATH];
gamedata data; gamedata data;
storage store;
struct unit *u; struct unit *u;
struct region *r; struct region *r;
struct faction *f; struct faction *f;
int fno; int fno;
/* FIXME: at some point during this test, errno is set to 17 (File exists), why? */
create_directories();
test_cleanup(); test_cleanup();
r = test_create_region(0, 0, 0); r = test_create_region(0, 0, 0);
f = test_create_faction(0); f = test_create_faction(0);
fno = f->no; fno = f->no;
u = test_create_unit(f, r); u = test_create_unit(f, r);
join_path(datapath(), filename, path, sizeof(path));
CuAssertIntEquals(tc, 0, gamedata_openfile(&data, path, "wb", RELEASE_VERSION)); // TODO: intermittent test (even after the 'b' fix!) mstream_init(&data.strm);
gamedata_init(&data, &store, RELEASE_VERSION);
write_unit(&data, u); write_unit(&data, u);
gamedata_close(&data);
data.strm.api->rewind(data.strm.handle);
free_gamedata(); free_gamedata();
f = test_create_faction(0); f = test_create_faction(0);
renumber_faction(f, fno); renumber_faction(f, fno);
CuAssertIntEquals(tc, 0, gamedata_openfile(&data, path, "rb", RELEASE_VERSION)); // TODO: intermittent test (even after the 'b' fix!) gamedata_init(&data, &store, RELEASE_VERSION);
u = read_unit(&data); u = read_unit(&data);
gamedata_close(&data); gamedata_done(&data);
CuAssertPtrNotNull(tc, u); CuAssertPtrNotNull(tc, u);
CuAssertPtrEquals(tc, f, u->faction); CuAssertPtrEquals(tc, f, u->faction);
CuAssertPtrEquals(tc, 0, u->region); CuAssertPtrEquals(tc, 0, u->region);
CuAssertIntEquals(tc, 0, remove(path));
test_cleanup(); test_cleanup();
} }