new test: verify that units swim after terraforming, and can get picked up by boats in the turn thereafter.

This commit is contained in:
Enno Rehling 2010-10-31 19:34:55 -07:00
parent 321c0816f6
commit 101ff092d5

View file

@ -2,6 +2,8 @@ require "lunit"
function setup()
free_game()
settings.set("nmr.removenewbie", "0")
settings.set("nmr.timeout", "0")
settings.set("rules.economy.food", "4")
end
@ -18,9 +20,7 @@ end
function two_factions()
local f1 = faction.create("noreply@eressea.de", "human", "de")
f1.id = 1
local f2 = faction.create("noreply@eressea.de", "orc", "de")
f2.id = 2
return f1, f2
end
@ -371,7 +371,6 @@ function test_work()
free_game()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
f.id = 42
local u = unit.create(f, r, 1)
u:add_item("money", u.number * 10) -- humans cost 10
u:set_skill("herbalism", 5)
@ -385,7 +384,6 @@ function test_upkeep()
free_game()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
f.id = 42
local u = unit.create(f, r, 5)
u:add_item("money", u.number * 11)
u:clear_orders()
@ -430,7 +428,6 @@ function test_herbalism()
free_game()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
f.id = 42
local u = unit.create(f, r, 1)
u:add_item("money", u.number * 100)
u:set_skill("herbalism", 5)
@ -524,12 +521,12 @@ function test_control()
assert_equal(u2, b.owner)
end
function test_storage()
function test_store_unit()
free_game()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
f.id = 42
local u = unit.create(f, r, 1)
local fid = f.id
u:add_item("money", u.number * 100)
store = storage.create("test.unit.dat", "wb")
assert_not_equal(store, nil)
@ -539,7 +536,7 @@ function test_storage()
-- recreate world:
r = region.create(0, 0, "plain")
f = faction.create("noreply@eressea.de", "human", "de")
f.id = 42
f.id = fid
store = storage.create("test.unit.dat", "rb")
assert(store)
u = store:read_unit()
@ -678,3 +675,33 @@ function test_food_can_override()
process_orders()
assert_equal(90, u:get_item("money"))
end
function test_swim_and_survive()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
f.nam = "chaos"
local u = unit.create(f, r, 1)
f.age = 20
u:add_item("money", 100)
process_orders()
r.terrain = "ocean"
local s = ship.create(r, "boat")
u:clear_orders()
u:add_order("BETRETE SCHIFF " .. itoa36(s.id))
process_orders()
assert_equal(u.number, 1)
end
function test_swim_and_die()
local r = region.create(0, 0, "plain")
local f = faction.create("noreply@eressea.de", "human", "de")
local u = unit.create(f, r, 1)
local uid = u.id
u:add_item("money", 100)
process_orders()
r.terrain = "ocean"
u = get_unit(uid)
assert_not_equal(get_unit(uid), nil)
process_orders()
assert_equal(get_unit(uid), nil)
end