forked from github/server
create a failing test for stones in the NR.
This commit is contained in:
parent
45862a06d0
commit
52dd11a28f
3 changed files with 37 additions and 6 deletions
|
@ -203,6 +203,7 @@ struct rawmaterial_type *rmt_create(struct resource_type *rtype)
|
||||||
rawmaterial_type *rmtype;
|
rawmaterial_type *rmtype;
|
||||||
|
|
||||||
assert(!rtype->raw);
|
assert(!rtype->raw);
|
||||||
|
assert(!rtype->itype || rtype->itype->construction);
|
||||||
rmtype = rtype->raw = malloc(sizeof(rawmaterial_type));
|
rmtype = rtype->raw = malloc(sizeof(rawmaterial_type));
|
||||||
rmtype->rtype = rtype;
|
rmtype->rtype = rtype;
|
||||||
rmtype->terraform = terraform_default;
|
rmtype->terraform = terraform_default;
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
#include <kernel/item.h>
|
#include <kernel/item.h>
|
||||||
#include <kernel/race.h>
|
#include <kernel/race.h>
|
||||||
#include <kernel/region.h>
|
#include <kernel/region.h>
|
||||||
|
#include <kernel/resources.h>
|
||||||
#include <kernel/ship.h>
|
#include <kernel/ship.h>
|
||||||
#include <kernel/unit.h>
|
#include <kernel/unit.h>
|
||||||
#include <kernel/spell.h>
|
#include <kernel/spell.h>
|
||||||
|
@ -60,12 +61,22 @@ static void test_report_region(CuTest *tc) {
|
||||||
char buf[1024];
|
char buf[1024];
|
||||||
region *r;
|
region *r;
|
||||||
faction *f;
|
faction *f;
|
||||||
|
unit *u;
|
||||||
stream out = { 0 };
|
stream out = { 0 };
|
||||||
size_t len;
|
size_t len;
|
||||||
struct locale *lang;
|
struct locale *lang;
|
||||||
|
struct resource_type *rt_stone;
|
||||||
|
construction *cons;
|
||||||
|
|
||||||
test_setup();
|
test_setup();
|
||||||
init_resources();
|
init_resources();
|
||||||
|
rt_stone = rt_get_or_create("stone");
|
||||||
|
rt_stone->itype = it_get_or_create(rt_stone);
|
||||||
|
cons = rt_stone->itype->construction = calloc(1, sizeof(construction));
|
||||||
|
cons->minskill = 1;
|
||||||
|
cons->skill = SK_QUARRYING;
|
||||||
|
rmt_create(rt_stone);
|
||||||
|
|
||||||
lang = get_or_create_locale("de"); /* CR tags are translated from this */
|
lang = get_or_create_locale("de"); /* CR tags are translated from this */
|
||||||
locale_setstring(lang, "money", "Silber");
|
locale_setstring(lang, "money", "Silber");
|
||||||
locale_setstring(lang, "money_p", "Silber");
|
locale_setstring(lang, "money_p", "Silber");
|
||||||
|
@ -80,23 +91,40 @@ static void test_report_region(CuTest *tc) {
|
||||||
locale_setstring(lang, "sapling", "Schoessling");
|
locale_setstring(lang, "sapling", "Schoessling");
|
||||||
locale_setstring(lang, "sapling_p", "Schoesslinge");
|
locale_setstring(lang, "sapling_p", "Schoesslinge");
|
||||||
locale_setstring(lang, "plain", "Ebene");
|
locale_setstring(lang, "plain", "Ebene");
|
||||||
|
locale_setstring(lang, "see_travel", "durchgereist");
|
||||||
|
|
||||||
mstream_init(&out);
|
mstream_init(&out);
|
||||||
r = test_create_region(0, 0, 0);
|
r = test_create_region(0, 0, 0);
|
||||||
r->land->peasants = 100;
|
add_resource(r, 1, 100, 10, rt_stone);
|
||||||
r->land->horses = 200;
|
CuAssertIntEquals(tc, 135, r->resources->amount);
|
||||||
|
CuAssertIntEquals(tc, 1, r->resources->level);
|
||||||
|
r->land->peasants = 5;
|
||||||
|
r->land->horses = 7;
|
||||||
|
r->land->money = 2;
|
||||||
rsettrees(r, 0, 1);
|
rsettrees(r, 0, 1);
|
||||||
rsettrees(r, 1, 2);
|
rsettrees(r, 1, 2);
|
||||||
rsettrees(r, 2, 3);
|
rsettrees(r, 2, 3);
|
||||||
region_setname(r, "Hodor");
|
region_setname(r, "Hodor");
|
||||||
f = test_create_faction(0);
|
f = test_create_faction(0);
|
||||||
f->locale = lang;
|
f->locale = lang;
|
||||||
|
u = test_create_unit(f, r);
|
||||||
|
set_level(u, SK_QUARRYING, 1);
|
||||||
|
|
||||||
|
r->seen.mode = seen_travel;
|
||||||
report_region(&out, r, f);
|
report_region(&out, r, f);
|
||||||
out.api->rewind(out.handle);
|
out.api->rewind(out.handle);
|
||||||
len = out.api->read(out.handle, buf, sizeof(buf));
|
len = out.api->read(out.handle, buf, sizeof(buf));
|
||||||
buf[len] = '\0';
|
buf[len] = '\0';
|
||||||
CuAssertStrEquals(tc, "Hodor (0,0), Ebene, 3/2 Blumen, 100 Bauern, 200 Pferde.\n", buf);
|
CuAssertStrEquals(tc, "Hodor (0,0) (durchgereist), Ebene, 3/2 Blumen, 5 Bauern, 2 Silber, 7 Pferde.\n", buf);
|
||||||
|
|
||||||
|
r->seen.mode = seen_unit;
|
||||||
|
out.api->rewind(out.handle);
|
||||||
|
report_region(&out, r, f);
|
||||||
|
out.api->rewind(out.handle);
|
||||||
|
len = out.api->read(out.handle, buf, sizeof(buf));
|
||||||
|
buf[len] = '\0';
|
||||||
|
CuAssertStrEquals(tc, "Hodor (0,0), Ebene, 3/2 Blumen, 135 Steine/1, 5 Bauern, 2 Silber, 7 Pferde.\n", buf);
|
||||||
|
|
||||||
mstream_done(&out);
|
mstream_done(&out);
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
}
|
}
|
||||||
|
|
|
@ -448,17 +448,19 @@ const faction * viewer, bool see_unit)
|
||||||
while (res) {
|
while (res) {
|
||||||
int maxskill = 0;
|
int maxskill = 0;
|
||||||
const item_type *itype = resource2item(res->type->rtype);
|
const item_type *itype = resource2item(res->type->rtype);
|
||||||
int level = res->level + itype->construction->minskill - 1;
|
int minskill = itype->construction->minskill;
|
||||||
|
skill_t skill = itype->construction->skill;
|
||||||
|
int level = res->level + minskill - 1;
|
||||||
int visible = -1;
|
int visible = -1;
|
||||||
if (res->type->visible == NULL) {
|
if (res->type->visible == NULL) {
|
||||||
visible = res->amount;
|
visible = res->amount;
|
||||||
level = res->level + itype->construction->minskill - 1;
|
level = res->level + minskill - 1;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
const unit *u;
|
const unit *u;
|
||||||
for (u = r->units; visible != res->amount && u != NULL; u = u->next) {
|
for (u = r->units; visible != res->amount && u != NULL; u = u->next) {
|
||||||
if (u->faction == viewer) {
|
if (u->faction == viewer) {
|
||||||
int s = effskill(u, itype->construction->skill, 0);
|
int s = effskill(u, skill, 0);
|
||||||
if (s > maxskill) {
|
if (s > maxskill) {
|
||||||
maxskill = s;
|
maxskill = s;
|
||||||
visible = res->type->visible(res, maxskill);
|
visible = res->type->visible(res, maxskill);
|
||||||
|
|
Loading…
Reference in a new issue