| #!/bin/sh |
| |
| test_description="Test whether cache-tree is properly updated |
| |
| Tests whether various commands properly update and/or rewrite the |
| cache-tree extension. |
| " |
| . ./test-lib.sh |
| |
| cmp_cache_tree () { |
| test-dump-cache-tree >actual && |
| sed "s/$_x40/SHA/" <actual >filtered && |
| test_cmp "$1" filtered |
| } |
| |
| # We don't bother with actually checking the SHA1: |
| # test-dump-cache-tree already verifies that all existing data is |
| # correct. |
| test_shallow_cache_tree () { |
| printf "SHA (%d entries, 0 subtrees)\n" $(git ls-files|wc -l) >expect && |
| cmp_cache_tree expect |
| } |
| |
| test_invalid_cache_tree () { |
| echo "invalid (0 subtrees)" >expect && |
| printf "SHA #(ref) (%d entries, 0 subtrees)\n" $(git ls-files|wc -l) >>expect && |
| cmp_cache_tree expect |
| } |
| |
| test_no_cache_tree () { |
| : >expect && |
| cmp_cache_tree expect |
| } |
| |
| test_expect_failure 'initial commit has cache-tree' ' |
| test_commit foo && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_success 'read-tree HEAD establishes cache-tree' ' |
| git read-tree HEAD && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_success 'git-add invalidates cache-tree' ' |
| test_when_finished "git reset --hard; git read-tree HEAD" && |
| echo "I changed this file" > foo && |
| git add foo && |
| test_invalid_cache_tree |
| ' |
| |
| test_expect_success 'update-index invalidates cache-tree' ' |
| test_when_finished "git reset --hard; git read-tree HEAD" && |
| echo "I changed this file" > foo && |
| git update-index --add foo && |
| test_invalid_cache_tree |
| ' |
| |
| test_expect_success 'write-tree establishes cache-tree' ' |
| test-scrap-cache-tree && |
| git write-tree && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_success 'test-scrap-cache-tree works' ' |
| git read-tree HEAD && |
| test-scrap-cache-tree && |
| test_no_cache_tree |
| ' |
| |
| test_expect_success 'second commit has cache-tree' ' |
| test_commit bar && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_success 'reset --hard gives cache-tree' ' |
| test-scrap-cache-tree && |
| git reset --hard && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_success 'reset --hard without index gives cache-tree' ' |
| rm -f .git/index && |
| git reset --hard && |
| test_shallow_cache_tree |
| ' |
| |
| test_expect_failure 'checkout gives cache-tree' ' |
| git checkout HEAD^ && |
| test_shallow_cache_tree |
| ' |
| |
| test_done |