diff options
Diffstat (limited to '')
-rwxr-xr-x | t/t3050-subprojects-fetch.sh | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/t/t3050-subprojects-fetch.sh b/t/t3050-subprojects-fetch.sh new file mode 100755 index 0000000..3884694 --- /dev/null +++ b/t/t3050-subprojects-fetch.sh @@ -0,0 +1,53 @@ +#!/bin/sh + +test_description='fetching and pushing project with subproject' + +TEST_PASSES_SANITIZE_LEAK=true +. ./test-lib.sh + +test_expect_success setup ' + test_tick && + mkdir -p sub && ( + cd sub && + git init && + >subfile && + git add subfile && + git commit -m "subproject commit #1" + ) && + >mainfile && + git add sub mainfile && + test_tick && + git commit -m "superproject commit #1" +' + +test_expect_success clone ' + git clone "file://$(pwd)/.git" cloned && + (git rev-parse HEAD && git ls-files -s) >expected && + ( + cd cloned && + (git rev-parse HEAD && git ls-files -s) >../actual + ) && + test_cmp expected actual +' + +test_expect_success advance ' + echo more >mainfile && + git update-index --force-remove sub && + mv sub/.git sub/.git-disabled && + git add sub/subfile mainfile && + mv sub/.git-disabled sub/.git && + test_tick && + git commit -m "superproject commit #2" +' + +test_expect_success fetch ' + (git rev-parse HEAD && git ls-files -s) >expected && + ( + cd cloned && + git pull && + (git rev-parse HEAD && git ls-files -s) >../actual + ) && + test_cmp expected actual +' + +test_done |