kubo/test/sharness
Stephen Whitmore 0a45ada4ed CLI: discoverability and consistency (#2542)
* reduces help indent from 4 to 2 spaces

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* reduces horz/vert space taken by "ipfs" cmd

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* show subcommands on shorthelp

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Drops colons at the end of cmd headings.

This makes command headings consistent with the output of 'ipfs', which
does not include colons.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* more consistent output between short-/long-help

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Puts DESCRIPTION before SUBCOMMANDS.

Users likely want to understand what a command does before worrying
about its subcommands.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Keeps ipfs cmd from outputting its subcmds twice.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant synopsis from "file"

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes extra whitespace from longhelp

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Consistent spacing whether SUBCMDS or not.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant SUBCMD output from ipfs object.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant synopsis from "name"

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Newline after Description only if it exists.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant synopsis from "bootstrap"

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant synopsis from "swarm"

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes trailing newline in ping help.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Prints shorthelp on parse error.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* tiny comment fixes

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* updates README usage

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Don't include extra whitespace if no .MoreHelp

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* description improvements

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Hides the obscure 'file' subcommand.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Splits 'ipfs daemon' into Short and Long help.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes redundant synopsis from "config"

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Wraps lines to keep from going over 80.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* specify repo separately

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* s/structure/hierarchy

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* missing .

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes trailing colon from 'usage' test.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Updates sharness test error messages.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes trailing colon from 'usage' test.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Updates add-symlink to use /bin/sh.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Removes "hierarchy".

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>

* Updates "ipfs ping" synopsis.

* Updates t0040 with latest wording.

* Removes unnecessary daemon setup.

License: MIT
Signed-off-by: Stephen Whitmore <noffle@ipfs.io>
2016-04-28 14:08:32 -07:00
..
lib make t0060 use port zero 2016-03-02 15:00:04 -08: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 sharness/Makefile: clean all BINS when cleaning 2016-04-03 13:02:04 +02:00
README.md Add test cases for ipfs api check 2015-08-27 18:30:28 +07:00
t0010-basic-commands.sh CLI: discoverability and consistency (#2542) 2016-04-28 14:08:32 -07:00
t0015-basic-sh-functions.sh Add t0015-basic-sh-functions.sh 2015-10-03 12:27:01 +02:00
t0020-init.sh sharness: replace POSIX prereq with STD_ERR_MSG 2016-02-22 22:13:30 +01:00
t0021-config.sh t0021: test 'ipfs config show' 2015-10-29 16:26:52 +01:00
t0030-mount.sh t0030: expect good ipfs mount output 2015-04-21 16:00:07 +02:00
t0031-mount-publish.sh t0031: ensure iptb init happens 2016-02-29 16:05:48 -08:00
t0040-add-and-cat.sh CLI: discoverability and consistency (#2542) 2016-04-28 14:08:32 -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 sort output in tests 2016-01-12 08:22:55 -08:00
t0044-add-symlink.sh CLI: discoverability and consistency (#2542) 2016-04-28 14:08:32 -07:00
t0045-ls.sh trailing whitespace 2016-02-29 16:05:48 -08:00
t0050-block.sh moved sharness tests to a subdir. 2015-01-07 07:10:17 -08:00
t0051-object.sh Adds tests to make sure 'object patch' writes. 2016-04-12 17:22:06 -07:00
t0052-object-diff.sh changes from CR feedback 2016-04-16 12:23:34 -07:00
t0060-daemon.sh CLI: discoverability and consistency (#2542) 2016-04-28 14:08:32 -07:00
t0061-daemon-opts.sh use nc -w instead of -q because osx is slow 2016-04-07 15:55:41 -07: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
t0070-user-config.sh fix(fsrepo): use "please run ipfs init" message 2015-01-13 03:09:32 -08:00
t0080-repo.sh repo-stat 2016-03-04 23:45:03 +00: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 commands: repo fsck (#2597) 2016-04-27 13:28:53 -07:00
t0090-get.sh small sharness test for promise failure checking 2016-04-12 11:21:34 -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 fix whitespace trimming 2016-03-14 16:36:31 -07:00
t0111-gateway-writeable.sh Use port zero for all ipfs daemon addresses in sharness testing 2016-02-12 14:04:32 -08:00
t0112-gateway-cors.sh Use port zero for all ipfs daemon addresses in sharness testing 2016-02-12 14:04:32 -08:00
t0120-bootstrap.sh config: update pluto's peerID 2015-10-19 21:04:42 +02:00
t0121-bootstrap-iptb.sh trailing whitespace 2016-02-29 16:05:48 -08:00
t0130-multinode.sh add new test to show problem 2016-03-09 09:50:00 -08:00
t0140-swarm.sh add small test to ensure ipfs id <self> works 2015-10-19 22:07:39 -07:00
t0141-addfilter.sh sharness: swap test_*cmp arguments 2015-10-04 11:39:22 +02:00
t0150-clisuggest.sh Better error message on unrecognized command 2015-07-28 09:20:53 -06:00
t0151-sysdiag.sh add small sharness test to make sure output happens 2015-10-18 19:50:15 -07: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 unix-friendly output for 'ipfs dht' commands (#2560) 2016-04-27 09:31:06 -07: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 t0220: show breakage with ipfs bitswap wantlist -p 2015-10-29 15:37:58 +01:00
t0230-channel-streaming-http-content-type.sh fix double transfer encoding head problem 2016-03-14 16:26:49 -07: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 Merge pull request #2382 from ipfs/fix/mfs-truncate 2016-02-23 10:42:06 -08:00
t0251-files-flushing.sh blockstore locks return unlocker object now 2016-02-08 14:42:07 -08:00
t0300-docker-image.sh t0300: improve docker_build debug message 2016-03-07 10:35:52 +01: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