summaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit.test/tst
diff options
context:
space:
mode:
authorRobin Stocker <robin@nibor.org>2013-05-04 16:43:51 +0200
committerGerrit Code Review @ Eclipse.org <gerrit@eclipse.org>2013-05-28 05:33:03 -0400
commita51899c2036984fa7a04290ca1364a02af34f95a (patch)
treea33c778e7e5345e813e3c905f9685033938fac7e /org.eclipse.jgit.test/tst
parentec97912762754ee88f1af5ed80e993c545778242 (diff)
downloadjgit-a51899c2036984fa7a04290ca1364a02af34f95a.tar.gz
jgit-a51899c2036984fa7a04290ca1364a02af34f95a.zip
Support refspecs with wildcard in middle (not only at end)
The following refspec, which can be used to fetch GitHub pull requests, is supported by C Git but was not yet by JGit: +refs/pull/*/head:refs/remotes/origin/pr/* The reason is that the wildcard in the source is in the middle. This change also includes more validation (e.g. "refs//heads" is not valid) and test cases. Bug: 405099 Change-Id: I9bcef7785a0762ed0a98ca95a0bdf8879d5702aa
Diffstat (limited to 'org.eclipse.jgit.test/tst')
-rw-r--r--org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/RefSpecTest.java150
1 files changed, 150 insertions, 0 deletions
diff --git a/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/RefSpecTest.java b/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/RefSpecTest.java
index 871741f697..3f5fcbbf07 100644
--- a/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/RefSpecTest.java
+++ b/org.eclipse.jgit.test/tst/org/eclipse/jgit/transport/RefSpecTest.java
@@ -1,6 +1,7 @@
/*
* Copyright (C) 2008, Robin Rosenberg <robin.rosenberg@dewire.com>
* Copyright (C) 2008, Shawn O. Pearce <spearce@spearce.org>
+ * Copyright (C) 2013, Robin Stocker <robin@nibor.org>
* and other copyright owners as documented in the project's IP log.
*
* This program and the accompanying materials are made available
@@ -46,6 +47,7 @@ package org.eclipse.jgit.transport;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
+import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNotSame;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertSame;
@@ -294,4 +296,152 @@ public class RefSpecTest {
assertEquals(src, r.getSource());
assertEquals(dst, r.getDestination());
}
+
+ @Test
+ public void isWildcardShouldWorkForWildcardSuffixAndComponent() {
+ assertTrue(RefSpec.isWildcard("refs/heads/*"));
+ assertTrue(RefSpec.isWildcard("refs/pull/*/head"));
+ assertFalse(RefSpec.isWildcard("refs/heads/a"));
+ }
+
+ @Test
+ public void testWildcardInMiddleOfSource() {
+ RefSpec a = new RefSpec("+refs/pull/*/head:refs/remotes/origin/pr/*");
+ assertTrue(a.isWildcard());
+ assertTrue(a.matchSource("refs/pull/a/head"));
+ assertTrue(a.matchSource("refs/pull/foo/head"));
+ assertTrue(a.matchSource("refs/pull/foo/bar/head"));
+ assertFalse(a.matchSource("refs/pull/foo"));
+ assertFalse(a.matchSource("refs/pull/head"));
+ assertFalse(a.matchSource("refs/pull/foo/head/more"));
+ assertFalse(a.matchSource("refs/pullx/head"));
+
+ RefSpec b = a.expandFromSource("refs/pull/foo/head");
+ assertEquals("refs/remotes/origin/pr/foo", b.getDestination());
+ RefSpec c = a.expandFromDestination("refs/remotes/origin/pr/foo");
+ assertEquals("refs/pull/foo/head", c.getSource());
+ }
+
+ @Test
+ public void testWildcardInMiddleOfDestionation() {
+ RefSpec a = new RefSpec("+refs/heads/*:refs/remotes/origin/*/head");
+ assertTrue(a.isWildcard());
+ assertTrue(a.matchDestination("refs/remotes/origin/a/head"));
+ assertTrue(a.matchDestination("refs/remotes/origin/foo/head"));
+ assertTrue(a.matchDestination("refs/remotes/origin/foo/bar/head"));
+ assertFalse(a.matchDestination("refs/remotes/origin/foo"));
+ assertFalse(a.matchDestination("refs/remotes/origin/head"));
+ assertFalse(a.matchDestination("refs/remotes/origin/foo/head/more"));
+ assertFalse(a.matchDestination("refs/remotes/originx/head"));
+
+ RefSpec b = a.expandFromSource("refs/heads/foo");
+ assertEquals("refs/remotes/origin/foo/head", b.getDestination());
+ RefSpec c = a.expandFromDestination("refs/remotes/origin/foo/head");
+ assertEquals("refs/heads/foo", c.getSource());
+ }
+
+ @Test
+ public void testWildcardMirror() {
+ RefSpec a = new RefSpec("*:*");
+ assertTrue(a.isWildcard());
+ assertTrue(a.matchSource("a"));
+ assertTrue(a.matchSource("foo"));
+ assertTrue(a.matchSource("foo/bar"));
+ assertTrue(a.matchDestination("a"));
+ assertTrue(a.matchDestination("foo"));
+ assertTrue(a.matchDestination("foo/bar"));
+
+ RefSpec b = a.expandFromSource("refs/heads/foo");
+ assertEquals("refs/heads/foo", b.getDestination());
+ RefSpec c = a.expandFromDestination("refs/heads/foo");
+ assertEquals("refs/heads/foo", c.getSource());
+ }
+
+ @Test
+ public void testWildcardAtStart() {
+ RefSpec a = new RefSpec("*/head:refs/heads/*");
+ assertTrue(a.isWildcard());
+ assertTrue(a.matchSource("a/head"));
+ assertTrue(a.matchSource("foo/head"));
+ assertTrue(a.matchSource("foo/bar/head"));
+ assertFalse(a.matchSource("/head"));
+ assertFalse(a.matchSource("a/head/extra"));
+
+ RefSpec b = a.expandFromSource("foo/head");
+ assertEquals("refs/heads/foo", b.getDestination());
+ RefSpec c = a.expandFromDestination("refs/heads/foo");
+ assertEquals("foo/head", c.getSource());
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenSourceOnlyAndWildcard() {
+ assertNotNull(new RefSpec("refs/heads/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenDestinationOnlyAndWildcard() {
+ assertNotNull(new RefSpec(":refs/heads/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenOnlySourceWildcard() {
+ assertNotNull(new RefSpec("refs/heads/*:refs/heads/foo"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenOnlyDestinationWildcard() {
+ assertNotNull(new RefSpec("refs/heads/foo:refs/heads/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenMoreThanOneWildcardInSource() {
+ assertNotNull(new RefSpec("refs/heads/*/*:refs/heads/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenMoreThanOneWildcardInDestination() {
+ assertNotNull(new RefSpec("refs/heads/*:refs/heads/*/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenWildcardAfterText() {
+ assertNotNull(new RefSpec("refs/heads/wrong*:refs/heads/right/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenWildcardBeforeText() {
+ assertNotNull(new RefSpec("*wrong:right/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidWhenWildcardBeforeTextAtEnd() {
+ assertNotNull(new RefSpec("refs/heads/*wrong:right/*"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidSourceDoubleSlashes() {
+ assertNotNull(new RefSpec("refs/heads//wrong"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidSlashAtStart() {
+ assertNotNull(new RefSpec("/foo:/foo"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidDestinationDoubleSlashes() {
+ assertNotNull(new RefSpec(":refs/heads//wrong"));
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidSetSource() {
+ RefSpec a = new RefSpec("refs/heads/*:refs/remotes/origin/*");
+ a.setSource("refs/heads/*/*");
+ }
+
+ @Test(expected = IllegalArgumentException.class)
+ public void invalidSetDestination() {
+ RefSpec a = new RefSpec("refs/heads/*:refs/remotes/origin/*");
+ a.setDestination("refs/remotes/origin/*/*");
+ }
}