kubo/test/sharness
Jeromy Johnson e893fb90b7 Merge pull request #3484 from ipfs/fix/pubsub-peers-cmd
cmd/pubsub: fix peers command topic filtering
2016-12-09 12:08:45 -08:00
..
lib pubsub sharness tests after chriscool feedback 2016-12-04 03:22:51 +01:00
t0051-object-data no newlines in json objects 2015-11-30 15:23:48 -08:00
t0060-data multistream tests use data from file 2016-04-07 15:55:41 -07:00
.gitignore moved sharness tests to a subdir. 2015-01-07 07:10:17 -08:00
bin moved sharness tests to a subdir. 2015-01-07 07:10:17 -08:00
Makefile Merge branch 'version/0.4.3-rc4' 2016-09-20 19:10:10 -07:00
README.md Add test cases for ipfs api check 2015-08-27 18:30:28 +07:00
t0010-basic-commands.sh Added tests for ipfs --version. 2016-07-26 19:41:20 -04:00
t0015-basic-sh-functions.sh Add t0015-basic-sh-functions.sh 2015-10-03 12:27:01 +02:00
t0020-init.sh Changed so only explicit ipfs cli commands are lowercased 2016-10-27 22:55:13 -07: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 starting to rework stdin handling 2016-07-07 16:58:43 -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 t0031: ensure iptb init happens 2016-02-29 16:05:48 -08:00
t0040-add-and-cat.sh bubble up go-datastore deps 2016-11-28 22:29:38 -08: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 sort output in tests 2016-01-12 08:22:55 -08:00
t0044-add-symlink.sh Add back still useful test from fe7b01f1 (Resolve symlink if ...) 2016-08-29 16:10:46 -04:00
t0045-ls.sh trailing whitespace 2016-02-29 16:05:48 -08: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 Merge pull request #2516 from Stebalien/protobuf-content-type 2016-05-28 23:28:45 -07:00
t0052-object-diff.sh Fixed tests 2016-05-10 10:39:53 -04:00
t0053-dag.sh clean up some code, update cbor package, and add tests 2016-10-27 15:49:41 -07:00
t0060-daemon.sh add better test to be more sure that file descriptor limits were actually raised 2016-09-02 07:15:08 -07:00
t0061-daemon-opts.sh gateway: clean up its surface, and remove BlockList 2016-06-19 00:52:35 +02:00
t0062-daemon-api.sh t0062: fix indentation 2016-02-19 04:24:12 +01: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 fix tests for changed migrations text 2016-08-30 21:37:45 -07:00
t0070-user-config.sh fix(fsrepo): use "please run ipfs init" message 2015-01-13 03:09:32 -08:00
t0080-repo.sh test: accept more than one digit in repo version tests 2016-08-26 18:23:40 +02:00
t0081-repo-pinning.sh fix test now that dag batches can more properly fail 2016-02-20 16:21:04 -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 update HashOnRead validation to properly support cids 2016-10-18 16:03:26 -07:00
t0085-pins.sh ignore those last bits, this time its for real 2016-07-08 14:35:18 -07:00
t0086-repo-verify.sh repo/verify: add better testing on repo verify command 2016-08-29 22:55:06 -07:00
t0090-get.sh Changed so only explicit ipfs cli commands are lowercased 2016-10-27 22:55:13 -07:00
t0100-name.sh Add newline to end of the output for a few commands. 2015-11-29 11:50:48 -06:00
t0101-iptb-name.sh iptb-lib: add startup_cluster() 2016-02-01 23:22:35 +01:00
t0110-gateway.sh Add sharness test for raw node fetch 2016-11-21 18:15:40 +01: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 and special case that one thing because why not 2016-07-09 11:33:02 -07:00
t0121-bootstrap-iptb.sh trailing whitespace 2016-02-29 16:05:48 -08:00
t0130-multinode.sh remove utp tests for now 2016-09-26 00:52:19 -07: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 add a test for swarm connect not triggering a backoff 2016-07-05 14:44:19 -07: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
t0170-dht.sh update to libp2p 4.0.1 and propogate other changes 2016-10-05 22:12:43 -07:00
t0180-pubsub.sh cmd/pubsub: fix peers command topic filtering 2016-12-08 21:26:09 -08: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 bitswap: clear wantlists when GetBlocks calls are cancelled 2016-09-04 06:44:21 -07: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 CLI: discoverability and consistency (#2542) 2016-04-28 14:08:32 -07:00
t0240-republisher.sh clean up dependencies 2016-03-23 11:54:26 -07:00
t0250-files-api.sh mfs: fix copying into directory with no given filename 2016-07-19 07:41:00 -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
t0300-docker-image.sh docker: take version suffixes like -dev into account 2016-07-03 01:45:02 +02:00
t0400-api-security.sh daemon: reintroduce --unrestricted-api 2016-07-09 00:07:36 +02: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 test: check if metrics work in sharness 2016-10-18 12:28:50 +02: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 "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