* Cleans up 'ipfs dht findpeer' output License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Adds more docs for 'ipfs dht put'. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Write pretty peer ids for ipfs dht put. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Writes pretty peer ids for ipfs dht query. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Suppresses unrecognized event type for FinalPeer. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Improves helptext on dht commands. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Adds 'ipfs dht findpeer' sharness test. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Adds sharness tests for remaining DHT commands. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Uses bash tests rather than 'test' command. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Removes commented code. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Removes unneeded init_ipfs. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Tweaks iptb setup. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Tweaks wording on dht 'put' and 'get'. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Removes extraneous ). License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Removes apostrophe. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Tests the expected peer addresses. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Gets peer id using iptb. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Checks explicitly for common put/findprovs peers. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Sorts expected/actual findpeer results. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> * Fix disconnect argument description License: MIT Signed-off-by: Richard Littauer <richard.littauer@gmail.com> * Fixes sort order in t0170-dht.sh. License: MIT Signed-off-by: Stephen Whitmore <noffle@ipfs.io> |
||
|---|---|---|
| .. | ||
| lib | ||
| t0051-object-data | ||
| t0060-data | ||
| .gitignore | ||
| bin | ||
| Makefile | ||
| README.md | ||
| t0010-basic-commands.sh | ||
| t0015-basic-sh-functions.sh | ||
| t0020-init.sh | ||
| t0021-config.sh | ||
| t0030-mount.sh | ||
| t0031-mount-publish.sh | ||
| t0040-add-and-cat.sh | ||
| t0042-add-skip.sh | ||
| t0043-add-w.sh | ||
| t0044-add-symlink.sh | ||
| t0045-ls.sh | ||
| t0050-block.sh | ||
| t0051-object.sh | ||
| t0052-object-diff.sh | ||
| t0060-daemon.sh | ||
| t0061-daemon-opts.sh | ||
| t0062-daemon-api.sh | ||
| t0063-external.sh | ||
| t0065-active-requests.sh | ||
| t0070-user-config.sh | ||
| t0080-repo.sh | ||
| t0081-repo-pinning.sh | ||
| t0082-repo-gc-auto.sh | ||
| t0090-get.sh | ||
| t0100-name.sh | ||
| t0101-iptb-name.sh | ||
| t0110-gateway.sh | ||
| t0111-gateway-writeable.sh | ||
| t0112-gateway-cors.sh | ||
| t0120-bootstrap.sh | ||
| t0121-bootstrap-iptb.sh | ||
| t0130-multinode.sh | ||
| t0140-swarm.sh | ||
| t0141-addfilter.sh | ||
| t0150-clisuggest.sh | ||
| t0151-sysdiag.sh | ||
| t0160-resolve.sh | ||
| t0170-dht.sh | ||
| t0200-unixfs-ls.sh | ||
| t0210-tar.sh | ||
| t0220-bitswap.sh | ||
| t0230-channel-streaming-http-content-type.sh | ||
| t0231-channel-streaming.sh | ||
| t0235-cli-request.sh | ||
| t0240-republisher.sh | ||
| t0250-files-api.sh | ||
| t0251-files-flushing.sh | ||
| t0300-docker-image.sh | ||
ipfs whole tests using the sharness framework
Running all the tests
Just use make in this directory to run all the tests.
Run with TEST_VERBOSE=1 to get helpful verbose output.
TEST_VERBOSE=1 make
The usual ipfs env flags also apply:
# the output will make your eyes bleed
IPFS_LOGGING=debug TEST_VERBOSE=1 make
Running just one test
You can run only one test script by launching it like a regular shell script:
$ ./t0010-basic-commands.sh
Debugging one test
You can use the -v option to make it verbose and the -i option to
make it stop as soon as one test fails.
For example:
$ ./t0010-basic-commands.sh -v -i
Sharness
When running "make" in this directory for the first time, sharness will be downloaded from its github repo and installed in a "lib/sharness" directory.
Please do not change anything in the "lib/sharness" directory.
If you really need some changes in sharness, please fork it from its cannonical repo and send pull requests there.
Writing Tests
Please have a look at existing tests and try to follow their example.
When possible and not too inefficient, that means most of the time,
an ipfs command should not be on the left side of a pipe, because if
the ipfs command fails (exit non zero), the pipe will mask this failure.
For example after false | true, echo $? prints 0 (despite false
failing).
It should be possible to put most of the code inside test_expect_success,
or sometimes test_expect_failure, blocks, and to chain all the commands
inside those blocks with &&, or || for diagnostic commands.
Diagnostics
Make your test case output helpful for when running sharness verbosely. This means cating certain files, or running diagnostic commands. For example:
test_expect_success ".ipfs/ has been created" '
test -d ".ipfs" &&
test -f ".ipfs/config" &&
test -d ".ipfs/datastore" &&
test -d ".ipfs/blocks" ||
test_fsh ls -al .ipfs
'
The || ... is a diagnostic run when the preceding command fails.
test_fsh is a shell function that echoes the args, runs the cmd,
and then also fails, making sure the test case fails. (wouldnt want
the diagnostic accidentally returning true and making it seem like
the test case succeeded!).
Testing commands on daemon or mounted
Use the provided functions in lib/test-lib.sh to run the daemon or mount:
To init, run daemon, and mount in one go:
test_launch_ipfs_daemon_and_mount
test_expect_success "'ipfs add --help' succeeds" '
ipfs add --help >actual
'
# other tests here...
# dont forget to kill the daemon!!
test_kill_ipfs_daemon
To init, run daemon, and then mount separately:
test_init_ipfs
# tests inited but not running here
test_launch_ipfs_daemon
# tests running but not mounted here
test_mount_ipfs
# tests mounted here
# dont forget to kill the daemon!!
test_kill_ipfs_daemon