adding a lot of test coverage

extending the binding generation to more processing functions
This commit is contained in:
Enno Rehling 2012-06-07 09:47:02 -07:00
parent 8b3d735e8c
commit dafb2fc2ab
17 changed files with 242 additions and 59 deletions

7
scripts/default.lua Normal file → Executable file
View file

@ -26,7 +26,7 @@ function nmr_check(maxnmrs)
if nmrs >= maxnmrs then
print("Shit. More than " .. maxnmrs .. " factions with 1 NMR (" .. nmrs .. ")")
write_summary()
write_game("aborted.dat")
eressea.write_game("aborted.dat")
return -1
end
print (nmrs .. " Factions with 1 NMR")
@ -35,10 +35,7 @@ end
function open_game(turn)
file = "" .. get_turn()
if read_game(file .. ".dat", "binary")~=0 then
return read_game(file, "text")
end
return 0
return eressea.read_game(file .. ".dat")
end
function write_emails(locales)

2
scripts/init.lua Normal file → Executable file
View file

@ -8,7 +8,7 @@ function run_editor()
turn = read_turn()
set_turn(turn)
end
read_game(turn .. ".dat")
eressea.read_game(turn .. ".dat")
gmtool.editor()
end

28
scripts/tests/bindings.lua Executable file
View file

@ -0,0 +1,28 @@
require "lunit"
local eressea = eressea
local _G = _G
module("tests.bindings", lunit.testcase)
function test_eressea()
assert_equal("function", _G.type(eressea.free_game))
assert_equal("function", _G.type(eressea.read_game))
assert_equal("function", _G.type(eressea.write_game))
assert_equal("function", _G.type(eressea.read_orders))
end
function test_process()
assert_equal("function", _G.type(eressea.process.markets))
assert_equal("function", _G.type(eressea.process.produce))
assert_equal("function", _G.type(eressea.process.make_temp))
assert_equal("function", _G.type(eressea.process.settings))
assert_equal("function", _G.type(eressea.process.set_group))
assert_equal("function", _G.type(eressea.process.set_origin))
assert_equal("function", _G.type(eressea.process.quit))
end
function test_settings()
assert_equal("function", _G.type(eressea.settings.set))
assert_equal("function", _G.type(eressea.settings.get))
end

View file

@ -912,7 +912,7 @@ function test_parser()
file:write("BENENNEN EINHEIT 'Goldene Herde'\n")
file:close()
read_orders(filename)
eressea.read_orders(filename)
process_orders()
assert_equal("Goldene Herde", u.name)
end
@ -975,7 +975,7 @@ function test_bug_1814()
file:write("; ARBEITE\n")
file:close()
read_orders(filename)
eressea.read_orders(filename)
process_orders()
init_reports()
write_report(f)
@ -996,7 +996,7 @@ function test_bug_1679()
file:write("ARBEITEN\n")
file:close()
read_orders(filename)
eressea.read_orders(filename)
process_orders()
init_reports()
write_report(f)
@ -1103,7 +1103,7 @@ function test_bug_1875_use_normal()
local r = region.create(0, 0, "plain")
r:set_resource("peasant", 0)
settings.set("rules.economy.food", "0") -- food is not free
eressea.settings.set("rules.economy.food", "0") -- food is not free
local f = faction.create("noreply@eressea.de", "demon", "de")
local u = unit.create(f, r, 1)
@ -1126,7 +1126,7 @@ function test_bug_1875_use_help()
local r = region.create(0, 0, "plain")
r:set_resource("peasant", 0)
settings.set("rules.economy.food", "0") -- food is not free
eressea.settings.set("rules.economy.food", "0") -- food is not free
local f = faction.create("noreply@eressea.de", "demon", "de")
local u = unit.create(f, r, 1)
@ -1153,7 +1153,7 @@ function test_bug_1875_use_own_first()
local r = region.create(0, 0, "plain")
r:set_resource("peasant", 0)
settings.set("rules.economy.food", "0") -- food is not free
eressea.settings.set("rules.economy.food", "0") -- food is not free
local f = faction.create("noreply@eressea.de", "demon", "de")
local u = unit.create(f, r, 1)

View file

@ -33,3 +33,75 @@ function test_give()
assert_not_equal(5, u:get_item("money"))
assert_not_equal(5, u2:get_item("money"))
end
function test_make_temp()
u:add_order("MACHE TEMP 123 'Herpderp'")
u:add_order("// this comment will be copied")
u:add_order("ENDE")
eressea.process.make_temp()
for x in f.units do
if x.name == 'Herpderp' then u=x end
end
assert_equal('Herpderp', u.name)
assert_equal(0, u.number)
local c = 0
for o in u.orders do
assert_equal('// this comment will be copied', o)
c = c + 1
end
assert_equal(1, c)
end
function test_give_temp()
u.number = 2
u:add_order("GIB TEMP 123 1 PERSON")
u:add_order("MACHE TEMP 123 'Herpderp'")
u:add_order("ENDE")
_G.process_orders()
assert_equal(1, u.number)
for x in f.units do
if x.name == 'Herpderp' then u=x end
end
assert_equal('Herpderp', u.name)
assert_equal(1, u.number)
end
function test_process_settings()
f.options = 0
u:add_order("EMAIL herp@derp.com")
u:add_order("BANNER 'Herpderp'")
u:add_order("PASSWORT 'HerpDerp'")
u:add_order("OPTION AUSWERTUNG")
eressea.process.settings()
assert_equal("herp@derp.com", f.email)
assert_equal("Herpderp", f.info)
assert_equal("HerpDerp", f.password)
assert_equal(1, f.options)
end
function test_process_group()
u:add_order("GRUPPE herp")
eressea.process.set_group()
assert_equal('herp', u.group)
end
function test_process_origin()
u:add_order("URSPRUNG 1 2")
eressea.process.set_origin()
x, y = u.faction:get_origin()
assert_equal(1, x)
assert_equal(2, y)
end
function test_process_quit()
fno = f.id
u:add_order("STIRB '" .. u.faction.password .. "'")
assert_not_equal(nil, _G.get_faction(fno))
eressea.process.quit()
eressea.write_game('test.dat')
eressea.free_game()
eressea.read_game('test.dat')
assert_equal(nil, _G.get_faction(fno))
end

View file

@ -15,5 +15,10 @@ int eressea_read_game(const char * filename) {
}
int eressea_write_game(const char * filename) {
remove_empty_factions();
return writegame(filename, IO_BINARY);
}
int eressea_read_orders(const char * filename) {
return readorders(filename);
}

View file

@ -7,6 +7,7 @@ extern "C" {
void eressea_free_game(void);
int eressea_read_game(const char * filename);
int eressea_write_game(const char * filename);
int eressea_read_orders(const char * filename);
#ifdef __cplusplus
}

View file

@ -2,8 +2,11 @@
#include <platform.h>
#include <kernel/types.h>
#include <kernel/order.h>
#include <kernel/region.h>
#include <kernel/unit.h>
#include <gamecode/economy.h>
#include <gamecode/laws.h>
#include <gamecode/market.h>
void process_produce(void) {
@ -16,3 +19,61 @@ void process_produce(void) {
void process_markets(void) {
do_markets();
}
void process_make_temp(void) {
new_units();
}
void process_settings(void) {
region * r;
for (r=regions; r; r=r->next) {
unit * u;
for (u=r->units; u; u=u->next) {
order * ord;
for (ord=u->orders; ord; ord=ord->next) {
keyword_t kwd = get_keyword(ord);
if (kwd==K_BANNER) {
banner_cmd(u, ord);
}
else if (kwd==K_EMAIL) {
email_cmd(u, ord);
}
else if (kwd==K_SEND) {
send_cmd(u, ord);
}
else if (kwd==K_PASSWORD) {
password_cmd(u, ord);
}
}
}
}
}
static void process_cmd(keyword_t kwd, int (*callback)(unit *, order *))
{
region * r;
for (r=regions; r; r=r->next) {
unit * u;
for (u=r->units; u; u=u->next) {
order * ord;
for (ord=u->orders; ord; ord=ord->next) {
if (kwd == get_keyword(ord)) {
callback(u, ord);
}
}
}
}
}
void process_group(void) {
process_cmd(K_GROUP, group_cmd);
}
void process_origin(void) {
process_cmd(K_URSPRUNG, origin_cmd);
}
void process_quit(void) {
process_cmd(K_QUIT, quit_cmd);
quit();
}

View file

@ -6,6 +6,11 @@ extern "C" {
void process_produce(void);
void process_markets(void);
void process_make_temp(void);
void process_settings(void);
void process_group(void);
void process_origin(void);
void process_quit(void);
#ifdef __cplusplus
}

26
src/bindings/bind_unit.c Normal file → Executable file
View file

@ -28,6 +28,7 @@ without prior permission by the authors of Eressea.
#include <kernel/building.h>
#include <kernel/config.h>
#include <kernel/faction.h>
#include <kernel/group.h>
#include <kernel/item.h>
#include <kernel/magic.h>
#include <kernel/message.h>
@ -141,6 +142,25 @@ int tolua_unitlist_next(lua_State * L)
return 0; /* no more values to return */
}
static int tolua_unit_get_group(lua_State * L)
{
unit *u = (unit *) tolua_tousertype(L, 1, 0);
group *g = get_group(u);
if (g) {
tolua_pushstring(L, g->name);
return 1;
}
return 0;
}
static int tolua_unit_set_group(lua_State * L)
{
unit *self = (unit *) tolua_tousertype(L, 1, 0);
int result = join_group(self, tolua_tostring(L, 2, 0));
tolua_pushnumber(L, result);
return 1;
}
static int tolua_unit_get_name(lua_State * L)
{
unit *self = (unit *) tolua_tousertype(L, 1, 0);
@ -936,9 +956,9 @@ void tolua_unit_open(lua_State * L)
tolua_unit_set_name);
tolua_variable(L, TOLUA_CAST "faction", &tolua_unit_get_faction,
tolua_unit_set_faction);
tolua_variable(L, TOLUA_CAST "id", &tolua_unit_get_id, tolua_unit_set_id);
tolua_variable(L, TOLUA_CAST "info", &tolua_unit_get_info,
tolua_unit_set_info);
tolua_variable(L, TOLUA_CAST "id", tolua_unit_get_id, tolua_unit_set_id);
tolua_variable(L, TOLUA_CAST "group", tolua_unit_get_group, tolua_unit_set_group);
tolua_variable(L, TOLUA_CAST "info", tolua_unit_get_info, tolua_unit_set_info);
tolua_variable(L, TOLUA_CAST "hp", &tolua_unit_get_hp, tolua_unit_set_hp);
tolua_variable(L, TOLUA_CAST "status", &tolua_unit_get_status,
tolua_unit_set_status);

View file

@ -540,12 +540,6 @@ static int tolua_write_summary(lua_State * L)
return 0;
}
static int tolua_free_game(lua_State * L)
{
free_gamedata();
return 0;
}
static int tolua_write_map(lua_State * L)
{
const char *filename = tolua_tostring(L, 1, 0);
@ -555,31 +549,6 @@ static int tolua_write_map(lua_State * L)
return 0;
}
static int tolua_write_game(lua_State * L)
{
const char *filename = tolua_tostring(L, 1, 0);
const char *mode = tolua_tostring(L, 2, 0);
int result, m = IO_BINARY;
if (mode && strcmp(mode, "text") == 0)
m = IO_TEXT;
remove_empty_factions();
result = writegame(filename, m);
tolua_pushnumber(L, (lua_Number) result);
return 1;
}
static int tolua_read_game(lua_State * L)
{
const char *filename = tolua_tostring(L, 1, 0);
const char *mode = tolua_tostring(L, 2, 0);
int rv, m = IO_BINARY;
if (mode && strcmp(mode, "text") == 0)
m = IO_TEXT;
rv = readgame(filename, m, false);
tolua_pushnumber(L, (lua_Number) rv);
return 1;
}
static int tolua_read_turn(lua_State * L)
{
int cturn = current_turn();
@ -1208,9 +1177,6 @@ int tolua_bindings_open(lua_State * L)
tolua_function(L, TOLUA_CAST "factions", tolua_get_factions);
tolua_function(L, TOLUA_CAST "regions", tolua_get_regions);
tolua_function(L, TOLUA_CAST "read_turn", tolua_read_turn);
tolua_function(L, TOLUA_CAST "read_game", tolua_read_game);
tolua_function(L, TOLUA_CAST "write_game", tolua_write_game);
tolua_function(L, TOLUA_CAST "free_game", tolua_free_game);
tolua_function(L, TOLUA_CAST "write_map", &tolua_write_map);
tolua_function(L, TOLUA_CAST "read_orders", tolua_read_orders);
tolua_function(L, TOLUA_CAST "process_orders", tolua_process_orders);

View file

@ -4,4 +4,5 @@ module eressea {
void eressea_free_game @ free_game(void);
int eressea_read_game @ read_game(const char * filename);
int eressea_write_game @ write_game(const char * filename);
int eressea_read_orders @ read_orders(const char * filename);
}

View file

@ -4,5 +4,10 @@ module eressea {
module process {
void process_markets @ markets(void);
void process_produce @ produce(void);
void process_make_temp @ make_temp(void);
void process_settings @ settings(void);
void process_group @ set_group(void);
void process_origin @ set_origin(void);
void process_quit @ quit(void);
}
}

20
src/gamecode/laws.c Normal file → Executable file
View file

@ -1117,7 +1117,7 @@ static boolean EnhancedQuit(void)
return value;
}
static int quit_cmd(unit * u, struct order *ord)
int quit_cmd(unit * u, struct order *ord)
{
faction *f = u->faction;
const char *passwd;
@ -1159,7 +1159,7 @@ static int quit_cmd(unit * u, struct order *ord)
return 0;
}
static void quit(void)
void quit(void)
{
faction **fptr = &factions;
while (*fptr) {
@ -2107,7 +2107,7 @@ static int mail_cmd(unit * u, struct order *ord)
/* ------------------------------------------------------------- */
static int banner_cmd(unit * u, struct order *ord)
int banner_cmd(unit * u, struct order *ord)
{
init_tokens(ord);
skip_token();
@ -2120,7 +2120,7 @@ static int banner_cmd(unit * u, struct order *ord)
return 0;
}
static int email_cmd(unit * u, struct order *ord)
int email_cmd(unit * u, struct order *ord)
{
const char *s;
@ -2142,7 +2142,7 @@ static int email_cmd(unit * u, struct order *ord)
return 0;
}
static int password_cmd(unit * u, struct order *ord)
int password_cmd(unit * u, struct order *ord)
{
char pwbuf[32];
int i;
@ -2182,7 +2182,7 @@ static int password_cmd(unit * u, struct order *ord)
return 0;
}
static int send_cmd(unit * u, struct order *ord)
int send_cmd(unit * u, struct order *ord)
{
const char *s;
int option;
@ -2516,7 +2516,7 @@ static int promotion_cmd(unit * u, struct order *ord)
return 0;
}
static int group_cmd(unit * u, struct order *ord)
int group_cmd(unit * u, struct order *ord)
{
const char *s;
@ -2528,7 +2528,7 @@ static int group_cmd(unit * u, struct order *ord)
return 0;
}
static int origin_cmd(unit * u, struct order *ord)
int origin_cmd(unit * u, struct order *ord)
{
short px, py;
@ -3291,7 +3291,7 @@ int checkunitnumber(const faction * f, int add)
return 0;
}
static void new_units(void)
void new_units(void)
{
region *r;
unit *u, *u2;
@ -4154,7 +4154,7 @@ void init_processor(void)
p += 10;
add_proc_unit(p, &setdefaults, "Default-Befehle");
add_proc_order(p, K_BANNER, &banner_cmd, 0, NULL);
add_proc_order(p, K_BANNER, banner_cmd, 0, NULL);
add_proc_order(p, K_EMAIL, &email_cmd, 0, NULL);
add_proc_order(p, K_PASSWORD, &password_cmd, 0, NULL);
add_proc_order(p, K_SEND, &send_cmd, 0, NULL);

10
src/gamecode/laws.h Normal file → Executable file
View file

@ -45,6 +45,16 @@ extern "C" {
extern int dropouts[2];
extern int *age;
extern void new_units(void);
extern void quit(void);
extern int password_cmd(struct unit *u, struct order *ord);
extern int banner_cmd(struct unit *u, struct order *ord);
extern int email_cmd(struct unit *u, struct order *ord);
extern int send_cmd(struct unit *u, struct order *ord);
extern int origin_cmd(struct unit *u, struct order *ord);
extern int group_cmd(struct unit *u, struct order *ord);
extern int quit_cmd(struct unit *u, struct order *ord);
#ifdef __cplusplus
}
#endif

11
src/kernel/group.c Normal file → Executable file
View file

@ -136,6 +136,17 @@ void free_group(group * g)
free(g);
}
group * get_group(const struct unit *u)
{
if (fval(u, UFL_GROUP)) {
attrib * a = a_find(u->attribs, &at_group);
if (a) {
return (group *) a->data.v;
}
}
return 0;
}
void set_group(struct unit *u, struct group *g)
{
attrib *a = NULL;

1
src/kernel/group.h Normal file → Executable file
View file

@ -40,6 +40,7 @@ extern "C" {
extern struct attrib_type at_group; /* attribute for units assigned to a group */
extern boolean join_group(struct unit *u, const char *name);
extern void set_group(struct unit *u, struct group *g);
extern struct group * get_group(const struct unit *u);
extern void free_group(struct group *g);
extern void write_groups(struct storage *F, struct group *g);