Browse Source

Merge branch 'dm/svn-remote'

* dm/svn-remote:
  git-svn: Make branch use correct svn-remote
maint
Junio C Hamano 16 years ago
parent
commit
123ed65908
  1. 2
      git-svn.perl
  2. 19
      t/t9128-git-svn-cmd-branch.sh

2
git-svn.perl

@ -558,7 +558,7 @@ sub cmd_branch { @@ -558,7 +558,7 @@ sub cmd_branch {

my ($src, $rev, undef, $gs) = working_head_info($head);

my $remote = Git::SVN::read_all_remotes()->{svn};
my $remote = Git::SVN::read_all_remotes()->{$gs->{repo_id}};
my $glob = $remote->{ $_tag ? 'tags' : 'branches' };
my ($lft, $rgt) = @{ $glob->{path} }{qw/left right/};
my $dst = join '/', $remote->{url}, $lft, $branch_name, ($rgt || ());

19
t/t9128-git-svn-cmd-branch.sh

@ -56,4 +56,23 @@ test_expect_success 'git svn branch tests' ' @@ -56,4 +56,23 @@ test_expect_success 'git svn branch tests' '
test_must_fail git svn tag tag1
'

test_expect_success 'branch uses correct svn-remote' '
(svn co "$svnrepo" svn &&
cd svn &&
mkdir mirror &&
svn add mirror &&
svn copy trunk mirror/ &&
svn copy tags mirror/ &&
svn copy branches mirror/ &&
svn ci -m "made mirror" ) &&
rm -rf svn &&
git svn init -s -R mirror --prefix=mirror/ "$svnrepo"/mirror &&
git svn fetch -R mirror &&
git checkout mirror/trunk &&
base=$(git rev-parse HEAD:) &&
git svn branch -m "branch in mirror" d &&
test $base = $(git rev-parse remotes/mirror/d:) &&
test_must_fail git rev-parse remotes/d
'

test_done

Loading…
Cancel
Save