From bd6b9761b00ddef906e283ebfab07d398ac95199 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Wed, 17 Dec 2014 19:53:19 +0100 Subject: [PATCH] add simple tests for pay_cmd. --- src/kernel/config.test.c | 4 +-- src/laws.test.c | 69 +++++++++++++++++++++++++++++++++++++--- src/tests.c | 8 +++++ src/tests.h | 2 ++ 4 files changed, 76 insertions(+), 7 deletions(-) diff --git a/src/kernel/config.test.c b/src/kernel/config.test.c index 79643106c..b5d7957be 100644 --- a/src/kernel/config.test.c +++ b/src/kernel/config.test.c @@ -21,12 +21,10 @@ static void test_getunit(CuTest *tc) { struct region *r; struct locale *lang; struct terrain_type *t_plain; - struct critbit_tree ** cb; test_cleanup(); lang = get_or_create_locale("de"); - cb = (struct critbit_tree **)get_translations(lang, UT_PARAMS); - add_translation(cb, "TEMP", P_TEMP); + 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)); diff --git a/src/laws.test.c b/src/laws.test.c index bc8fa7247..5275d459e 100644 --- a/src/laws.test.c +++ b/src/laws.test.c @@ -329,7 +329,6 @@ static void test_reserve_cmd(CuTest *tc) { region *r; order *ord; const resource_type *rtype; - const struct locale *loc; test_cleanup(); test_create_world(); @@ -342,9 +341,7 @@ static void test_reserve_cmd(CuTest *tc) { u1 = test_create_unit(f, r); u2 = test_create_unit(f, r); assert(u1 && u2); - loc = get_locale("de"); - assert(loc); - ord = create_order(K_RESERVE, loc, "200 SILBER"); + ord = create_order(K_RESERVE, f->locale, "200 SILBER"); assert(ord); i_change(&u1->items, rtype->itype, 100); i_change(&u2->items, rtype->itype, 100); @@ -354,6 +351,68 @@ static void test_reserve_cmd(CuTest *tc) { test_cleanup(); } +struct pay_fixture { + unit *u1; + unit *u2; +}; + +static void setup_pay_cmd(struct pay_fixture *fix) { + faction *f; + region *r; + building *b; + + test_create_world(); + f = test_create_faction(NULL); + r = findregion(0, 0); + assert(r && f); + b = test_create_building(r, bt_get_or_create("lighthouse")); + assert(b); + fix->u1 = test_create_unit(f, r); + fix->u2 = test_create_unit(f, r); + assert(fix->u1 && fix->u2); + u_set_building(fix->u1, b); + u_set_building(fix->u2, b); + assert(building_owner(b) == fix->u1); + test_translate_param(f->locale, P_NOT, "NOT"); +} + +static void test_pay_cmd(CuTest *tc) { + struct pay_fixture fix; + order *ord; + faction *f; + building *b; + + test_cleanup(); + setup_pay_cmd(&fix); + b = fix.u1->building; + f = fix.u1->faction; + + ord = create_order(K_PAY, f->locale, "NOT"); + assert(ord); + CuAssertIntEquals(tc, 0, pay_cmd(fix.u1, ord)); + CuAssertIntEquals(tc, BLD_DONTPAY, b->flags&BLD_DONTPAY); + test_cleanup(); +} + +static void test_pay_cmd_must_be_owner(CuTest *tc) { + struct pay_fixture fix; + order *ord; + faction *f; + building *b; + + test_cleanup(); + setup_pay_cmd(&fix); + b = fix.u1->building; + f = fix.u1->faction; + + ord = create_order(K_PAY, f->locale, "NOT"); + assert(ord); + CuAssertIntEquals(tc, 0, pay_cmd(fix.u2, ord)); + CuAssertIntEquals(tc, 0, b->flags&BLD_DONTPAY); + test_cleanup(); +} + + static void test_new_units(CuTest *tc) { unit *u; faction *f; @@ -521,6 +580,8 @@ CuSuite *get_laws_suite(void) SUITE_ADD_TEST(suite, test_low_skill_cannot_guard); SUITE_ADD_TEST(suite, test_reserve_self); SUITE_ADD_TEST(suite, test_reserve_cmd); + SUITE_ADD_TEST(suite, test_pay_cmd); + SUITE_ADD_TEST(suite, test_pay_cmd_must_be_owner); SUITE_ADD_TEST(suite, test_new_units); SUITE_ADD_TEST(suite, test_cannot_create_unit_above_limit); SUITE_ADD_TEST(suite, test_contact); diff --git a/src/tests.c b/src/tests.c index db9bcbc69..7f7b73d75 100644 --- a/src/tests.c +++ b/src/tests.c @@ -132,6 +132,14 @@ item_type * test_create_itemtype(const char * name) { return itype; } +void test_translate_param(const struct locale *lang, param_t param, const char *text) { + struct critbit_tree **cb; + + assert(lang && text); + cb = (struct critbit_tree **)get_translations(lang, UT_PARAMS); + add_translation(cb, text, param); +} + /** creates a small world and some stuff in it. * two terrains: 'plain' and 'ocean' * one race: 'human' diff --git a/src/tests.h b/src/tests.h index a35b5acf3..5a565076f 100644 --- a/src/tests.h +++ b/src/tests.h @@ -1,6 +1,7 @@ #ifndef ERESSEA_TESTS_H #define ERESSEA_TESTS_H +#include #include #ifdef __cplusplus @@ -33,6 +34,7 @@ extern "C" { struct building_type *test_create_buildingtype(const char *name); int RunAllTests(void); + void test_translate_param(const struct locale *lang, param_t param, const char *text); #ifdef __cplusplus }