#!/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/" 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_success 'checkout gives cache-tree' ' git tag current && git checkout HEAD^ && test_shallow_cache_tree ' test_expect_success 'checkout -b gives cache-tree' ' git checkout current && git checkout -b prev HEAD^ && test_shallow_cache_tree ' test_expect_success 'checkout -B gives cache-tree' ' git checkout current && git checkout -B prev HEAD^ && test_shallow_cache_tree ' test_done