From 5095c2e2ba9aadf468514804fb3a872d10fdc17d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?John=20Ankarstr=C3=B6m?= Date: Tue, 16 Aug 2022 04:37:48 +0200 Subject: Implement preliminary IO. It might be a good idea to eschew the structs and access the data directly from the view. Alternatively, the serialization functions might be rewritten to simply memcpy the structs, after either adding __attribute__((packed)) or ensuring consistent padding. --- c/test.cpp | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) (limited to 'c/test.cpp') diff --git a/c/test.cpp b/c/test.cpp index 1fc7e3b..fb5d44d 100644 --- a/c/test.cpp +++ b/c/test.cpp @@ -71,6 +71,36 @@ TESTS if (wcscmp(e1.title, e2.title) != 0) FAIL("title is different"); } + + TEST(SerializationPlusIO) + { + ElvData e1; + FromProlog(6, e1); + { + DatView dv{L"tmp.dat", CB_SERIALIZE_ELVDATA}; + Serialize(e1, static_cast(dv.view)); + } + { + DatView dv{L"tmp.dat", CB_SERIALIZE_ELVDATA}; + + ElvData e2; + if (!Unserialize(e2, static_cast(dv.view))) + FAIL("invalid serialization version"); + if (e1.rating != e2.rating) + FAIL("rating is different"); + if (e1.bWatched != e2.bWatched) + FAIL("bWatched is different"); + if (e1.bTVOriginal != e2.bTVOriginal) + FAIL("bTVOriginal is different"); + if (wcscmp(e1.sRating, e2.sRating) != 0) + FAIL("sRating is different"); + if (wcscmp(e1.siEp, e2.siEp) != 0) + FAIL("siEp is different"); + if (wcscmp(e1.title, e2.title) != 0) + FAIL("title is different"); + } + DeleteFile(L"tmp.dat"); + } }; int RunTests() @@ -80,6 +110,7 @@ int RunTests() //EpisodeDataFromWeb{}, EpisodeDataFromProlog{}, Serialization{}, + SerializationPlusIO{}, }; printf("Results (%llu tests):\n", sizeof(tests)/sizeof(*tests)); -- cgit v1.2.3