diff --git a/include/player.h b/include/player.h index 64eb09fe..ddd26d6d 100644 --- a/include/player.h +++ b/include/player.h @@ -29,7 +29,7 @@ * Known contributors to this file: * Dave Pare, 1994 * Doug Hay, 1998 - * Markus Armbruster, 2005-2012 + * Markus Armbruster, 2005-2014 */ #ifndef PLAYER_H @@ -46,6 +46,7 @@ #define SANCT bit(1) /* can execute commands available in sanctuary */ #define NORM bit(2) /* can execute active player commands */ #define GOD bit(3) /* can execute deity commands */ +#define TESTING bit(4) /* can execute commands meant for test suite */ #define EXEC bit(5) /* can execute the execute command */ #define CAP bit(6) /* has capital */ #define MONEY bit(7) /* isn't broke */ diff --git a/include/testing.h b/include/testing.h new file mode 100644 index 00000000..eaa4f0e2 --- /dev/null +++ b/include/testing.h @@ -0,0 +1,41 @@ +/* + * Empire - A multi-player, client/server Internet based war game. + * Copyright (C) 1986-2014, Dave Pare, Jeff Bailey, Thomas Ruschak, + * Ken Stevens, Steve McClure, Markus Armbruster + * + * Empire is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + * + * --- + * + * See files README, COPYING and CREDITS in the root of the source + * tree for related information and legal notices. It is expected + * that future projects/authors will amend these files as needed. + * + * --- + * + * testing.h: Test suite support + * + * Known contributors to this file: + * Markus Armbruster, 2014 + */ + +#ifndef TESTING_H +#define TESTING_H + +extern int test_suite_prng_seed; + +/* Commands for test suite use */ +int testing_cmd(void); + +#endif diff --git a/src/lib/commands/testing.c b/src/lib/commands/testing.c new file mode 100644 index 00000000..6469d4f0 --- /dev/null +++ b/src/lib/commands/testing.c @@ -0,0 +1,58 @@ +/* + * Empire - A multi-player, client/server Internet based war game. + * Copyright (C) 1986-2014, Dave Pare, Jeff Bailey, Thomas Ruschak, + * Ken Stevens, Steve McClure, Markus Armbruster + * + * Empire is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + * + * --- + * + * See files README, COPYING and CREDITS in the root of the source + * tree for related information and legal notices. It is expected + * that future projects/authors will amend these files as needed. + * + * --- + * + * testing.c: Commands for test-suite use + * + * Known contributors to this file: + * Markus Armbruster, 2014 + */ + +#include + +#include "chance.h" +#include "commands.h" +#include "testing.h" + +int +testing_cmd(void) +{ + char *p; + char buf[1024]; + + p = getstarg(player->argp[1], "? ", buf); + if (!p) + return RET_SYN; + if (!strcmp(p, "added")) { + p = getstarg(player->argp[2], "number? ", buf); + test_suite_prng_seed -= strtol(p, NULL, 10); + p = getstarg(player->argp[3], "BTUs? ", buf); + player->btused -= strtol(p, NULL, 10); + p = getstarg(player->argp[4], "money? ", buf); + player->dolcost -= strtod(p, NULL); + return RET_OK; + } + return RET_SYN; +} diff --git a/src/lib/player/dispatch.c b/src/lib/player/dispatch.c index 681156e1..50379b48 100644 --- a/src/lib/player/dispatch.c +++ b/src/lib/player/dispatch.c @@ -46,6 +46,7 @@ #include "player.h" #include "prototypes.h" #include "server.h" +#include "testing.h" /* * Last command's PRNG seed. @@ -101,9 +102,12 @@ dispatch(char *buf, char *redir) * When running the test suite, reseed PRNG for each command with * a counter, to keep results stable even when the number of PRNs * consumed changes. + * Tests can adjust the counter with "__cmd added ...", to + * keep the results stable when commands are inserted or deleted. */ + test_suite_prng_seed += !(command->c_permit & TESTING); if (running_test_suite) - seed_prng(++test_suite_prng_seed); + seed_prng(test_suite_prng_seed); if (redir) { prredir(redir); diff --git a/src/lib/player/empmod.c b/src/lib/player/empmod.c index 578ccf34..c89896cd 100644 --- a/src/lib/player/empmod.c +++ b/src/lib/player/empmod.c @@ -32,7 +32,7 @@ * Thomas Ruschak, 1992 * Ken Stevens, 1995 * Steve McClure, 1996-2000 - * Markus Armbruster, 2004-2013 + * Markus Armbruster, 2004-2014 */ /* @@ -46,6 +46,7 @@ #include "com.h" #include "player.h" #include "prototypes.h" +#include "testing.h" struct cmndstr player_coms[] = { /* command form cost addr permit */ @@ -282,5 +283,6 @@ struct cmndstr player_coms[] = { {"work ", 1, work, C_MOD, NORM + MONEY + CAP}, {"xdump [\"meta\"] []", 0, xdump, 0, 0}, {"zdone ", 0, zdon, C_MOD, NORM}, + {"__cmd \"added\" ", 0, testing_cmd, 0, TESTING}, {NULL, 0, NULL, 0, 0} }; diff --git a/src/lib/player/init_nats.c b/src/lib/player/init_nats.c index bc054f70..705229be 100644 --- a/src/lib/player/init_nats.c +++ b/src/lib/player/init_nats.c @@ -29,7 +29,7 @@ * Known contributors to this file: * Dave Pare, 1994 * Steve McClure, 2000 - * Markus Armbruster, 2007-2012 + * Markus Armbruster, 2007-2014 */ #include @@ -81,6 +81,8 @@ player_set_nstat(struct player *pl, struct natstr *np) pl->nstat |= MONEY; if (np->nat_stat == STAT_ACTIVE && !influx(np)) pl->nstat |= CAP; + if (running_test_suite) + pl->nstat |= TESTING; pl->nstat |= EXEC; return pl->nstat; } diff --git a/tests/info-test b/tests/info-test index 09940f7e..8544b20e 100755 --- a/tests/info-test +++ b/tests/info-test @@ -10,6 +10,10 @@ srcdir="$1" . "$srcdir"/tests/test-common.sh create_sandbox +# Suppress test-only commands: +cat >>sandbox/etc/empire/econfig <