added tests to make sure volcanooutbreak and spyreport are no longer empty messages.

This commit is contained in:
Enno Rehling 2015-02-22 22:31:50 +01:00
parent d637571a52
commit b68e2a983e
2 changed files with 41 additions and 0 deletions

View file

@ -779,3 +779,26 @@ function test_weightless_silver()
u1:add_item("money", 540)
assert_equal(1000, u1.weight)
end
function test_spyreport_message()
local r1 = region.create(1, 2, "plain")
local f1 = faction.create("noreply@eressea.de", "human", "de")
local u1 = unit.create(f1, r1, 1)
local u2 = unit.create(f1, r1, 1)
msg = message.create("spyreport")
msg:set_unit("spy", u1)
msg:set_unit("target", u2)
msg:set_string("status", "hodor")
assert_not_equal("", msg:render("de"))
assert_not_equal("", msg:render("en"))
end
function test_volcanooutbreak_message()
local r1 = region.create(1, 0, "plain")
local r2 = region.create(1, 1, "plain")
msg = message.create("volcanooutbreak")
msg:set_region("regionn", r1)
msg:set_region("regionv", r2)
assert_not_equal("", msg:render("de"))
assert_not_equal("", msg:render("en"))
end

View file

@ -11,7 +11,9 @@
#include <kernel/unit.h>
/* util includes */
#include <util/language.h>
#include <util/message.h>
#include <util/nrmessage.h>
/* lua includes */
#include <tolua.h>
@ -307,6 +309,21 @@ static int tolua_msg_send_faction(lua_State * L)
return 0;
}
static int tolua_msg_render(lua_State * L)
{
lua_message *lmsg = (lua_message *)tolua_tousertype(L, 1, 0);
const char * lname = tolua_tostring(L, 2, 0);
const struct locale * lang = lname ? get_locale(lname) : default_locale;
char name[64];
if (lmsg->msg == NULL) {
lmsg->msg = msg_create(lmsg->mtype, lmsg->args);
}
nr_render(lmsg->msg, lang, name, sizeof(name), NULL);
lua_pushstring(L, name);
return 1;
}
void tolua_message_open(lua_State * L)
{
/* register user types */
@ -321,6 +338,7 @@ void tolua_message_open(lua_State * L)
NULL);
tolua_beginmodule(L, TOLUA_CAST "message");
{
tolua_function(L, TOLUA_CAST "render", tolua_msg_render);
tolua_function(L, TOLUA_CAST "set", tolua_msg_set);
tolua_function(L, TOLUA_CAST "set_unit", tolua_msg_set_unit);
tolua_function(L, TOLUA_CAST "set_region", tolua_msg_set_region);