2012-05-17 09:13:30 +02:00
|
|
|
#include <platform.h>
|
|
|
|
|
2012-05-18 00:23:15 +02:00
|
|
|
#include <kernel/config.h>
|
2012-05-17 09:13:30 +02:00
|
|
|
#include <kernel/race.h>
|
|
|
|
#include <kernel/region.h>
|
|
|
|
#include <kernel/ship.h>
|
|
|
|
#include <kernel/unit.h>
|
2015-08-07 11:50:49 +02:00
|
|
|
#include <kernel/curse.h>
|
|
|
|
|
|
|
|
#include <util/attrib.h>
|
|
|
|
|
|
|
|
#include <spells/shipcurse.h>
|
|
|
|
#include <attributes/movement.h>
|
2012-05-17 09:13:30 +02:00
|
|
|
|
2012-05-31 04:17:08 +02:00
|
|
|
#include <CuTest.h>
|
2012-05-17 09:13:30 +02:00
|
|
|
#include <tests.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2015-08-07 09:03:19 +02:00
|
|
|
#include <assert.h>
|
2012-05-17 09:13:30 +02:00
|
|
|
|
|
|
|
static void test_register_ship(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
ship_type *stype;
|
2012-05-17 09:13:30 +02:00
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2012-05-17 09:13:30 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
stype = st_get_or_create("herp");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
CuAssertPtrEquals(tc, stype, (void *)st_find("herp"));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 09:13:30 +02:00
|
|
|
}
|
|
|
|
|
2012-05-17 21:23:25 +02:00
|
|
|
static void test_ship_set_owner(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u1, *u2;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
stype = st_find("boat");
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
u1 = test_create_unit(f, r);
|
|
|
|
u_set_ship(u1, sh);
|
|
|
|
CuAssertPtrEquals(tc, u1, ship_owner(sh));
|
|
|
|
|
|
|
|
u2 = test_create_unit(f, r);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
CuAssertPtrEquals(tc, u1, ship_owner(sh));
|
|
|
|
ship_set_owner(u2);
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 21:23:25 +02:00
|
|
|
}
|
|
|
|
|
2012-05-19 08:20:38 +02:00
|
|
|
static void test_shipowner_goes_to_next_when_empty(CuTest * tc)
|
2012-05-17 09:13:30 +02:00
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u = test_create_unit(f, r);
|
|
|
|
u2 = test_create_unit(f, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
u->number = 0;
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 09:25:47 +02:00
|
|
|
}
|
|
|
|
|
2012-05-19 08:20:38 +02:00
|
|
|
static void test_shipowner_goes_to_other_when_empty(CuTest * tc)
|
2012-05-17 10:14:43 +02:00
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u2 = test_create_unit(f, r);
|
|
|
|
u = test_create_unit(f, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
u->number = 0;
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 10:14:43 +02:00
|
|
|
}
|
|
|
|
|
2012-05-19 08:20:38 +02:00
|
|
|
static void test_shipowner_goes_to_same_faction_when_empty(CuTest * tc)
|
2012-05-17 10:14:43 +02:00
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2, *u3;
|
|
|
|
struct faction *f1, *f2;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f1 = test_create_faction(human);
|
|
|
|
f2 = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u2 = test_create_unit(f2, r);
|
|
|
|
u3 = test_create_unit(f1, r);
|
|
|
|
u = test_create_unit(f1, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
u_set_ship(u3, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
u->number = 0;
|
|
|
|
CuAssertPtrEquals(tc, u3, ship_owner(sh));
|
|
|
|
u3->number = 0;
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 10:14:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipowner_goes_to_next_after_leave(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u = test_create_unit(f, r);
|
|
|
|
u2 = test_create_unit(f, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
leave_ship(u);
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 10:14:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipowner_goes_to_other_after_leave(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u2 = test_create_unit(f, r);
|
|
|
|
u = test_create_unit(f, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
leave_ship(u);
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 10:14:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipowner_goes_to_same_faction_after_leave(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u, *u2, *u3;
|
|
|
|
struct faction *f1, *f2;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f1 = test_create_faction(human);
|
|
|
|
f2 = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u2 = test_create_unit(f2, r);
|
|
|
|
u3 = test_create_unit(f1, r);
|
|
|
|
u = test_create_unit(f1, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
u_set_ship(u3, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
leave_ship(u);
|
|
|
|
CuAssertPtrEquals(tc, u3, ship_owner(sh));
|
|
|
|
leave_ship(u3);
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
|
|
|
leave_ship(u2);
|
|
|
|
CuAssertPtrEquals(tc, 0, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 10:14:43 +02:00
|
|
|
}
|
|
|
|
|
2012-05-19 08:20:38 +02:00
|
|
|
static void test_shipowner_resets_when_empty(CuTest * tc)
|
2012-05-17 09:25:47 +02:00
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u;
|
|
|
|
struct faction *f;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u = test_create_unit(f, r);
|
|
|
|
CuAssertPtrNotNull(tc, u);
|
|
|
|
u_set_ship(u, sh);
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
|
|
|
u->number = 0;
|
|
|
|
CuAssertPtrEquals(tc, 0, ship_owner(sh));
|
|
|
|
u->number = 1;
|
|
|
|
CuAssertPtrEquals(tc, u, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-19 08:20:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void test_shipowner_goes_to_empty_unit_after_leave(CuTest * tc)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
struct region *r;
|
|
|
|
struct ship *sh;
|
|
|
|
struct unit *u1, *u2, *u3;
|
|
|
|
struct faction *f1;
|
|
|
|
const struct ship_type *stype;
|
|
|
|
const struct race *human;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-01-30 20:37:14 +01:00
|
|
|
test_create_world();
|
|
|
|
|
|
|
|
human = rc_find("human");
|
|
|
|
CuAssertPtrNotNull(tc, human);
|
|
|
|
|
|
|
|
stype = st_find("boat");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
|
|
|
|
f1 = test_create_faction(human);
|
|
|
|
r = findregion(0, 0);
|
|
|
|
|
|
|
|
sh = test_create_ship(r, stype);
|
|
|
|
CuAssertPtrNotNull(tc, sh);
|
|
|
|
|
|
|
|
u1 = test_create_unit(f1, r);
|
|
|
|
u2 = test_create_unit(f1, r);
|
|
|
|
u3 = test_create_unit(f1, r);
|
|
|
|
u_set_ship(u1, sh);
|
|
|
|
u_set_ship(u2, sh);
|
|
|
|
u_set_ship(u3, sh);
|
|
|
|
|
|
|
|
CuAssertPtrEquals(tc, u1, ship_owner(sh));
|
|
|
|
u2->number = 0;
|
|
|
|
leave_ship(u1);
|
|
|
|
CuAssertPtrEquals(tc, u3, ship_owner(sh));
|
|
|
|
leave_ship(u3);
|
|
|
|
CuAssertPtrEquals(tc, 0, ship_owner(sh));
|
|
|
|
u2->number = 1;
|
|
|
|
CuAssertPtrEquals(tc, u2, ship_owner(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2012-05-17 09:13:30 +02:00
|
|
|
}
|
|
|
|
|
2015-02-03 17:10:29 +01:00
|
|
|
static void test_stype_defaults(CuTest *tc) {
|
|
|
|
ship_type *stype;
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-02-03 17:10:29 +01:00
|
|
|
stype = st_get_or_create("hodor");
|
|
|
|
CuAssertPtrNotNull(tc, stype);
|
|
|
|
CuAssertStrEquals(tc, "hodor", stype->_name);
|
|
|
|
CuAssertPtrEquals(tc, 0, stype->construction);
|
|
|
|
CuAssertPtrEquals(tc, 0, stype->coasts);
|
|
|
|
CuAssertDblEquals(tc, 0.0, stype->damage, 0.0);
|
|
|
|
CuAssertDblEquals(tc, 1.0, stype->storm, 0.0);
|
|
|
|
CuAssertDblEquals(tc, 0.0, stype->tac_bonus, 0.0);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->cabins);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->cargo);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->combat);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->fishing);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->range);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->cptskill);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->minskill);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->sumskill);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->at_bonus);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->df_bonus);
|
|
|
|
CuAssertIntEquals(tc, 0, stype->flags);
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-02-03 17:10:29 +01:00
|
|
|
}
|
|
|
|
|
2015-08-07 09:03:19 +02:00
|
|
|
static void test_crew_skill(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
region *r;
|
|
|
|
struct faction *f;
|
|
|
|
int i;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 09:03:19 +02:00
|
|
|
test_create_world();
|
2017-12-27 19:58:39 +01:00
|
|
|
r = test_create_region(0, 0, NULL);
|
2015-08-07 09:03:19 +02:00
|
|
|
f = test_create_faction(0);
|
|
|
|
assert(r && f);
|
|
|
|
sh = test_create_ship(r, st_find("boat"));
|
|
|
|
for (i = 0; i != 4; ++i) {
|
|
|
|
unit * u = test_create_unit(f, r);
|
|
|
|
set_level(u, SK_SAILING, 5);
|
|
|
|
u->ship = sh;
|
|
|
|
}
|
|
|
|
CuAssertIntEquals(tc, 20, crew_skill(sh));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 09:03:19 +02:00
|
|
|
}
|
|
|
|
|
2015-08-07 11:50:49 +02:00
|
|
|
static ship *setup_ship(void) {
|
2015-08-07 09:03:19 +02:00
|
|
|
region *r;
|
2015-08-07 11:50:49 +02:00
|
|
|
ship_type *stype;
|
2015-08-07 09:03:19 +02:00
|
|
|
|
2015-11-22 10:33:31 +01:00
|
|
|
config_set("movement.shipspeed.skillbonus", "0");
|
2015-08-07 09:03:19 +02:00
|
|
|
r = test_create_region(0, 0, test_create_terrain("ocean", 0));
|
|
|
|
stype = test_create_shiptype("longboat");
|
|
|
|
stype->cptskill = 1;
|
|
|
|
stype->sumskill = 10;
|
|
|
|
stype->minskill = 1;
|
|
|
|
stype->range = 2;
|
2015-07-23 16:10:13 +02:00
|
|
|
stype->range_max = 4;
|
2015-08-07 09:03:19 +02:00
|
|
|
return test_create_ship(r, stype);
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void setup_crew(ship *sh, struct faction *f, unit **cap, unit **crew) {
|
|
|
|
if (!f) f = test_create_faction(0);
|
|
|
|
assert(cap);
|
|
|
|
assert(crew);
|
|
|
|
*cap = test_create_unit(f, sh->region);
|
|
|
|
*crew = test_create_unit(f, sh->region);
|
|
|
|
(*cap)->ship = sh;
|
|
|
|
(*crew)->ship = sh;
|
|
|
|
set_level(*cap, SK_SAILING, sh->type->cptskill);
|
|
|
|
set_level(*crew, SK_SAILING, sh->type->sumskill - sh->type->cptskill);
|
|
|
|
}
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
static void test_shipspeed_speedy(CuTest *tc) {
|
|
|
|
ship_type *stype;
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crw;
|
|
|
|
test_setup();
|
|
|
|
stype = test_create_shiptype("dragonship");
|
|
|
|
stype->range = 2;
|
|
|
|
stype->range_max = -1;
|
|
|
|
stype->flags |= SFL_SPEEDY;
|
|
|
|
cap = test_create_unit(test_create_faction(NULL), test_create_region(0, 0, NULL));
|
|
|
|
crw = test_create_unit(cap->faction, cap->region);
|
|
|
|
sh = test_create_ship(cap->region, stype);
|
|
|
|
cap->ship = sh;
|
|
|
|
crw->ship = sh;
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill);
|
|
|
|
set_level(crw, SK_SAILING, stype->sumskill - stype->cptskill);
|
|
|
|
CuAssertPtrEquals(tc, cap, ship_owner(sh));
|
|
|
|
CuAssertIntEquals(tc, 2, shipspeed(sh, cap));
|
|
|
|
test_teardown();
|
|
|
|
}
|
|
|
|
|
2015-08-07 11:50:49 +02:00
|
|
|
static void test_shipspeed_stormwind(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
register_shipcurse();
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
2017-08-20 19:07:52 +02:00
|
|
|
create_curse(0, &sh->attribs, &ct_stormwind, 1, 1, 1, 0);
|
|
|
|
CuAssertPtrNotNull(tc, sh->attribs);
|
2015-08-07 11:50:49 +02:00
|
|
|
CuAssertIntEquals_Msg(tc, "stormwind doubles ship range", sh->type->range * 2, shipspeed(sh, cap));
|
2017-08-20 19:07:52 +02:00
|
|
|
a_age(&sh->attribs, sh);
|
|
|
|
CuAssertPtrEquals(tc, NULL, sh->attribs);
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed_nodrift(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
register_shipcurse();
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
2017-08-21 20:18:19 +02:00
|
|
|
create_curse(0, &sh->attribs, &ct_nodrift, 1, 1, 1, 0);
|
2015-08-07 11:50:49 +02:00
|
|
|
CuAssertIntEquals_Msg(tc, "nodrift adds +1 to range", sh->type->range + 1, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed_shipspeedup(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
register_shipcurse();
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
2017-08-18 18:42:59 +02:00
|
|
|
create_curse(0, &sh->attribs, &ct_shipspeedup, 1, 1, 3, 0);
|
2015-08-07 11:50:49 +02:00
|
|
|
CuAssertIntEquals_Msg(tc, "shipspeedup adds effect to range", sh->type->range + 3, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed_at_speedup(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
attrib *a;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
|
|
|
a = a_new(&at_speedup);
|
|
|
|
a->data.i = 3;
|
|
|
|
a_add(&sh->attribs, a);
|
|
|
|
CuAssertIntEquals_Msg(tc, "at_speedup adds value to range", sh->type->range + 3, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed_race_bonus(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
race *rc;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
|
|
|
rc = rc_get_or_create(cap->_race->_name);
|
|
|
|
rc->flags |= RCF_SHIPSPEED;
|
|
|
|
CuAssertIntEquals_Msg(tc, "captain with RCF_SHIPSPEED adds +1 to range", sh->type->range + 1, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed_damage(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
|
|
|
assert(sh && cap && crew);
|
|
|
|
|
|
|
|
sh->damage = 1;
|
|
|
|
CuAssertIntEquals_Msg(tc, "minimally damaged ships lose no range", 2, shipspeed(sh, cap));
|
|
|
|
sh->damage = sh->size * DAMAGE_SCALE / 2;
|
|
|
|
CuAssertIntEquals_Msg(tc, "damaged ships lose range", 1, shipspeed(sh, cap));
|
|
|
|
sh->damage = sh->size * DAMAGE_SCALE;
|
|
|
|
CuAssertIntEquals_Msg(tc, "fully damaged ships have no range", 0, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 11:50:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void test_shipspeed(CuTest *tc) {
|
|
|
|
ship *sh;
|
2015-07-23 16:10:13 +02:00
|
|
|
const ship_type *stype;
|
2015-08-07 11:50:49 +02:00
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-08-07 11:50:49 +02:00
|
|
|
sh = setup_ship();
|
2015-07-23 16:10:13 +02:00
|
|
|
stype = sh->type;
|
2015-08-07 09:03:19 +02:00
|
|
|
|
|
|
|
CuAssertIntEquals_Msg(tc, "ship without a captain cannot move", 0, shipspeed(sh, NULL));
|
|
|
|
|
2015-08-07 09:03:19 +02:00
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
2015-07-23 16:10:13 +02:00
|
|
|
|
2015-08-07 09:03:19 +02:00
|
|
|
CuAssertPtrEquals(tc, cap, ship_owner(sh));
|
|
|
|
CuAssertIntEquals_Msg(tc, "ship with fully skilled crew can sail at max speed", 2, shipspeed(sh, cap));
|
2015-08-07 11:50:49 +02:00
|
|
|
CuAssertIntEquals_Msg(tc, "shipspeed without a hint defaults to captain", 2, shipspeed(sh, NULL));
|
2015-08-07 09:03:19 +02:00
|
|
|
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill + 5);
|
2015-08-07 11:50:49 +02:00
|
|
|
set_level(crew, SK_SAILING, (stype->sumskill - stype->cptskill) * 10);
|
|
|
|
CuAssertIntEquals_Msg(tc, "higher skills should not affect top speed", 2, shipspeed(sh, cap));
|
2015-08-07 09:03:19 +02:00
|
|
|
set_level(cap, SK_SAILING, stype->cptskill);
|
2015-08-07 11:50:49 +02:00
|
|
|
set_level(crew, SK_SAILING, stype->sumskill - stype->cptskill);
|
2015-08-07 09:03:19 +02:00
|
|
|
|
|
|
|
CuAssertIntEquals(tc, 2, shipspeed(sh, cap));
|
|
|
|
|
|
|
|
set_level(crew, SK_SAILING, (stype->sumskill - stype->cptskill) * 11);
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill + 10);
|
|
|
|
CuAssertIntEquals_Msg(tc, "regular skills should not exceed sh.range", 2, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-08-07 09:03:19 +02:00
|
|
|
}
|
|
|
|
|
2015-07-23 16:10:13 +02:00
|
|
|
static void test_shipspeed_max_range(CuTest *tc) {
|
|
|
|
ship *sh;
|
|
|
|
ship_type *stype;
|
|
|
|
region *r;
|
|
|
|
struct faction *f;
|
|
|
|
unit *cap, *crew;
|
|
|
|
|
2017-12-27 19:58:39 +01:00
|
|
|
test_setup();
|
2015-07-23 16:10:13 +02:00
|
|
|
sh = setup_ship();
|
|
|
|
setup_crew(sh, 0, &cap, &crew);
|
2015-11-22 10:33:31 +01:00
|
|
|
config_set("movement.shipspeed.skillbonus", "5");
|
2015-07-23 16:10:13 +02:00
|
|
|
r = sh->region;
|
|
|
|
f = test_create_faction(0);
|
|
|
|
assert(r && f);
|
|
|
|
stype = st_get_or_create(sh->type->_name);
|
|
|
|
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill + 4);
|
|
|
|
set_level(crew, SK_SAILING, (stype->sumskill - stype->cptskill) * 4);
|
|
|
|
CuAssertIntEquals_Msg(tc, "skill bonus requires at least movement.shipspeed.skillbonus points", 2, shipspeed(sh, cap));
|
|
|
|
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill + 5);
|
|
|
|
set_level(crew, SK_SAILING, (stype->sumskill - stype->cptskill) * 5);
|
|
|
|
CuAssertIntEquals_Msg(tc, "skill bonus from movement.shipspeed.skillbonus", 3, shipspeed(sh, cap));
|
|
|
|
|
|
|
|
set_level(cap, SK_SAILING, stype->cptskill + 15);
|
|
|
|
set_level(crew, SK_SAILING, (stype->sumskill - stype->cptskill) * 15);
|
|
|
|
CuAssertIntEquals_Msg(tc, "skill-bonus cannot exceed max_range", 4, shipspeed(sh, cap));
|
2017-12-27 19:58:39 +01:00
|
|
|
test_teardown();
|
2015-07-23 16:10:13 +02:00
|
|
|
}
|
|
|
|
|
2012-05-17 09:13:30 +02:00
|
|
|
CuSuite *get_ship_suite(void)
|
|
|
|
{
|
2015-01-30 20:37:14 +01:00
|
|
|
CuSuite *suite = CuSuiteNew();
|
|
|
|
SUITE_ADD_TEST(suite, test_register_ship);
|
2015-02-03 17:10:29 +01:00
|
|
|
SUITE_ADD_TEST(suite, test_stype_defaults);
|
2015-01-30 20:37:14 +01:00
|
|
|
SUITE_ADD_TEST(suite, test_ship_set_owner);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_resets_when_empty);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_next_when_empty);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_other_when_empty);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_same_faction_when_empty);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_next_after_leave);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_other_after_leave);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_same_faction_after_leave);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipowner_goes_to_empty_unit_after_leave);
|
2015-04-18 11:41:50 +02:00
|
|
|
SUITE_ADD_TEST(suite, test_crew_skill);
|
2015-08-07 09:03:19 +02:00
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed);
|
2017-12-27 19:58:39 +01:00
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_speedy);
|
2015-08-07 11:50:49 +02:00
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_stormwind);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_nodrift);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_shipspeedup);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_at_speedup);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_race_bonus);
|
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_damage);
|
2015-07-23 16:10:13 +02:00
|
|
|
SUITE_ADD_TEST(suite, test_shipspeed_max_range);
|
2015-01-30 20:37:14 +01:00
|
|
|
return suite;
|
2012-05-17 09:13:30 +02:00
|
|
|
}
|