clean up item tests so they don't use test_create_world

fix intermittent skillpotion test
This commit is contained in:
Enno Rehling 2015-11-07 13:52:18 +01:00
parent d29429f309
commit 2f8dc29396
3 changed files with 22 additions and 20 deletions

View file

@ -33,17 +33,17 @@ static void test_skillpotion(CuTest *tc) {
learn_skill(u, SK_ENTERTAINMENT, 1.0);
pSkill = unit_skill(u, SK_ENTERTAINMENT);
sk_set(pSkill, 5);
initialWeeks_Entertainment = pSkill->weeks;
initialWeeks_Entertainment = pSkill->weeks = 4;
learn_skill(u, SK_STAMINA, 1.0);
pSkill = unit_skill(u, SK_STAMINA);
sk_set(pSkill, 5);
initialWeeks_Stamina = pSkill->weeks;
initialWeeks_Stamina = pSkill->weeks = 4;
learn_skill(u, SK_MAGIC, 1.0);
pSkill = unit_skill(u, SK_MAGIC);
sk_set(pSkill, 5);
initialWeeks_Magic = pSkill->weeks;
initialWeeks_Magic = pSkill->weeks = 4;
CuAssertIntEquals(tc, 1, use_skillpotion(u, itype, 1, NULL));

View file

@ -45,6 +45,8 @@ static void test_resourcename_with_appearance(CuTest *tc) {
static void test_uchange(CuTest * tc, unit * u, const resource_type * rtype) {
int n;
assert(rtype);
change_resource(u, rtype, 4);
n = get_resource(u, rtype);
CuAssertPtrNotNull(tc, rtype->uchange);
@ -59,8 +61,8 @@ void test_change_item(CuTest * tc)
unit * u;
test_cleanup();
test_create_itemtype("iron");
init_resources();
test_create_world();
u = test_create_unit(0, 0);
test_uchange(tc, u, get_resourcetype(R_IRON));
@ -79,43 +81,41 @@ void test_resource_type(CuTest * tc)
itype = test_create_itemtype("herp");
CuAssertPtrEquals(tc, itype->rtype, rt_find("herp"));
test_cleanup();
}
void test_finditemtype(CuTest * tc)
{
const item_type *itype;
const resource_type *rtype;
struct locale * lang;
test_cleanup();
test_create_world();
lang = get_locale("de");
lang = get_or_create_locale("de");
locale_setstring(lang, "horse", "Pferd");
rtype = get_resourcetype(R_HORSE);
itype = finditemtype("Pferd", lang);
CuAssertPtrNotNull(tc, itype);
CuAssertPtrEquals(tc, (void*)rtype->itype, (void*)itype);
itype = test_create_itemtype("horse");
CuAssertPtrEquals(tc, (void *)itype, (void *)finditemtype("Pferd", lang));
test_cleanup();
}
void test_findresourcetype(CuTest * tc)
{
const resource_type *rtype, *rresult;
const item_type *itype;
struct locale * lang;
test_cleanup();
test_create_world();
lang = get_locale("de");
lang = get_or_create_locale("de");
locale_setstring(lang, "horse", "Pferd");
locale_setstring(lang, "peasant", "Bauer");
init_resources();
CuAssertPtrNotNull(tc, rt_find("peasant"));
CuAssertPtrEquals(tc, 0, rt_find("horse"));
itype = test_create_itemtype("horse");
rtype = get_resourcetype(R_HORSE);
rresult = findresourcetype("Pferd", lang);
CuAssertPtrNotNull(tc, rresult);
CuAssertPtrEquals(tc, (void*)rtype, (void*)rresult);
CuAssertPtrNotNull(tc, findresourcetype("Bauer", lang));
CuAssertPtrEquals(tc, (void*)itype->rtype, (void*)findresourcetype("Pferd", lang));
CuAssertPtrEquals(tc, (void *)rt_find("peasant"), (void *)findresourcetype("Bauer", lang));
test_cleanup();
}
#include <modules/autoseed.h>

View file

@ -68,6 +68,8 @@ int change_resource(unit * u, const resource_type * rtype, int change)
{
int i = 0;
assert(rtype);
if (rtype->uchange)
i = rtype->uchange(u, rtype, change);
else if (rtype == get_resourcetype(R_AURA))