Mercurial > molko
view tests/test-save.c @ 408:0ea90751a62d
tests: disable entirely automatic registration
author | David Demelier <markand@malikania.fr> |
---|---|
date | Fri, 08 Apr 2022 15:59:08 +0200 |
parents | e6f972e04519 |
children | 1bf7d6669f0a |
line wrap: on
line source
/* * test-save.c -- test save routines * * Copyright (c) 2020-2022 David Demelier <markand@malikania.fr> * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include <stdio.h> #include <rpg/property.h> #include <rpg/save.h> #include "test.h" RX_SET_UP(basics_set_up) { return RX_SUCCESS; } RX_TEAR_DOWN(basics_tear_down) { remove("1.db"); remove("2.db"); } RX_TEST_CASE(basics, read) { struct save db; /* Non-existent should return error. */ RX_INT_REQUIRE_EQUAL(save_open_path(&db, "1.db", SAVE_MODE_READ), -1); save_finish(&db); } RX_TEST_CASE(basics, write) { struct save db[2] = {0}; /* Write should work on both non-existent and existent database. */ RX_INT_REQUIRE_EQUAL(save_open_path(&db[0], "1.db", SAVE_MODE_WRITE), 0); RX_INT_REQUIRE_EQUAL(save_open_path(&db[1], "2.db", SAVE_MODE_WRITE), 0); /* Update and create date must not be 0. */ RX_REQUIRE(db[0].created > 0); RX_REQUIRE(db[0].updated > 0); RX_REQUIRE(db[1].created > 0); RX_REQUIRE(db[1].updated > 0); save_finish(&db[0]); save_finish(&db[1]); /* Should work again. */ RX_REQUIRE(save_open_path(&db[0], "1.db", SAVE_MODE_WRITE) == 0); RX_REQUIRE(save_open_path(&db[1], "2.db", SAVE_MODE_WRITE) == 0); RX_REQUIRE(db[0].created > 0); RX_REQUIRE(db[0].updated > 0); RX_REQUIRE(db[1].created > 0); RX_REQUIRE(db[1].updated > 0); save_finish(&db[0]); save_finish(&db[1]); } #if 0 RX_TEST_CASE(properties, set) { struct save db; struct property prop; RX_REQUIRE(save_open_path(&db, "1.db", SAVE_MODE_WRITE) == 0); /* Insert a new property 'state'. */ prop = (struct property){.key = "state", .value = "intro"}; RX_REQUIRE(property_save(&prop, &db) == 0); prop = (struct property){.key = "state"}; RX_REQUIRE(property_load(&prop, &db) == 0); GREATEST_ASSERT_STR_EQ(prop.value, "intro"); /* Now we replace the value. */ prop = (struct property){.key = "state", .value = "map"}; RX_REQUIRE(property_save(&prop, &db) == 0); prop = (struct property){.key = "state"}; RX_REQUIRE(property_load(&prop, &db) == 0); GREATEST_ASSERT_STR_EQ(prop.value, "map"); save_finish(&db); GREATEST_PASS(); } GREATEST_TEST properties_notfound(void) { struct save db; struct property prop = {.key = "state"}; RX_REQUIRE(save_open_path(&db, "1.db", SAVE_MODE_WRITE) == 0); RX_REQUIRE(property_load(&prop, &db) < 0); GREATEST_ASSERT_STR_EQ(prop.value, ""); GREATEST_PASS(); } GREATEST_TEST properties_remove(void) { struct save db; struct property prop; RX_REQUIRE(save_open_path(&db, "1.db", SAVE_MODE_WRITE) == 0); /* Insert a new property 'initialized'. */ prop = (struct property){.key = "state", .value = "intro"}; RX_REQUIRE(property_save(&prop, &db) == 0); prop = (struct property){.key = "state"}; RX_REQUIRE(property_remove(&prop, &db) == 0); prop = (struct property){.key = "state"}; RX_REQUIRE(property_load(&prop, &db) < 0); RX_STR_REQUIRE_EQUAL(prop.value, ""); GREATEST_PASS(); } #endif static const struct rx_test_case tests[] = { TEST_FIXTURE(basics, read, void *), TEST_FIXTURE(basics, write, void *) }; int main(int argc, char **argv) { return TEST_RUN_ALL(tests, argc, argv) }