aboutsummaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java
diff options
context:
space:
mode:
authorMatthias Sohn <matthias.sohn@sap.com>2013-10-21 01:22:08 +0200
committerGerrit Code Review @ Eclipse.org <gerrit@eclipse.org>2013-10-31 08:28:46 -0400
commite649287502407e10c89de03e82cc0de855e01dcf (patch)
treee768ce0c14a4ea9b449a0786810537cd244ee445 /org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java
parent7904060a5a6a986550773ed59bfd7e02f88090b7 (diff)
downloadjgit-e649287502407e10c89de03e82cc0de855e01dcf.tar.gz
jgit-e649287502407e10c89de03e82cc0de855e01dcf.zip
Enhance RepositoryTestCase.commitFile() to work on empty repository
Change-Id: Ic64497f0eedf8996ba593ca52dc9a040732a5b24 Signed-off-by: Matthias Sohn <matthias.sohn@sap.com>
Diffstat (limited to 'org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java')
-rw-r--r--org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java17
1 files changed, 13 insertions, 4 deletions
diff --git a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java
index 7b12ce1b21..15334ee396 100644
--- a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java
+++ b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/RepositoryTestCase.java
@@ -463,16 +463,25 @@ public abstract class RepositoryTestCase extends LocalDiskRepositoryTestCase {
protected RevCommit commitFile(String filename, String contents, String branch) {
try {
Git git = new Git(db);
- String originalBranch = git.getRepository().getFullBranch();
- if (git.getRepository().getRef(branch) == null)
- git.branchCreate().setName(branch).call();
- git.checkout().setName(branch).call();
+ Repository repo = git.getRepository();
+ String originalBranch = repo.getFullBranch();
+ boolean empty = repo.resolve(Constants.HEAD) == null;
+ if (!empty) {
+ if (repo.getRef(branch) == null)
+ git.branchCreate().setName(branch).call();
+ git.checkout().setName(branch).call();
+ }
+
writeTrashFile(filename, contents);
git.add().addFilepattern(filename).call();
RevCommit commit = git.commit()
.setMessage(branch + ": " + filename).call();
+
if (originalBranch != null)
git.checkout().setName(originalBranch).call();
+ else if (empty)
+ git.branchCreate().setName(branch).setStartPoint(commit).call();
+
return commit;
} catch (IOException e) {
throw new RuntimeException(e);