add a test for default_order, so I can change it.

This commit is contained in:
Enno Rehling 2016-04-09 18:49:25 +02:00
parent 01ecc72f2d
commit 11ae7dd55e
5 changed files with 26 additions and 14 deletions

View file

@ -2332,7 +2332,7 @@ void do_attack(fighter * af)
if (apr > 0) {
/* Wenn die Waffe nachladen muss, oder es sich nicht um einen
* Waffen-Angriff handelt, dann gilt der Speed nicht. */
/* FIXME allow multiple AT_NATURAL attacks? */
/* TODO: allow multiple AT_NATURAL attacks? */
if (u_race(au)->attack[a].type != AT_STANDARD)
continue;
else {

View file

@ -1013,7 +1013,6 @@ void set_default_order(int kwd) {
// see also test_long_order_hungry
order *default_order(const struct locale *lang)
{
static int usedefault = 1;
int i = locale_index(lang);
order *result = 0;
assert(i < MAXLOCALES);
@ -1023,14 +1022,11 @@ order *default_order(const struct locale *lang)
}
result = defaults[i];
if (!result && usedefault) {
if (!result) {
const char * str = LOC(lang, "defaultorder");
if (str) {
result = defaults[i] = parse_order(str, lang);
}
else {
usedefault = 0;
}
}
return result ? copy_order(result) : 0;
}

View file

@ -172,6 +172,22 @@ static void test_forbiddenid(CuTest *tc) {
CuAssertIntEquals(tc, 1, forbiddenid(atoi36("t")));
}
static void test_default_order(CuTest *tc) {
order *ord;
struct locale * loc;
test_cleanup();
loc = test_create_locale();
ord = default_order(loc);
CuAssertPtrEquals(tc, 0, ord);
locale_setstring(loc, "defaultorder", "work");
ord = default_order(loc);
CuAssertPtrNotNull(tc, ord);
CuAssertIntEquals(tc, K_WORK, getkeyword(ord));
CuAssertPtrEquals(tc, ord->data, default_order(loc)->data);
test_cleanup();
}
CuSuite *get_config_suite(void)
{
CuSuite *suite = CuSuiteNew();
@ -181,5 +197,6 @@ CuSuite *get_config_suite(void)
SUITE_ADD_TEST(suite, test_forbiddenid);
SUITE_ADD_TEST(suite, test_getunit);
SUITE_ADD_TEST(suite, test_read_unitid);
SUITE_ADD_TEST(suite, test_default_order);
return suite;
}

View file

@ -511,7 +511,7 @@ static void json_prefixes(cJSON *json) {
}
/** disable a feature.
* features are identified by eone of:
* features are identified by one of:
* 1. the keyword for their orders,
* 2. the name of the skill they use,
* 3. a "module.enabled" flag in the settings
@ -525,13 +525,11 @@ static void disable_feature(const char *str) {
enable_skill(sk, false);
return;
}
for (k = 0; k != MAXKEYWORDS; ++k) {
// FIXME: this loop is slow as balls.
if (strcmp(keywords[k], str) == 0) {
log_debug("disable keyword %s\n", str);
enable_keyword(k, false);
return;
}
k = findkeyword(str);
if (k!=NOKEYWORD) {
log_debug("disable keyword %s\n", str);
enable_keyword(k, false);
return;
}
_snprintf(name, sizeof(name), "%s.enabled", str);
log_info("disable feature %s\n", name);

View file

@ -101,6 +101,7 @@ struct locale * test_create_locale(void) {
test_translate_param(loc, i, parameters[i]);
}
init_parameters(loc);
init_keywords(loc);
init_skills(loc);
}
return loc;