summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Halstrick <christian.halstrick@sap.com>2011-04-02 03:38:07 -0400
committerCode Review <codereview-daemon@eclipse.org>2011-04-02 03:38:07 -0400
commit12d7e3af1a1246d1ff65dffc79d20a1d9845b28d (patch)
tree72709ff588a8705f2cf1903c5482dacfb94e11cc
parent11e2e746c13cc94cabc96e708f3c6a2b159b5995 (diff)
parent82372d36f85b5ef003ae1af6857e7a3129049ac5 (diff)
downloadjgit-12d7e3af1a1246d1ff65dffc79d20a1d9845b28d.tar.gz
jgit-12d7e3af1a1246d1ff65dffc79d20a1d9845b28d.zip
Merge "Add open(File) and wrap(Repository) to Git"
-rw-r--r--org.eclipse.jgit.test/tst/org/eclipse/jgit/api/GitConstructionTest.java112
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/api/Git.java48
2 files changed, 159 insertions, 1 deletions
diff --git a/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/GitConstructionTest.java b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/GitConstructionTest.java
new file mode 100644
index 0000000000..cfaac6352f
--- /dev/null
+++ b/org.eclipse.jgit.test/tst/org/eclipse/jgit/api/GitConstructionTest.java
@@ -0,0 +1,112 @@
+/*
+ * Copyright (C) 2011, Christian Halstrick <christian.halstrick@sap.com>
+ * and other copyright owners as documented in the project's IP log.
+ *
+ * This program and the accompanying materials are made available
+ * under the terms of the Eclipse Distribution License v1.0 which
+ * accompanies this distribution, is reproduced below, and is
+ * available at http://www.eclipse.org/org/documents/edl-v10.php
+ *
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or
+ * without modification, are permitted provided that the following
+ * conditions are met:
+ *
+ * - Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ *
+ * - Redistributions in binary form must reproduce the above
+ * copyright notice, this list of conditions and the following
+ * disclaimer in the documentation and/or other materials provided
+ * with the distribution.
+ *
+ * - Neither the name of the Eclipse Foundation, Inc. nor the
+ * names of its contributors may be used to endorse or promote
+ * products derived from this software without specific prior
+ * written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
+ * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
+ * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
+ * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
+ * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+ * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+package org.eclipse.jgit.api;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.fail;
+
+import java.io.IOException;
+
+import org.eclipse.jgit.api.ListBranchCommand.ListMode;
+import org.eclipse.jgit.errors.RepositoryNotFoundException;
+import org.eclipse.jgit.lib.Repository;
+import org.eclipse.jgit.lib.RepositoryTestCase;
+import org.junit.Before;
+import org.junit.Test;
+
+public class GitConstructionTest extends RepositoryTestCase {
+ private Repository bareRepo;
+
+ @Override
+ @Before
+ public void setUp() throws Exception {
+ super.setUp();
+ Git git = new Git(db);
+ git.commit().setMessage("initial commit").call();
+ writeTrashFile("Test.txt", "Hello world");
+ git.add().addFilepattern("Test.txt").call();
+ git.commit().setMessage("Initial commit").call();
+
+ bareRepo = Git.cloneRepository().setBare(true)
+ .setURI(db.getDirectory().toURI().toString()).call()
+ .getRepository();
+ }
+
+ @Test
+ public void testWrap() {
+ Git git = Git.wrap(db);
+ assertEquals(1, git.branchList().call().size());
+
+ git = Git.wrap(bareRepo);
+ assertEquals(1, git.branchList().setListMode(ListMode.ALL).call()
+ .size());
+
+ try {
+ Git.wrap(null);
+ fail("Expected exception has not been thrown");
+ } catch (NullPointerException e) {
+ // should not get here
+ }
+ }
+
+ @Test
+ public void testOpen() throws IOException {
+ Git git = Git.open(db.getDirectory());
+ assertEquals(1, git.branchList().call().size());
+
+ git = Git.open(bareRepo.getDirectory());
+ assertEquals(1, git.branchList().setListMode(ListMode.ALL).call()
+ .size());
+
+ git = Git.open(db.getWorkTree());
+ assertEquals(1, git.branchList().setListMode(ListMode.ALL).call()
+ .size());
+
+ try {
+ Git.open(db.getObjectsDirectory());
+ fail("Expected exception has not been thrown");
+ } catch (RepositoryNotFoundException e) {
+ // should not get here
+ }
+ }
+}
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/api/Git.java b/org.eclipse.jgit/src/org/eclipse/jgit/api/Git.java
index d2f2059160..19f140be26 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/api/Git.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/api/Git.java
@@ -43,7 +43,13 @@
*/
package org.eclipse.jgit.api;
+import java.io.File;
+import java.io.IOException;
+
import org.eclipse.jgit.lib.Repository;
+import org.eclipse.jgit.lib.RepositoryBuilder;
+import org.eclipse.jgit.lib.RepositoryCache;
+import org.eclipse.jgit.util.FS;
/**
* Offers a "GitPorcelain"-like API to interact with a git repository.
@@ -80,6 +86,46 @@ public class Git {
private final Repository repo;
/**
+ * @param dir
+ * the repository to open. May be either the GIT_DIR, or the
+ * working tree directory that contains {@code .git}.
+ * @return a {@link Git} object for the existing git repository
+ * @throws IOException
+ */
+ public static Git open(File dir) throws IOException {
+ return open(dir, FS.DETECTED);
+ }
+
+ /**
+ * @param dir
+ * the repository to open. May be either the GIT_DIR, or the
+ * working tree directory that contains {@code .git}.
+ * @param fs
+ * filesystem abstraction to use when accessing the repository.
+ * @return a {@link Git} object for the existing git repository
+ * @throws IOException
+ */
+ public static Git open(File dir, FS fs) throws IOException {
+ RepositoryCache.FileKey key;
+
+ key = RepositoryCache.FileKey.lenient(dir, fs);
+ return wrap(new RepositoryBuilder()
+ .setFS(fs)
+ .setGitDir(key.getFile())
+ .setMustExist(true).build());
+ }
+
+ /**
+ * @param repo
+ * the git repository this class is interacting with.
+ * {@code null} is not allowed
+ * @return a {@link Git} object for the existing git repository
+ */
+ public static Git wrap(Repository repo) {
+ return new Git(repo);
+ }
+
+ /**
* Returns a command object to execute a {@code clone} command
*
* @see <a
@@ -88,7 +134,7 @@ public class Git {
* @return a {@link CloneCommand} used to collect all optional parameters
* and to finally execute the {@code clone} command
*/
- static public CloneCommand cloneRepository() {
+ public static CloneCommand cloneRepository() {
return new CloneCommand();
}