diff options
Diffstat (limited to '')
-rwxr-xr-x | t/t7101-reset-empty-subdirs.sh | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/t/t7101-reset-empty-subdirs.sh b/t/t7101-reset-empty-subdirs.sh new file mode 100755 index 0000000..638bb04 --- /dev/null +++ b/t/t7101-reset-empty-subdirs.sh @@ -0,0 +1,66 @@ +#!/bin/sh +# +# Copyright (c) 2006 Shawn Pearce +# + +test_description='git reset should cull empty subdirs' + +TEST_PASSES_SANITIZE_LEAK=true +. ./test-lib.sh +. "$TEST_DIRECTORY"/lib-diff-data.sh + +test_expect_success 'creating initial files' ' + mkdir path0 && + COPYING_test_data >path0/COPYING && + git add path0/COPYING && + git commit -m add -a +' + +test_expect_success 'creating second files' ' + mkdir path1 && + mkdir path1/path2 && + COPYING_test_data >path1/path2/COPYING && + COPYING_test_data >path1/COPYING && + COPYING_test_data >COPYING && + COPYING_test_data >path0/COPYING-TOO && + git add path1/path2/COPYING && + git add path1/COPYING && + git add COPYING && + git add path0/COPYING-TOO && + git commit -m change -a +' + +test_expect_success 'resetting tree HEAD^' ' + git reset --hard HEAD^ +' + +test_expect_success 'checking initial files exist after rewind' ' + test -d path0 && + test -f path0/COPYING +' + +test_expect_success 'checking lack of path1/path2/COPYING' ' + ! test -f path1/path2/COPYING +' + +test_expect_success 'checking lack of path1/COPYING' ' + ! test -f path1/COPYING +' + +test_expect_success 'checking lack of COPYING' ' + ! test -f COPYING +' + +test_expect_success 'checking checking lack of path1/COPYING-TOO' ' + ! test -f path0/COPYING-TOO +' + +test_expect_success 'checking lack of path1/path2' ' + ! test -d path1/path2 +' + +test_expect_success 'checking lack of path1' ' + ! test -d path1 +' + +test_done |