summaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit.test/tst
diff options
context:
space:
mode:
authorRobin Stocker <robin@nibor.org>2012-09-23 01:57:20 +0200
committerChris Aniszczyk <zx@twitter.com>2012-11-16 10:31:32 -0800
commitcdaded26b0711bfd99cc2990db25b4562540c3b5 (patch)
treee036b301f6d625f19115c6602fbec7adf7d19740 /org.eclipse.jgit.test/tst
parent20c829838ac101cf595ee9d4575d6b95a6d2c99d (diff)
downloadjgit-cdaded26b0711bfd99cc2990db25b4562540c3b5.tar.gz
jgit-cdaded26b0711bfd99cc2990db25b4562540c3b5.zip
CheckoutCommand: Support checking out ours and theirs
The checkoutPaths body is split into two implementations, depending on whether we are checking out the index or a branch. This improves readability, as in the index case we now also need to have access to DirCacheIterator. Bug: 390147 Change-Id: I99fd599b25b2ace9bdd84535a56565286a3cb7f1 Signed-off-by: Chris Aniszczyk <zx@twitter.com>
Diffstat (limited to 'org.eclipse.jgit.test/tst')
-rw-r--r--org.eclipse.jgit.test/tst/org/eclipse/jgit/api/PathCheckoutCommandTest.java48
1 files changed, 45 insertions, 3 deletions
diff --git a/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/PathCheckoutCommandTest.java b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/PathCheckoutCommandTest.java
index d37f57293d..43b632d2c8 100644
--- a/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/PathCheckoutCommandTest.java
+++ b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/PathCheckoutCommandTest.java
@@ -47,6 +47,7 @@ import static org.junit.Assert.assertEquals;
import java.io.File;
import java.io.IOException;
+import org.eclipse.jgit.api.CheckoutCommand.Stage;
import org.eclipse.jgit.api.errors.JGitInternalException;
import org.eclipse.jgit.dircache.DirCache;
import org.eclipse.jgit.dircache.DirCacheEntry;
@@ -246,10 +247,41 @@ public class PathCheckoutCommandTest extends RepositoryTestCase {
assertEquals("a", read(test2));
}
+
@Test(expected = JGitInternalException.class)
public void testCheckoutOfConflictingFileShouldThrow()
throws Exception {
- // Setup
+ setupConflictingState();
+
+ git.checkout().addPath(FILE1).call();
+ }
+
+ @Test
+ public void testCheckoutOurs() throws Exception {
+ setupConflictingState();
+
+ git.checkout().setStage(Stage.OURS).addPath(FILE1).call();
+
+ assertEquals("3", read(FILE1));
+ assertStageOneToThree(FILE1);
+ }
+
+ @Test
+ public void testCheckoutTheirs() throws Exception {
+ setupConflictingState();
+
+ git.checkout().setStage(Stage.THEIRS).addPath(FILE1).call();
+
+ assertEquals("Conflicting", read(FILE1));
+ assertStageOneToThree(FILE1);
+ }
+
+ @Test(expected = IllegalStateException.class)
+ public void testStageNotPossibleWithBranch() throws Exception {
+ git.checkout().setStage(Stage.OURS).setStartPoint("master").call();
+ }
+
+ private void setupConflictingState() throws Exception {
git.checkout().setCreateBranch(true).setName("conflict")
.setStartPoint(initialCommit).call();
writeTrashFile(FILE1, "Conflicting");
@@ -260,8 +292,18 @@ public class PathCheckoutCommandTest extends RepositoryTestCase {
git.merge().include(conflict).call();
assertEquals(RepositoryState.MERGING, db.getRepositoryState());
+ assertStageOneToThree(FILE1);
+ }
- // Now check out the conflicting path
- git.checkout().addPath(FILE1).call();
+ private void assertStageOneToThree(String name) throws Exception {
+ DirCache cache = DirCache.read(db.getIndexFile(), db.getFS());
+ int i = cache.findEntry(name);
+ DirCacheEntry stage1 = cache.getEntry(i);
+ DirCacheEntry stage2 = cache.getEntry(i + 1);
+ DirCacheEntry stage3 = cache.getEntry(i + 2);
+
+ assertEquals(DirCacheEntry.STAGE_1, stage1.getStage());
+ assertEquals(DirCacheEntry.STAGE_2, stage2.getStage());
+ assertEquals(DirCacheEntry.STAGE_3, stage3.getStage());
}
}