#!/bin/sh # # Copyright (c) 2015 Jeromy Johnson # MIT Licensed; see the LICENSE file in this repository. # test_description="test the unix files api" . lib/test-lib.sh test_init_ipfs create_files() { FILE1=$(echo foo | ipfs add "$@" -q) && FILE2=$(echo bar | ipfs add "$@" -q) && FILE3=$(echo baz | ipfs add "$@" -q) && mkdir -p stuff_test && echo cats > stuff_test/a && echo dogs > stuff_test/b && echo giraffes > stuff_test/c && DIR1=$(ipfs add -r "$@" -q stuff_test | tail -n1) } verify_path_exists() { # simply running ls on a file should be a good 'check' ipfs files ls $1 } verify_dir_contents() { dir=$1 shift rm -f expected touch expected for e in $@ do echo $e >> expected done test_expect_success "can list dir" ' ipfs files ls $dir > output ' test_expect_success "dir entries look good" ' test_sort_cmp output expected ' } test_sharding() { test_expect_success "make a directory" ' ipfs files mkdir /foo ' test_expect_success "can make 100 files in a directory" ' printf "" > list_exp_raw for i in `seq 100` do echo $i | ipfs files write --create /foo/file$i echo file$i >> list_exp_raw done ' test_expect_success "listing works" ' ipfs files ls /foo |sort > list_out && sort list_exp_raw > list_exp && test_cmp list_exp list_out ' test_expect_success "can read a file from sharded directory" ' ipfs files read /foo/file65 > file_out && echo "65" > file_exp && test_cmp file_out file_exp ' test_expect_success "can pin a file from sharded directory" ' ipfs files stat --hash /foo/file42 > pin_file_hash && ipfs pin add < pin_file_hash > pin_hash ' test_expect_success "can unpin a file from sharded directory" ' read -r _ HASH _ < pin_hash && ipfs pin rm $HASH ' test_expect_success "output object was really sharded" ' ipfs files stat --hash /foo > expected_foo_hash && echo QmPkwLJTYZRGPJ8Lazr9qPdrLmswPtUjaDbEpmR9jEh1se > actual_foo_hash && test_cmp expected_foo_hash actual_foo_hash ' } test_files_api() { ROOT_HASH=$1 test_expect_success "can mkdir in root" ' ipfs files mkdir /cats ' test_expect_success "'files ls' lists root by default" ' ipfs files ls >actual && echo "cats" >expected && test_cmp expected actual ' test_expect_success "directory was created" ' verify_path_exists /cats ' test_expect_success "directory is empty" ' verify_dir_contents /cats ' # we do verification of stat formatting now as we depend on it test_expect_success "stat works" ' ipfs files stat / >stat ' test_expect_success "hash is first line of stat" ' ipfs ls $(head -1 stat) | grep "cats" ' test_expect_success "stat --hash gives only hash" ' ipfs files stat --hash / >actual && head -n1 stat >expected && test_cmp expected actual ' test_expect_success "stat with multiple format options should fail" ' test_must_fail ipfs files stat --hash --size / ' test_expect_success "compare hash option with format" ' ipfs files stat --hash / >expected && ipfs files stat --format='"'"''"'"' / >actual && test_cmp expected actual ' test_expect_success "compare size option with format" ' ipfs files stat --size / >expected && ipfs files stat --format='"'"''"'"' / >actual && test_cmp expected actual ' test_expect_success "check root hash" ' ipfs files stat --hash / > roothash ' test_expect_success "cannot mkdir /" ' test_expect_code 1 ipfs files mkdir / ' test_expect_success "check root hash was not changed" ' ipfs files stat --hash / > roothashafter && test_cmp roothash roothashafter ' test_expect_success "can put files into directory" ' ipfs files cp /ipfs/$FILE1 /cats/file1 ' test_expect_success "file shows up in directory" ' verify_dir_contents /cats file1 ' test_expect_success "file has correct hash and size in directory" ' echo "file1 $FILE1 4" > ls_l_expected && ipfs files ls -l /cats > ls_l_actual && test_cmp ls_l_expected ls_l_actual ' test_expect_success "can read file" ' ipfs files read /cats/file1 > file1out ' test_expect_success "output looks good" ' echo foo > expected && test_cmp expected file1out ' test_expect_success "can put another file into root" ' ipfs files cp /ipfs/$FILE2 /file2 ' test_expect_success "file shows up in root" ' verify_dir_contents / file2 cats ' test_expect_success "can read file" ' ipfs files read /file2 > file2out ' test_expect_success "output looks good" ' echo bar > expected && test_cmp expected file2out ' test_expect_success "can make deep directory" ' ipfs files mkdir -p /cats/this/is/a/dir ' test_expect_success "directory was created correctly" ' verify_path_exists /cats/this/is/a/dir && verify_dir_contents /cats this file1 && verify_dir_contents /cats/this is && verify_dir_contents /cats/this/is a && verify_dir_contents /cats/this/is/a dir && verify_dir_contents /cats/this/is/a/dir ' test_expect_success "can copy file into new dir" ' ipfs files cp /ipfs/$FILE3 /cats/this/is/a/dir/file3 ' test_expect_success "can read file" ' ipfs files read /cats/this/is/a/dir/file3 > output ' test_expect_success "output looks good" ' echo baz > expected && test_cmp expected output ' test_expect_success "file shows up in dir" ' verify_dir_contents /cats/this/is/a/dir file3 ' test_expect_success "can remove file" ' ipfs files rm /cats/this/is/a/dir/file3 ' test_expect_success "file no longer appears" ' verify_dir_contents /cats/this/is/a/dir ' test_expect_success "can remove dir" ' ipfs files rm -r /cats/this/is/a/dir ' test_expect_success "dir no longer appears" ' verify_dir_contents /cats/this/is/a ' test_expect_success "can remove file from root" ' ipfs files rm /file2 ' test_expect_success "file no longer appears" ' verify_dir_contents / cats ' test_expect_success "check root hash" ' ipfs files stat --hash / > roothash ' test_expect_success "cannot remove root" ' test_expect_code 1 ipfs files rm -r / ' test_expect_success "check root hash was not changed" ' ipfs files stat --hash / > roothashafter && test_cmp roothash roothashafter ' # test read options test_expect_success "read from offset works" ' ipfs files read -o 1 /cats/file1 > output ' test_expect_success "output looks good" ' echo oo > expected && test_cmp expected output ' test_expect_success "read with size works" ' ipfs files read -n 2 /cats/file1 > output ' test_expect_success "output looks good" ' printf fo > expected && test_cmp expected output ' test_expect_success "cannot read from negative offset" ' test_expect_code 1 ipfs files read --offset -3 /cats/file1 ' test_expect_success "read from offset 0 works" ' ipfs files read --offset 0 /cats/file1 > output ' test_expect_success "output looks good" ' echo foo > expected && test_cmp expected output ' test_expect_success "read last byte works" ' ipfs files read --offset 2 /cats/file1 > output ' test_expect_success "output looks good" ' echo o > expected && test_cmp expected output ' test_expect_success "offset past end of file fails" ' test_expect_code 1 ipfs files read --offset 5 /cats/file1 ' test_expect_success "cannot read negative count bytes" ' test_expect_code 1 ipfs read --count -1 /cats/file1 ' test_expect_success "reading zero bytes prints nothing" ' ipfs files read --count 0 /cats/file1 > output ' test_expect_success "output looks good" ' printf "" > expected && test_cmp expected output ' test_expect_success "count > len(file) prints entire file" ' ipfs files read --count 200 /cats/file1 > output ' test_expect_success "output looks good" ' echo foo > expected && test_cmp expected output ' # test write test_expect_success "can write file" ' echo "ipfs rocks" > tmpfile && cat tmpfile | ipfs files write --create /cats/ipfs ' test_expect_success "file was created" ' verify_dir_contents /cats ipfs file1 this ' test_expect_success "can read file we just wrote" ' ipfs files read /cats/ipfs > output ' test_expect_success "can write to offset" ' echo "is super cool" | ipfs files write -o 5 /cats/ipfs ' test_expect_success "file looks correct" ' echo "ipfs is super cool" > expected && ipfs files read /cats/ipfs > output && test_cmp expected output ' test_expect_success "cant write to negative offset" ' ipfs files stat --hash /cats/ipfs > filehash && test_expect_code 1 ipfs files write --offset -1 /cats/ipfs < output ' test_expect_success "verify file was not changed" ' ipfs files stat --hash /cats/ipfs > afterhash && test_cmp filehash afterhash ' test_expect_success "write new file for testing" ' echo foobar | ipfs files write --create /fun ' test_expect_success "write to offset past end works" ' echo blah | ipfs files write --offset 50 /fun ' test_expect_success "can read file" ' ipfs files read /fun > sparse_output ' test_expect_success "output looks good" ' echo foobar > sparse_expected && echo blah | dd of=sparse_expected bs=50 seek=1 && test_cmp sparse_expected sparse_output ' test_expect_success "cleanup" ' ipfs files rm /fun ' test_expect_success "cannot write to directory" ' ipfs files stat --hash /cats > dirhash && test_expect_code 1 ipfs files write /cats < output ' test_expect_success "verify dir was not changed" ' ipfs files stat --hash /cats > afterdirhash && test_cmp dirhash afterdirhash ' test_expect_success "cannot write to nonexistant path" ' test_expect_code 1 ipfs files write /cats/bar/ < output ' test_expect_success "no new paths were created" ' verify_dir_contents /cats file1 ipfs this ' test_expect_success "write 'no-flush' succeeds" ' echo "testing" | ipfs files write -f=false -e /cats/walrus ' test_expect_success "root hash not bubbled up yet" ' test -z "$ONLINE" || (ipfs refs local > refsout && test_expect_code 1 grep $ROOT_HASH refsout) ' test_expect_success "changes bubbled up to root on inspection" ' ipfs files stat --hash / > root_hash ' test_expect_success "root hash looks good" ' export EXP_ROOT_HASH="$ROOT_HASH" && echo $EXP_ROOT_HASH > root_hash_exp && test_cmp root_hash_exp root_hash ' test_expect_success "flush root succeeds" ' ipfs files flush / ' # test mv test_expect_success "can mv dir" ' ipfs files mv /cats/this/is /cats/ ' test_expect_success "mv worked" ' verify_dir_contents /cats file1 ipfs this is walrus && verify_dir_contents /cats/this ' test_expect_success "cleanup, remove 'cats'" ' ipfs files rm -r /cats ' test_expect_success "cleanup looks good" ' verify_dir_contents / ' # test truncating test_expect_success "create a new file" ' echo "some content" | ipfs files write --create /cats ' test_expect_success "truncate and write over that file" ' echo "fish" | ipfs files write --truncate /cats ' test_expect_success "output looks good" ' ipfs files read /cats > file_out && echo "fish" > file_exp && test_cmp file_out file_exp ' test_expect_success "cleanup" ' ipfs files rm /cats ' # test flush flags test_expect_success "mkdir --flush works" ' ipfs files mkdir --flush --parents /flushed/deep ' test_expect_success "mkdir --flush works a second time" ' ipfs files mkdir --flush --parents /flushed/deep ' test_expect_success "dir looks right" ' verify_dir_contents / flushed ' test_expect_success "child dir looks right" ' verify_dir_contents /flushed deep ' test_expect_success "cleanup" ' ipfs files rm -r /flushed ' test_expect_success "child dir looks right" ' verify_dir_contents / ' # test for https://github.com/ipfs/go-ipfs/issues/2654 test_expect_success "create and remove dir" ' ipfs files mkdir /test_dir && ipfs files rm -r "/test_dir" ' test_expect_success "create test file" ' echo "content" | ipfs files write -e "/test_file" ' test_expect_success "copy test file onto test dir" ' ipfs files cp "/test_file" "/test_dir" ' test_expect_success "test /test_dir" ' ipfs files stat "/test_dir" | grep -q "^Type: file" ' test_expect_success "clean up /test_dir and /test_file" ' ipfs files rm -r /test_dir && ipfs files rm -r /test_file ' test_expect_success "make a directory and a file" ' ipfs files mkdir /adir && echo "blah" | ipfs files write --create /foobar ' test_expect_success "copy a file into a directory" ' ipfs files cp /foobar /adir/ ' test_expect_success "file made it into directory" ' ipfs files ls /adir | grep foobar ' test_expect_success "clean up" ' ipfs files rm -r /foobar && ipfs files rm -r /adir ' test_expect_success "root mfs entry is empty" ' verify_dir_contents / ' test_expect_success "repo gc" ' ipfs repo gc ' } # test offline and online test_expect_success "can create some files for testing" ' create_files ' test_files_api QmcwKfTMCT7AaeiD92hWjnZn9b6eh9NxnhfSzN5x2vnDpt test_expect_success "can create some files for testing with raw-leaves" ' create_files --raw-leaves ' test_files_api QmTpKiKcAj4sbeesN6vrs5w3QeVmd4QmGpxRL81hHut4dZ test_launch_ipfs_daemon --offline ONLINE=1 # set online flag so tests can easily tell test_expect_success "can create some files for testing" ' create_files ' test_files_api QmcwKfTMCT7AaeiD92hWjnZn9b6eh9NxnhfSzN5x2vnDpt test_expect_success "can create some files for testing with raw-leaves" ' create_files --raw-leaves ' test_files_api QmTpKiKcAj4sbeesN6vrs5w3QeVmd4QmGpxRL81hHut4dZ test_kill_ipfs_daemon --offline test_expect_success "enable sharding in config" ' ipfs config --json Experimental.ShardingEnabled true ' test_launch_ipfs_daemon --offline test_sharding test_kill_ipfs_daemon test_done