summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2011-09-23 14:16:22 -0700
committerJunio C Hamano <gitster@pobox.com>2011-09-23 14:16:22 -0700
commit503359f13abc251ecbcd6a135918efbc58a4e6f6 (patch)
tree514086a43e1247efa9a31265557440ec8f2d5c01
parent40ffc49876611150104102d59a35d865e4670bd7 (diff)
parente9d4f7405b6ab399ef0ea62a796c646de676555d (diff)
downloadgit-503359f13abc251ecbcd6a135918efbc58a4e6f6.tar.gz
Merge branch 'mg/branch-set-upstream-previous' into maint
* mg/branch-set-upstream-previous: branch.c: use the parsed branch name
-rw-r--r--branch.c2
-rwxr-xr-xt/t6040-tracking-info.sh14
2 files changed, 15 insertions, 1 deletions
diff --git a/branch.c b/branch.c
index c0c865a4b1..d62cc0132c 100644
--- a/branch.c
+++ b/branch.c
@@ -210,7 +210,7 @@ void create_branch(const char *head,
start_name);
if (real_ref && track)
- setup_tracking(name, real_ref, track);
+ setup_tracking(ref.buf+11, real_ref, track);
if (!dont_change_ref)
if (write_ref_sha1(lock, sha1, msg) < 0)
diff --git a/t/t6040-tracking-info.sh b/t/t6040-tracking-info.sh
index a9b0ac1efc..19de5b16eb 100755
--- a/t/t6040-tracking-info.sh
+++ b/t/t6040-tracking-info.sh
@@ -110,4 +110,18 @@ test_expect_success '--set-upstream does not change branch' '
grep -q "^refs/heads/master$" actual &&
cmp expect2 actual2
'
+
+test_expect_success '--set-upstream @{-1}' '
+ git checkout from-master &&
+ git checkout from-master2 &&
+ git config branch.from-master2.merge > expect2 &&
+ git branch --set-upstream @{-1} follower &&
+ git config branch.from-master.merge > actual &&
+ git config branch.from-master2.merge > actual2 &&
+ git branch --set-upstream from-master follower &&
+ git config branch.from-master.merge > expect &&
+ test_cmp expect2 actual2 &&
+ test_cmp expect actual
+'
+
test_done