forked from github/server
fix compilation, add tests for upkeep
This commit is contained in:
parent
bed6cdff58
commit
0fcc1b8d29
3 changed files with 41 additions and 1 deletions
|
@ -681,6 +681,24 @@ static void test_get_modifier_cursed(CuTest *tc) {
|
|||
test_teardown();
|
||||
}
|
||||
|
||||
static void test_maintenance_cost(CuTest *tc) {
|
||||
unit *u;
|
||||
race *rc;
|
||||
test_setup();
|
||||
CuAssertIntEquals(tc, 10, maintenance_cost(NULL));
|
||||
u = test_create_unit(test_create_faction(), test_create_plain(0, 0));
|
||||
CuAssertIntEquals(tc, 10, maintenance_cost(u));
|
||||
u->number = 4;
|
||||
CuAssertIntEquals(tc, 40, maintenance_cost(u));
|
||||
rc = test_create_race("smurf");
|
||||
rc->maintenance = 15;
|
||||
u_setrace(u, rc);
|
||||
CuAssertIntEquals(tc, 60, maintenance_cost(u));
|
||||
u->faction->flags |= FFL_PAUSED;
|
||||
CuAssertIntEquals(tc, 0, maintenance_cost(u));
|
||||
test_teardown();
|
||||
}
|
||||
|
||||
static void test_gift_items(CuTest *tc) {
|
||||
unit *u, *u1, *u2;
|
||||
region *r;
|
||||
|
@ -770,5 +788,6 @@ CuSuite *get_unit_suite(void)
|
|||
SUITE_ADD_TEST(suite, test_get_modifier);
|
||||
SUITE_ADD_TEST(suite, test_get_modifier_cursed);
|
||||
SUITE_ADD_TEST(suite, test_gift_items);
|
||||
SUITE_ADD_TEST(suite, test_maintenance_cost);
|
||||
return suite;
|
||||
}
|
||||
|
|
|
@ -66,7 +66,7 @@ static void handle_faction(void *userData, int no, const char *password) {
|
|||
if (checkpasswd(f, password)) {
|
||||
state->f = f;
|
||||
f->lastorders = turn;
|
||||
freset(f, FFL_PAUSED);
|
||||
f->flags &= ~(FFL_PAUSED);
|
||||
}
|
||||
else {
|
||||
log_debug("invalid password for faction %s", itoa36(no));
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
#include <kernel/ally.h>
|
||||
#include <kernel/config.h>
|
||||
#include <kernel/faction.h>
|
||||
#include <kernel/race.h>
|
||||
#include <kernel/region.h>
|
||||
#include <kernel/unit.h>
|
||||
#include <kernel/item.h>
|
||||
|
@ -137,6 +138,25 @@ void test_upkeep_from_friend(CuTest * tc)
|
|||
test_teardown();
|
||||
}
|
||||
|
||||
void test_lifestyle(CuTest *tc)
|
||||
{
|
||||
unit *u;
|
||||
race *rc;
|
||||
|
||||
test_setup();
|
||||
u = test_create_unit(test_create_faction(), test_create_plain(0, 0));
|
||||
CuAssertIntEquals(tc, 10, lifestyle(u));
|
||||
u->number = 2;
|
||||
CuAssertIntEquals(tc, 20, lifestyle(u));
|
||||
rc = test_create_race("smurf");
|
||||
rc->maintenance = 15;
|
||||
u_setrace(u, rc);
|
||||
CuAssertIntEquals(tc, 30, lifestyle(u));
|
||||
u->faction->flags |= FFL_PAUSED;
|
||||
CuAssertIntEquals(tc, 0, lifestyle(u));
|
||||
test_teardown();
|
||||
}
|
||||
|
||||
void test_upkeep_free(CuTest * tc)
|
||||
{
|
||||
region *r;
|
||||
|
@ -168,5 +188,6 @@ CuSuite *get_upkeep_suite(void)
|
|||
SUITE_ADD_TEST(suite, test_upkeep_from_friend);
|
||||
SUITE_ADD_TEST(suite, test_upkeep_hunger_damage);
|
||||
SUITE_ADD_TEST(suite, test_upkeep_free);
|
||||
SUITE_ADD_TEST(suite, test_lifestyle);
|
||||
return suite;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue