1
0
Fork 0
mirror of https://github.com/git/git.git synced 2024-06-01 15:56:08 +02:00

contrib/subtree: respect spaces in a repository path

Remote repository may have spaces in its path, so take it into account.

Also, as far as there are no tests for the `push` command, add them.

Signed-off-by: Alexey Shumkin <Alex.Crezoff@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Alexey Shumkin 2015-09-05 01:24:11 +03:00 committed by Junio C Hamano
parent c61eb4106d
commit 5b6ab38bd3
2 changed files with 48 additions and 1 deletions

View File

@ -735,7 +735,7 @@ cmd_push()
refspec=$2
echo "git push using: " $repository $refspec
localrev=$(git subtree split --prefix="$prefix") || die
git push $repository $localrev:refs/heads/$refspec
git push "$repository" $localrev:refs/heads/$refspec
else
die "'$dir' must already exist. Try 'git subtree add'."
fi

View File

@ -1,6 +1,7 @@
#!/bin/sh
#
# Copyright (c) 2012 Avery Pennaraum
# Copyright (c) 2015 Alexey Shumkin
#
test_description='Basic porcelain support for subtrees
@ -471,4 +472,50 @@ test_expect_success 'verify one file change per commit' '
))
'
# test push
cd ../..
mkdir test-push
cd test-push
test_expect_success 'init main' '
test_create_repo main
'
test_expect_success 'init sub' '
test_create_repo "sub project"
'
cd ./"sub project"
test_expect_success 'add subproject' '
create "sub project" &&
git commit -m "Sub project: 1" &&
git branch sub-branch-1
'
cd ../main
test_expect_success 'make first commit and add subproject' '
create "main-1" &&
git commit -m "main: 1" &&
git subtree add "../sub project" --prefix "sub dir" --message "Added subproject" sub-branch-1 &&
check_equal "$(last_commit_message)" "Added subproject"
'
test_expect_success 'make second commit to a subproject file and push it into a sub project' '
create "sub dir/sub1" &&
git commit -m "Sub project: 2" &&
git subtree push "../sub project" --prefix "sub dir" sub-branch-1
'
cd ../"sub project"
test_expect_success 'Test second commit is pushed' '
git checkout sub-branch-1 &&
check_equal "$(last_commit_message)" "Sub project: 2"
'
test_done