kubo/test/sharness
Juan Benet d4938c9b0c Merge pull request #1777 from rht/test/add
Add trickle and chunker test
2015-10-03 19:40:31 -04:00
..
lib test-lib: improve test_check_peerid 2015-09-12 19:27:55 +02:00
t0051-object-data t0051: add UTF-8 test file 2015-08-24 23:05:48 +02: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 added random-files tool for testing 2015-07-29 03:18:24 -07:00
README.md Add test cases for ipfs api check 2015-08-27 18:30:28 +07:00
t0010-basic-commands.sh Replace fsh with test_fsh in sharness tests 2015-02-04 21:53:19 +01:00
t0015-basic-sh-functions.sh Add t0015-basic-sh-functions.sh 2015-10-03 12:27:01 +02:00
t0020-init.sh sharness: generalize test_check_peerid() 2015-09-12 19:00:26 +02:00
t0021-config.sh config set: test setting with null & not-defined parent 2015-08-13 19:41:41 +07:00
t0030-mount.sh t0030: expect good ipfs mount output 2015-04-21 16:00:07 +02:00
t0040-add-and-cat.sh sharness: add trickle and chunker test 2015-10-03 09:03:09 +07:00
t0042-add-skip.sh t0042: fix test indentation 2015-08-21 20:29:18 +02:00
t0043-add-w.sh cmds/add: use dagutils.Editor, like patch 2015-08-12 08:24:06 +02:00
t0044-add-symlink.sh add tests for symlinks 2015-09-02 12:59:09 -07:00
t0045-ls.sh core/commands/ls: Remove trailing tabs 2015-06-09 06:23:44 -07:00
t0050-block.sh moved sharness tests to a subdir. 2015-01-07 07:10:17 -08:00
t0051-object.sh t0051: swap test_cmp arguments 2015-10-03 23:26:20 +02:00
t0060-daemon.sh t0060: simplify peerid check 2015-09-12 19:06:50 +02:00
t0061-daemon-opts.sh test-lib: use all the test_launch_ipfs_daemon() arguments 2015-08-28 05:17:27 +02:00
t0062-daemon-api.sh t0062: add peerid check 2015-09-12 19:14:34 +02:00
t0070-user-config.sh fix(fsrepo): use "please run ipfs init" message 2015-01-13 03:09:32 -08:00
t0080-repo.sh Bump version of dir-index-html 2015-09-05 01:06:35 +07:00
t0081-repo-pinning.sh t0081: swap test_cmp arguments 2015-10-03 23:49:01 +02:00
t0090-get.sh Sharness: add test for compression level 2015-09-23 19:08:26 +07:00
t0100-name.sh t0100: swap test_cmp arguments 2015-10-04 00:02:17 +02:00
t0110-gateway.sh t0110: add peerid check 2015-09-12 19:10:18 +02:00
t0120-bootstrap.sh t0120: add missing && 2015-10-04 00:08:16 +02:00
t0140-swarm.sh ipfs swarm addrs local - show local addrs 2015-06-26 23:36:42 -07:00
t0141-addfilter.sh config: DialBlocklist -> Swarm.AddrFilters 2015-07-02 16:11:46 -07:00
t0150-clisuggest.sh Better error message on unrecognized command 2015-07-28 09:20:53 -06:00
t0200-unixfs-ls.sh core/commands/unixfs/ls: Explicitily record stat in LsObject 2015-06-20 13:34:47 -07:00
t0210-tar.sh add sharness test for tar commands 2015-09-10 17:11:35 -07:00
t0220-bitswap.sh add a basic test for unwant 2015-09-14 15:26:09 -07:00
t0230-channel-streaming-http-content-type.sh remove hard-coded json content-type for streaming http output 2015-09-24 19:13:29 -07:00
t0240-republisher.sh t0240: swap 'resolve' and 'expected' 2015-10-03 22:46:10 +02:00
x0045-add-cat-iptb.sh add a test for issue repro 2015-06-03 08:41:25 -07:00
x0111-gateway-writable.sh core: add context.Context param to core.Resolve() 2015-05-08 03:14:32 +02:00
xt0101-iptb-name.sh disable constantly failing iptb tests 2015-05-31 16:05:31 -07:00
xt0130-multinode.sh disable constantly failing iptb tests 2015-05-31 16:05:31 -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