|
|
@ -58,9 +58,11 @@ import java.io.File; |
|
|
|
import java.io.FileOutputStream; |
|
|
|
import java.io.FileOutputStream; |
|
|
|
import java.io.IOException; |
|
|
|
import java.io.IOException; |
|
|
|
import java.util.Map; |
|
|
|
import java.util.Map; |
|
|
|
|
|
|
|
import java.util.TreeSet; |
|
|
|
|
|
|
|
|
|
|
|
import org.eclipse.jgit.lib.Ref.Storage; |
|
|
|
import org.eclipse.jgit.lib.Ref.Storage; |
|
|
|
import org.eclipse.jgit.lib.RefUpdate.Result; |
|
|
|
import org.eclipse.jgit.lib.RefUpdate.Result; |
|
|
|
|
|
|
|
import org.eclipse.jgit.storage.file.FileBasedConfig; |
|
|
|
import org.eclipse.jgit.test.resources.SampleDataRepositoryTestCase; |
|
|
|
import org.eclipse.jgit.test.resources.SampleDataRepositoryTestCase; |
|
|
|
import org.junit.Test; |
|
|
|
import org.junit.Test; |
|
|
|
|
|
|
|
|
|
|
@ -82,6 +84,50 @@ public class RefTest extends SampleDataRepositoryTestCase { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
|
|
|
|
public void testRemoteNames() throws Exception { |
|
|
|
|
|
|
|
FileBasedConfig config = db.getConfig(); |
|
|
|
|
|
|
|
config.setBoolean(ConfigConstants.CONFIG_REMOTE_SECTION, |
|
|
|
|
|
|
|
"origin", "dummy", true); |
|
|
|
|
|
|
|
config.setBoolean(ConfigConstants.CONFIG_REMOTE_SECTION, |
|
|
|
|
|
|
|
"ab/c", "dummy", true); |
|
|
|
|
|
|
|
config.save(); |
|
|
|
|
|
|
|
assertEquals("[ab/c, origin]", |
|
|
|
|
|
|
|
new TreeSet<String>(db.getRemoteNames()).toString()); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// one-level deep remote branch
|
|
|
|
|
|
|
|
assertEquals("master", |
|
|
|
|
|
|
|
db.shortenRemoteBranchName("refs/remotes/origin/master")); |
|
|
|
|
|
|
|
assertEquals("origin", db.getRemoteName("refs/remotes/origin/master")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// two-level deep remote branch
|
|
|
|
|
|
|
|
assertEquals("masta/r", |
|
|
|
|
|
|
|
db.shortenRemoteBranchName("refs/remotes/origin/masta/r")); |
|
|
|
|
|
|
|
assertEquals("origin", db.getRemoteName("refs/remotes/origin/masta/r")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Remote with slash and one-level deep branch name
|
|
|
|
|
|
|
|
assertEquals("xmaster", |
|
|
|
|
|
|
|
db.shortenRemoteBranchName("refs/remotes/ab/c/xmaster")); |
|
|
|
|
|
|
|
assertEquals("ab/c", db.getRemoteName("refs/remotes/ab/c/xmaster")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Remote with slash and two-level deep branch name
|
|
|
|
|
|
|
|
assertEquals("xmasta/r", |
|
|
|
|
|
|
|
db.shortenRemoteBranchName("refs/remotes/ab/c/xmasta/r")); |
|
|
|
|
|
|
|
assertEquals("ab/c", db.getRemoteName("refs/remotes/ab/c/xmasta/r")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// no such remote
|
|
|
|
|
|
|
|
assertNull(db.getRemoteName("refs/remotes/nosuchremote/x")); |
|
|
|
|
|
|
|
assertNull(db.shortenRemoteBranchName("refs/remotes/nosuchremote/x")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// no such remote too, no branch name either
|
|
|
|
|
|
|
|
assertNull(db.getRemoteName("refs/remotes/abranch")); |
|
|
|
|
|
|
|
assertNull(db.shortenRemoteBranchName("refs/remotes/abranch")); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// // local branch
|
|
|
|
|
|
|
|
assertNull(db.getRemoteName("refs/heads/abranch")); |
|
|
|
|
|
|
|
assertNull(db.shortenRemoteBranchName("refs/heads/abranch")); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Test |
|
|
|
@Test |
|
|
|
public void testReadAllIncludingSymrefs() throws Exception { |
|
|
|
public void testReadAllIncludingSymrefs() throws Exception { |
|
|
|
ObjectId masterId = db.resolve("refs/heads/master"); |
|
|
|
ObjectId masterId = db.resolve("refs/heads/master"); |
|
|
|