forked from github/server
add unit tests for read_unitid
This commit is contained in:
parent
400b8f1ffa
commit
3dc173b6ec
1 changed files with 47 additions and 0 deletions
|
@ -14,6 +14,45 @@
|
||||||
|
|
||||||
struct critbit_tree;
|
struct critbit_tree;
|
||||||
|
|
||||||
|
static void test_read_unitid(CuTest *tc) {
|
||||||
|
unit *u;
|
||||||
|
order *ord;
|
||||||
|
attrib *a;
|
||||||
|
struct locale *lang;
|
||||||
|
struct terrain_type *t_plain;
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
lang = get_or_create_locale("de");
|
||||||
|
test_translate_param(lang, P_TEMP, "TEMP");
|
||||||
|
/* note that the english order is FIGHT, not COMBAT, so this is a poor example */
|
||||||
|
t_plain = test_create_terrain("plain", LAND_REGION);
|
||||||
|
u = test_create_unit(test_create_faction(0), test_create_region(0, 0, t_plain));
|
||||||
|
a = a_add(&u->attribs, a_new(&at_alias));
|
||||||
|
a->data.i = atoi36("42"); /* this unit is also TEMP 42 */
|
||||||
|
|
||||||
|
ord = create_order(K_GIVE, lang, "TEMP 42");
|
||||||
|
init_order(ord);
|
||||||
|
CuAssertIntEquals(tc, u->no, read_unitid(u->faction, u->region));
|
||||||
|
free_order(ord);
|
||||||
|
|
||||||
|
ord = create_order(K_GIVE, lang, "8");
|
||||||
|
init_order(ord);
|
||||||
|
CuAssertIntEquals(tc, 8, read_unitid(u->faction, u->region));
|
||||||
|
free_order(ord);
|
||||||
|
|
||||||
|
ord = create_order(K_GIVE, lang, "");
|
||||||
|
init_order(ord);
|
||||||
|
CuAssertIntEquals(tc, -1, read_unitid(u->faction, u->region));
|
||||||
|
free_order(ord);
|
||||||
|
|
||||||
|
ord = create_order(K_GIVE, lang, "TEMP");
|
||||||
|
init_order(ord);
|
||||||
|
CuAssertIntEquals(tc, -1, read_unitid(u->faction, u->region));
|
||||||
|
free_order(ord);
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
static void test_getunit(CuTest *tc) {
|
static void test_getunit(CuTest *tc) {
|
||||||
unit *u, *u2;
|
unit *u, *u2;
|
||||||
order *ord;
|
order *ord;
|
||||||
|
@ -53,6 +92,13 @@ static void test_getunit(CuTest *tc) {
|
||||||
CuAssertPtrEquals(tc, NULL, u2);
|
CuAssertPtrEquals(tc, NULL, u2);
|
||||||
free_order(ord);
|
free_order(ord);
|
||||||
|
|
||||||
|
// bug https://bugs.eressea.de/view.php?id=1685
|
||||||
|
ord = create_order(K_GIVE, lang, "TEMP ##");
|
||||||
|
init_order(ord);
|
||||||
|
CuAssertIntEquals(tc, GET_NOTFOUND, getunit(u->region, u->faction, &u2));
|
||||||
|
CuAssertPtrEquals(tc, NULL, u2);
|
||||||
|
free_order(ord);
|
||||||
|
|
||||||
// bug https://bugs.eressea.de/view.php?id=1685
|
// bug https://bugs.eressea.de/view.php?id=1685
|
||||||
ord = create_order(K_GIVE, lang, "##");
|
ord = create_order(K_GIVE, lang, "##");
|
||||||
init_order(ord);
|
init_order(ord);
|
||||||
|
@ -119,6 +165,7 @@ CuSuite *get_config_suite(void)
|
||||||
CuSuite *suite = CuSuiteNew();
|
CuSuite *suite = CuSuiteNew();
|
||||||
SUITE_ADD_TEST(suite, test_forbiddenid);
|
SUITE_ADD_TEST(suite, test_forbiddenid);
|
||||||
SUITE_ADD_TEST(suite, test_getunit);
|
SUITE_ADD_TEST(suite, test_getunit);
|
||||||
|
SUITE_ADD_TEST(suite, test_read_unitid);
|
||||||
SUITE_ADD_TEST(suite, test_get_set_param);
|
SUITE_ADD_TEST(suite, test_get_set_param);
|
||||||
SUITE_ADD_TEST(suite, test_param_int);
|
SUITE_ADD_TEST(suite, test_param_int);
|
||||||
SUITE_ADD_TEST(suite, test_param_flt);
|
SUITE_ADD_TEST(suite, test_param_flt);
|
||||||
|
|
Loading…
Reference in a new issue