tests: New test-suite-only command __cmd
authorMarkus Armbruster <armbru@pond.sub.org>
Mon, 13 Jan 2014 20:27:16 +0000 (21:27 +0100)
committerMarkus Armbruster <armbru@pond.sub.org>
Sun, 19 Jan 2014 09:16:24 +0000 (10:16 +0100)
commite852d458f92406c54c6dcd7e6846041221896b3d
treedef69df4d8fff586d1e3fb9fd8cd4132efc9f64e
parent73f1ac8a2c005f6876cc11e59808d8bde5db7491
tests: New test-suite-only command __cmd

Adding or removing a command to/from a test has unfortunate effects:

* Before the previous commit: if the command consumes pseudorandom
  numbers, all subsequent users of pseudorandom numbers get different
  ones.  This has always been a major headache.

* Since the previous commit: all subsequent users of pseudorandom
  numbers get different ones whether the command consumes any or not.
  That's even worse.

* If the command uses BTUs, subsequent prompts are changed.  Not
  nearly as bad as the above, but still annoying.

Create a new command __cmd to allow compensating for adding/removing
commands for tests.  Throw in the ability to compensate treasury
changes for good measure.  Three arguments: command count, BTU use,
money use.

Usage example: say you add a convert command to a test, and it uses 3
BTUs and $15.  Then you compensate by adding "__cmd added 1 3 15"
right after it.

The command must not be available unless running_test_suite is on, of
course.  Make it require the new player command capability TESTING,
and give that to all players when running_test_suite is on.

The command is intentionally not documented in info.  Switch
running_test_suite off for info-test, to hide it (and any future
TESTING commands) from info-test.

Suppress the command counter increment for TESTING commands, so they
can be used without upsetting pseudorandom numbers

Signed-off-by: Markus Armbruster <armbru@pond.sub.org>
include/player.h
include/testing.h [new file with mode: 0644]
src/lib/commands/testing.c [new file with mode: 0644]
src/lib/player/dispatch.c
src/lib/player/empmod.c
src/lib/player/init_nats.c
tests/info-test
tests/smoke/00/01-1
tests/smoke/journal.log