| #!/bin/sh |
| # |
| # Copyright (c) 2010 Sverre Rabbelier |
| # |
| |
| test_description='Test remote-helper import and export commands' |
| |
| GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main |
| export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME |
| |
| . ./test-lib.sh |
| . "$TEST_DIRECTORY"/lib-gpg.sh |
| |
| PATH="$TEST_DIRECTORY/t5801:$PATH" |
| |
| compare_refs() { |
| fail= && |
| if test "x$1" = 'x!' |
| then |
| fail='!' && |
| shift |
| fi && |
| git --git-dir="$1/.git" rev-parse --verify $2 >expect && |
| git --git-dir="$3/.git" rev-parse --verify $4 >actual && |
| eval $fail test_cmp expect actual |
| } |
| |
| test_expect_success 'setup repository' ' |
| git init server && |
| (cd server && |
| echo content >file && |
| git add file && |
| git commit -m one) |
| ' |
| |
| test_expect_success 'cloning from local repo' ' |
| git clone "testgit::${PWD}/server" local && |
| test_cmp server/file local/file |
| ' |
| |
| test_expect_success 'clone with remote.*.vcs config' ' |
| GIT_TRACE=$PWD/vcs-clone.trace \ |
| git clone --no-local -c remote.origin.vcs=testgit "$PWD/server" vcs-clone && |
| test_grep remote-testgit vcs-clone.trace |
| ' |
| |
| test_expect_success 'fetch with configured remote.*.vcs' ' |
| git init vcs-fetch && |
| git -C vcs-fetch config remote.origin.vcs testgit && |
| git -C vcs-fetch config remote.origin.url "$PWD/server" && |
| GIT_TRACE=$PWD/vcs-fetch.trace \ |
| git -C vcs-fetch fetch origin && |
| test_grep remote-testgit vcs-fetch.trace |
| ' |
| |
| test_expect_success 'vcs remote with no url' ' |
| NOURL_UPSTREAM=$PWD/server && |
| export NOURL_UPSTREAM && |
| git init vcs-nourl && |
| git -C vcs-nourl config remote.origin.vcs nourl && |
| git -C vcs-nourl fetch origin |
| ' |
| |
| test_expect_success 'create new commit on remote' ' |
| (cd server && |
| echo content >>file && |
| git commit -a -m two) |
| ' |
| |
| test_expect_success 'pulling from local repo' ' |
| (cd local && git pull) && |
| test_cmp server/file local/file |
| ' |
| |
| test_expect_success 'pushing to local repo' ' |
| (cd local && |
| echo content >>file && |
| git commit -a -m three && |
| git push) && |
| compare_refs local HEAD server HEAD |
| ' |
| |
| test_expect_success 'fetch new branch' ' |
| (cd server && |
| git reset --hard && |
| git checkout -b new && |
| echo content >>file && |
| git commit -a -m five |
| ) && |
| (cd local && |
| git fetch origin new |
| ) && |
| compare_refs server HEAD local FETCH_HEAD |
| ' |
| |
| test_expect_success 'fetch multiple branches' ' |
| (cd local && |
| git fetch |
| ) && |
| compare_refs server main local refs/remotes/origin/main && |
| compare_refs server new local refs/remotes/origin/new |
| ' |
| |
| test_expect_success 'push when remote has extra refs' ' |
| (cd local && |
| git reset --hard origin/main && |
| echo content >>file && |
| git commit -a -m six && |
| git push |
| ) && |
| compare_refs local main server main |
| ' |
| |
| test_expect_success 'push new branch by name' ' |
| (cd local && |
| git checkout -b new-name && |
| echo content >>file && |
| git commit -a -m seven && |
| git push origin new-name |
| ) && |
| compare_refs local HEAD server refs/heads/new-name |
| ' |
| |
| test_expect_success 'push new branch with old:new refspec' ' |
| (cd local && |
| git push origin new-name:new-refspec |
| ) && |
| compare_refs local HEAD server refs/heads/new-refspec |
| ' |
| |
| test_expect_success 'push new branch with HEAD:new refspec' ' |
| (cd local && |
| git checkout new-name && |
| git push origin HEAD:new-refspec-2 |
| ) && |
| compare_refs local HEAD server refs/heads/new-refspec-2 |
| ' |
| |
| test_expect_success 'push delete branch' ' |
| (cd local && |
| git push origin :new-name |
| ) && |
| test_must_fail git --git-dir="server/.git" \ |
| rev-parse --verify refs/heads/new-name |
| ' |
| |
| test_expect_success 'forced push' ' |
| (cd local && |
| git checkout -b force-test && |
| echo content >> file && |
| git commit -a -m eight && |
| git push origin force-test && |
| echo content >> file && |
| git commit -a --amend -m eight-modified && |
| git push --force origin force-test |
| ) && |
| compare_refs local refs/heads/force-test server refs/heads/force-test |
| ' |
| |
| test_expect_success 'cloning without refspec' ' |
| GIT_REMOTE_TESTGIT_NOREFSPEC=1 \ |
| git clone "testgit::${PWD}/server" local2 2>error && |
| test_grep "this remote helper should implement refspec capability" error && |
| compare_refs local2 HEAD server HEAD |
| ' |
| |
| test_expect_success 'pulling without refspecs' ' |
| (cd local2 && |
| git reset --hard && |
| GIT_REMOTE_TESTGIT_NOREFSPEC=1 git pull 2>../error) && |
| test_grep "this remote helper should implement refspec capability" error && |
| compare_refs local2 HEAD server HEAD |
| ' |
| |
| test_expect_success 'pushing without refspecs' ' |
| test_when_finished "(cd local2 && git reset --hard origin)" && |
| (cd local2 && |
| echo content >>file && |
| git commit -a -m ten && |
| GIT_REMOTE_TESTGIT_NOREFSPEC=1 && |
| export GIT_REMOTE_TESTGIT_NOREFSPEC && |
| test_must_fail git push 2>../error) && |
| test_grep "remote-helper doesn.t support push; refspec needed" error |
| ' |
| |
| test_expect_success 'pulling without marks' ' |
| (cd local2 && |
| GIT_REMOTE_TESTGIT_NO_MARKS=1 git pull) && |
| compare_refs local2 HEAD server HEAD |
| ' |
| |
| test_expect_failure 'pushing without marks' ' |
| test_when_finished "(cd local2 && git reset --hard origin)" && |
| (cd local2 && |
| echo content >>file && |
| git commit -a -m twelve && |
| GIT_REMOTE_TESTGIT_NO_MARKS=1 git push) && |
| compare_refs local2 HEAD server HEAD |
| ' |
| |
| test_expect_success 'push all with existing object' ' |
| (cd local && |
| git branch dup2 main && |
| git push origin --all |
| ) && |
| compare_refs local dup2 server dup2 |
| ' |
| |
| test_expect_success 'push ref with existing object' ' |
| (cd local && |
| git branch dup main && |
| git push origin dup |
| ) && |
| compare_refs local dup server dup |
| ' |
| |
| test_expect_success GPG 'push signed tag' ' |
| (cd local && |
| git checkout main && |
| git tag -s -m signed-tag signed-tag && |
| git push origin signed-tag |
| ) && |
| compare_refs local signed-tag^{} server signed-tag^{} && |
| compare_refs ! local signed-tag server signed-tag |
| ' |
| |
| test_expect_success GPG 'push signed tag with signed-tags capability' ' |
| (cd local && |
| git checkout main && |
| git tag -s -m signed-tag signed-tag-2 && |
| GIT_REMOTE_TESTGIT_SIGNED_TAGS=1 git push origin signed-tag-2 |
| ) && |
| compare_refs local signed-tag-2 server signed-tag-2 |
| ' |
| |
| test_expect_success 'push update refs' ' |
| (cd local && |
| git checkout -b update main && |
| echo update >>file && |
| git commit -a -m update && |
| git push origin update && |
| git rev-parse --verify remotes/origin/update >expect && |
| git rev-parse --verify testgit/origin/heads/update >actual && |
| test_cmp expect actual |
| ) |
| ' |
| |
| test_expect_success 'push update refs disabled by no-private-update' ' |
| (cd local && |
| echo more-update >>file && |
| git commit -a -m more-update && |
| git rev-parse --verify testgit/origin/heads/update >expect && |
| GIT_REMOTE_TESTGIT_NO_PRIVATE_UPDATE=t git push origin update && |
| git rev-parse --verify testgit/origin/heads/update >actual && |
| test_cmp expect actual |
| ) |
| ' |
| |
| test_expect_success 'push update refs failure' ' |
| (cd local && |
| git checkout update && |
| echo "update fail" >>file && |
| git commit -a -m "update fail" && |
| git rev-parse --verify testgit/origin/heads/update >expect && |
| test_expect_code 1 env GIT_REMOTE_TESTGIT_FAILURE="non-fast forward" \ |
| git push origin update && |
| git rev-parse --verify testgit/origin/heads/update >actual && |
| test_cmp expect actual |
| ) |
| ' |
| |
| clean_mark () { |
| cut -f 2 -d ' ' "$1" | |
| git cat-file --batch-check | |
| grep commit | |
| sort >$(basename "$1") |
| } |
| |
| test_expect_success 'proper failure checks for fetching' ' |
| (cd local && |
| test_must_fail env GIT_REMOTE_TESTGIT_FAILURE=1 git fetch 2>error && |
| test_grep -q "error while running fast-import" error |
| ) |
| ' |
| |
| test_expect_success 'proper failure checks for pushing' ' |
| test_when_finished "rm -rf local/git.marks local/testgit.marks" && |
| (cd local && |
| git checkout -b crash main && |
| echo crash >>file && |
| git commit -a -m crash && |
| test_must_fail env GIT_REMOTE_TESTGIT_FAILURE=1 git push --all && |
| clean_mark ".git/testgit/origin/git.marks" && |
| clean_mark ".git/testgit/origin/testgit.marks" && |
| test_cmp git.marks testgit.marks |
| ) |
| ' |
| |
| test_expect_success 'push messages' ' |
| (cd local && |
| git checkout -b new_branch main && |
| echo new >>file && |
| git commit -a -m new && |
| git push origin new_branch && |
| git fetch origin && |
| echo new >>file && |
| git commit -a -m new && |
| git push origin new_branch 2> msg && |
| ! grep "\[new branch\]" msg |
| ) |
| ' |
| |
| test_expect_success 'fetch HEAD' ' |
| (cd server && |
| git checkout main && |
| echo more >>file && |
| git commit -a -m more |
| ) && |
| (cd local && |
| git fetch origin HEAD |
| ) && |
| compare_refs server HEAD local FETCH_HEAD |
| ' |
| |
| test_expect_success 'fetch url' ' |
| (cd server && |
| git checkout main && |
| echo more >>file && |
| git commit -a -m more |
| ) && |
| (cd local && |
| git fetch "testgit::${PWD}/../server" |
| ) && |
| compare_refs server HEAD local FETCH_HEAD |
| ' |
| |
| test_expect_success 'fetch tag' ' |
| (cd server && |
| git tag v1.0 |
| ) && |
| (cd local && |
| git fetch |
| ) && |
| compare_refs local v1.0 server v1.0 |
| ' |
| |
| test_done |