kubo/test/sharness
Jeromy Johnson 5f26f00465 Merge pull request #4127 from ipfs/feat/dns-bootstrap
bootstrap: add /dnsaddr nodes
2017-08-25 15:23:31 -07:00
..
lib Removed tour command and fix test 2017-08-09 10:14:57 -04:00
t0051-object-data no newlines in json objects 2015-11-30 15:23:48 -08:00
t0053-dag-data fix printing out of binary escaped data for test 2017-02-09 10:31:18 -08:00
t0060-data multistream tests use data from file 2016-04-07 15:55:41 -07:00
t0280-plugin-git-data git: add git plugin tests 2017-07-12 23:38:32 +02:00
.gitignore make(sharness): add plugins as part of sharness build 2017-07-12 21:53:59 +02:00
Makefile make: make default rule 'aggregate' in sharness 2017-02-12 01:18:40 +01:00
README.md make: rework makefiles for non-recursive make and add sharness coverage 2017-02-12 01:18:40 +01:00
Rules.mk make(sharness): add plugins as part of sharness build 2017-07-12 21:53:59 +02:00
t0010-basic-commands.sh test: add test for checking if commands mans lengths are shorter than 80 2017-03-10 19:05:34 +01:00
t0015-basic-sh-functions.sh Add t0015-basic-sh-functions.sh 2015-10-03 12:27:01 +02:00
t0020-init.sh Add test init profile 2017-07-06 22:41:47 +02:00
t0021-config.sh Merge pull request #3073 from ipfs/feat/test-config-replace 2016-10-03 17:29:52 -07:00
t0022-init-default.sh sharness: don't run go-ipfs instance with default config 2016-12-21 10:29:38 +01:00
t0023-shutdown.sh fix shutdown check in t0023 2017-06-10 11:32:46 -07:00
t0030-mount.sh Make t0030 use iptb for consistent test passing. 2016-05-16 13:38:41 -07:00
t0031-mount-publish.sh sharness: fix the error message in the mount-publish test case 2017-07-04 16:54:12 -07:00
t0040-add-and-cat.sh sharness: fix the 'useful error message when adding a named pipe' test 2017-07-31 18:31:40 -07:00
t0042-add-skip.sh Lets 'ipfs add' add hidden files when explicit. 2016-01-15 11:19:40 -08:00
t0043-add-w.sh adder: add support for using CidV1 2017-04-25 23:36:39 -04:00
t0044-add-symlink.sh adder: add support for using CidV1 2017-04-25 23:36:39 -04:00
t0045-ls.sh Add tests for "ls --resolve-type=false". 2017-01-04 15:08:01 -05:00
t0050-block.sh cmd/block: add selection of multihash parameters to block put command 2016-12-07 16:36:00 -08:00
t0051-object.sh object put --pin option 2017-07-31 19:38:05 +02:00
t0052-object-diff.sh Fixed tests 2016-05-10 10:39:53 -04:00
t0053-dag.sh dag: dag resolve subcommand 2017-08-13 20:58:29 +02:00
t0060-daemon.sh ipfs swarm addrs listen command, fix t0060-daemon 2017-08-16 09:28:05 +03:00
t0061-daemon-opts.sh test: add test for invalid routing option 2017-01-10 19:07:58 +01:00
t0062-daemon-api.sh t0062: fix indentation 2016-02-19 04:24:12 +01:00
t0063-daemon-init.sh daemon: use fsrepo.IsInitialized to test for initialization 2017-03-22 04:25:57 -04:00
t0063-external.sh add a test 2015-12-30 11:08:09 -08:00
t0065-active-requests.sh add a pause to fix timing on t0065 2016-02-15 19:16:03 -08:00
t0066-migration.sh add tests to make sure docker requests correct migrations version 2017-02-17 08:37:27 +01:00
t0070-user-config.sh fix(fsrepo): use "please run ipfs init" message 2015-01-13 03:09:32 -08:00
t0080-repo.sh Add MaxStorage field to output of "repo stat". 2017-05-10 23:41:35 -04:00
t0081-repo-pinning.sh update test to print error from EnumerateChildren 2017-01-12 13:51:53 -08:00
t0082-repo-gc-auto.sh disable auto repo gc tests temporarily 2015-12-27 14:55:19 -08:00
t0083-repo-fsck.sh Capitalized NOTE, first letter of following word 2016-04-29 16:57:19 -04:00
t0084-repo-read-rehash.sh Change repo version to 5, use new flatfs sharding 2017-01-19 14:59:12 -08:00
t0085-pins.sh Report progress during 'pin add'. 2017-02-17 16:19:42 -05:00
t0086-repo-verify.sh don't select README or SHARDING file for random corruption in t0086 2017-01-21 10:19:50 -08:00
t0087-repo-robust-gc.sh gc: add option to stream errors 2017-03-06 14:26:14 -05:00
t0090-get.sh fix: ipfs get panic with empty API call 2017-03-09 15:42:15 +01:00
t0100-name.sh add sharness tests 2017-05-03 06:19:30 +03:00
t0101-iptb-name.sh iptb-lib: add startup_cluster() 2016-02-01 23:22:35 +01:00
t0110-gateway.sh Removed tour command and fix test 2017-08-09 10:14:57 -04:00
t0111-gateway-writeable.sh gateway: fix --writable flag :| 2016-09-11 21:09:09 +02:00
t0112-gateway-cors.sh test: do explicit check of CORS headers 2016-08-29 21:43:58 +02:00
t0120-bootstrap.sh bootstrap: add /dnsaddr nodes, remove half of /ip4,/ip6 nodes 2017-08-17 16:22:38 +02:00
t0121-bootstrap-iptb.sh trailing whitespace 2016-02-29 16:05:48 -08:00
t0125-twonode.sh Add more info to bitswap stat 2017-03-06 09:47:53 +01:00
t0130-multinode.sh feat: remove broken spdy multiplexer and enable mplex by default 2017-03-01 23:28:05 -08:00
t0131-multinode-client-routing.sh clean up test, run checks on all nodes 2016-09-30 16:10:20 -07:00
t0140-swarm.sh core: make announced swarm addresses configurable 2017-07-31 13:03:09 +02:00
t0141-addfilter.sh Add ipfs config Swarm.AddrFilters test 2016-06-21 09:03:40 +03:00
t0150-clisuggest.sh Better error message on unrecognized command 2015-07-28 09:20:53 -06:00
t0151-sysdiag.sh Add test for online field in diag sys 2016-06-18 19:15:04 +02:00
t0160-resolve.sh Add newline to end of the output for a few commands. 2015-11-29 11:50:48 -06:00
t0165-keystore.sh Add a test for failure of 'ipfs key rm self' 2017-05-14 21:01:18 +09:00
t0170-dht.sh update to libp2p 4.0.1 and propogate other changes 2016-10-05 22:12:43 -07:00
t0175-reprovider.sh reprovide: fix ipfs bitswap reprovide when interval set to 0 2017-08-20 18:23:09 +02:00
t0180-p2p.sh Don't use wait in p2p sharness test 2017-06-21 18:35:17 +02:00
t0180-pubsub.sh Fix typo and formatting issues. 2017-01-04 17:26:08 -05:00
t0181-private-network.sh deps: update dependencies for PNet 2017-02-22 20:04:43 +01:00
t0182-circuit-relay.sh test/sharness: extended circuit relay test 2017-08-16 09:26:49 +03:00
t0200-unixfs-ls.sh fixify tests 2016-01-12 08:22:55 -08:00
t0210-tar.sh add sharness test for tar commands 2015-09-10 17:11:35 -07:00
t0220-bitswap.sh Add more info to bitswap stat 2017-03-06 09:47:53 +01:00
t0230-channel-streaming-http-content-type.sh Migrate rs/cors to gx 2016-05-31 22:40:41 +02:00
t0231-channel-streaming.sh put newlines between streaming json output objects 2015-10-25 22:38:38 -07:00
t0235-cli-request.sh Fixes nc on macOS not closing socket when the stdin sends EOF 2016-12-16 21:10:53 +01:00
t0240-republisher.sh repub: iterate through all keys in keystore 2017-06-07 14:35:44 -04:00
t0250-files-api.sh fix small typo 2017-06-27 19:20:41 -07:00
t0251-files-flushing.sh blockstore locks return unlocker object now 2016-02-08 14:42:07 -08:00
t0252-files-gc.sh Enhance tests for files API root best-effort pin. 2016-08-31 18:16:36 -04:00
t0260-sharding-flag.sh Fix sharding memory growth, and fix resolver for unixfs paths 2017-04-30 13:48:28 -07:00
t0270-filestore.sh test: skip not necessary var assigment 2017-03-08 00:07:18 +01:00
t0271-filestore-utils.sh filestore: add "--file-order" option to "filestore ls" and "verify" 2017-05-23 17:40:20 -04:00
t0280-plugin-git.sh misc: small code style edit 2017-07-16 10:26:34 +02:00
t0300-docker-image.sh docker: take version suffixes like -dev into account 2016-07-03 01:45:02 +02:00
t0301-docker-migrate.sh add tests to make sure docker requests correct migrations version 2017-02-17 08:37:27 +01:00
t0400-api-security.sh daemon: reintroduce --unrestricted-api 2016-07-09 00:07:36 +02:00
t0410-api-add.sh ipfs add: added test case to verify presence of size 2017-07-27 08:58:41 -04:00
t0500-issues-and-regressions-offline.sh test: remove time-out script, use go-timeout instead 2016-09-01 15:59:12 +02:00
t0600-issues-and-regressions-online.sh sharness: fix #4003 test case 2017-07-28 17:21:04 -07:00
x0601-pin-fail-test.sh add test to be run to detect future regressions in pinsets 2016-10-12 09:29:09 -07:00

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 sharness tests from main Makefile or when test_sharness_deps target is run dependencies for 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