commit 84127eb6eb5b090e666f938d744cc823fc0b5f69 Author: teor teor@torproject.org Date: Wed Mar 13 12:47:42 2019 +1000
README: updates after recent features
Closes 29762. --- README | 43 ++++++++++++++++++++++++++++++++++++------- 1 file changed, 36 insertions(+), 7 deletions(-)
diff --git a/README b/README index 23c6ed2..28f90a0 100644 --- a/README +++ b/README @@ -10,7 +10,8 @@ It is supposed to be a good tool for: Right now it only sorta does these things.
You will need: - - Python 2.7 or later (Python 3 support is an ongoing work), and + - Python 2.7, or a supported Python 3, + - (we support Python versions that are still getting updates), - Tor binaries.
Chutney checks for Tor binaries in this order: @@ -33,6 +34,7 @@ Automated Setup, Verification, and Shutdown: (The script tries hard to find tor.) ./tools/test-network.sh --chutney-path <chutney-directory> (The script is pretty good at finding chutney.) + ./tools/test-network.sh --allow-failures <N>
test-network.sh looks for some tor binaries (either in a nearby build directory or in your $PATH), configures a comprehensive tor test network, @@ -42,6 +44,14 @@ itself. Relative paths are supported. You can modify its configuration using command-line arguments, or use the chutney environmental variables documented below:
+Verification Options: + # repeats bootstrap and verify + --allow-failures CHUTNEY_ALLOW_FAILURES=N + # repeats verify + --rounds CHUTNEY_ROUNDS=N + # makes multiple connections within verify + --connections CHUTNEY_CONNECTIONS=N + Timing Options: --start-time CHUTNEY_START_TIME=N --bootstrap-time CHUTNEY_BOOTSTRAP_TIME=N @@ -49,9 +59,6 @@ Timing Options:
Traffic Options: --data CHUTNEY_DATA_BYTES=N - # connections are simultaneous, rounds are sequential - --connections CHUTNEY_CONNECTIONS=N - --rounds CHUTNEY_ROUNDS=N --hs-multi-client CHUTNEY_HS_MULTI_CLIENT=N
Address/DNS Options: @@ -83,6 +90,7 @@ Standard Actions: ./chutney configure networks/basic ./chutney start networks/basic ./chutney status networks/basic + ./chutney wait_for_bootstrap networks/basic ./chutney verify networks/basic ./chutney hup networks/basic ./chutney stop networks/basic @@ -127,16 +135,34 @@ Bandwidth File Tests: date +%s > /tmp/bwfile ./tools/test-network.sh --flavour bwfile
+Multiple Tests: + + Chutney can allow a certain number of failed tests. You can either set + CHUTNEY_ALLOW_FAILURES or use an --allow-failures command-line option to + control this. Chutney will then reattempt the test, from bootstrap + through shutdown, until either it succeeds, or until it has failed + $CHUTNEY_ALLOW_FAILURES+1 times. The default value is zero, so the default + behavior will not change. + + You can also use CHUTNEY_ROUNDS=N to run multiple verification rounds, or + CHUTNEY_CONNECTIONS=N to make multiple connections within each verification + round. Any round or connection failure will fail the current test. + Waiting for the network:
The tools/test-network.sh script waits CHUTNEY_START_TIME seconds - (default: 20) before calling chutney verify, because that's the minimum + (default: 40) before calling chutney verify, because that's the minimum amount of time it takes to bootstrap a consensus containing relays. - (It takes 5-10 seconds for the authorities to create the first consensus, - then 10 seconds for relays to bootstrap, submit their descriptors, and be + (It takes 20 seconds for the authorities to create the first consensus, + then 20 seconds for relays to bootstrap, submit their descriptors, and be included in the next consensus.) If CHUTNEY_START_TIME is negative, the script leaves the network running, and exits immediately (without verifying).
+ chutney also has an experimental wait_for_bootstrap command. It waits for + up to CHUTNEY_START_TIME seconds, checking whether the logged bootstrapped + status for every node is 100%. If it is, great: it succeeds. If not, it + dumps the bootstrap statuses and exits. + Commands like "chutney verify" start immediately, and keep trying for CHUTNEY_BOOTSTRAP_TIME seconds (default: 60). If it hasn't been successful after that time, it fails. If CHUTNEY_BOOTSTRAP_TIME is negative, @@ -191,10 +217,12 @@ Using DNS: Use --dns-conf resolv.conf (relative paths work).
The configuration files: + networks/basic holds the configuration for the network you're configuring above. It refers to some torrc template files in torrc_templates/.
The working files: + chutney sticks its working files, including all data directories, log files, etc, in ./net/. Each tor instance gets a subdirectory of net/nodes.
@@ -202,6 +230,7 @@ The working files: environment variable.
Test scripts: + The test scripts are stored in the "scripts/chutney_tests" directory. These Python files must define a "run_test(network)" function. Files starting with an underscore ("_") are ignored.