diff options
author | Shawn Pearce <sop@google.com> | 2013-11-01 10:49:06 -0600 |
---|---|---|
committer | Gerrit Code Review @ Eclipse.org <gerrit@eclipse.org> | 2013-11-24 05:27:00 -0500 |
commit | 573d36a4647c79ba0d2350f65c9ad8ac889e17ee (patch) | |
tree | bcd100af3881600612b4aadf29ecb828880f7e96 | |
parent | 7f7dd171df7c02d2e9b95c640909cc11acda2644 (diff) | |
download | jgit-573d36a4647c79ba0d2350f65c9ad8ac889e17ee.tar.gz jgit-573d36a4647c79ba0d2350f65c9ad8ac889e17ee.zip |
Support running from JARs in JGitTestUtil
Buck invokes JUnit tests from compiled JARs, not class directories.
When copying a resource back to the filesystem a jar: style URL is
obtained from the ClassLoader.
Change-Id: I28d702484ec13b0b309b87990da867050e4b5ec6
-rw-r--r-- | org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/JGitTestUtil.java | 35 | ||||
-rw-r--r-- | org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/SampleDataRepositoryTestCase.java | 8 |
2 files changed, 38 insertions, 5 deletions
diff --git a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/JGitTestUtil.java b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/JGitTestUtil.java index c6fe4e4d91..1079d98439 100644 --- a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/JGitTestUtil.java +++ b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/JGitTestUtil.java @@ -46,8 +46,10 @@ package org.eclipse.jgit.junit; import java.io.File; +import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; +import java.io.InputStream; import java.io.OutputStreamWriter; import java.io.Writer; import java.lang.reflect.Method; @@ -124,13 +126,44 @@ public abstract class JGitTestUtil { // loaded previously return new File("tst", fileName); } + if ("jar".equals(url.getProtocol())) { + try { + File tmp = File.createTempFile("tmp_", "_" + fileName); + copyTestResource(fileName, tmp); + return tmp; + } catch (IOException err) { + throw new RuntimeException("Cannot create temporary file", err); + } + } try { return new File(url.toURI()); - } catch(URISyntaxException e) { + } catch (IllegalArgumentException e) { + throw new IllegalArgumentException(e.getMessage() + " " + url); + } catch (URISyntaxException e) { return new File(url.getPath()); } } + public static void copyTestResource(String name, File dest) + throws IOException { + URL url = cl().getResource(CLASSPATH_TO_RESOURCES + name); + if (url == null) + throw new FileNotFoundException(name); + InputStream in = url.openStream(); + try { + FileOutputStream out = new FileOutputStream(dest); + try { + byte[] buf = new byte[4096]; + for (int n; (n = in.read(buf)) > 0;) + out.write(buf, 0, n); + } finally { + out.close(); + } + } finally { + in.close(); + } + } + private static ClassLoader cl() { return JGitTestUtil.class.getClassLoader(); } diff --git a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/SampleDataRepositoryTestCase.java b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/SampleDataRepositoryTestCase.java index fb4b9e9f80..0b03a2c413 100644 --- a/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/SampleDataRepositoryTestCase.java +++ b/org.eclipse.jgit.junit/src/org/eclipse/jgit/junit/SampleDataRepositoryTestCase.java @@ -66,11 +66,11 @@ public abstract class SampleDataRepositoryTestCase extends RepositoryTestCase { }; final File packDir = new File(db.getObjectDatabase().getDirectory(), "pack"); for (String n : packs) { - copyFile(JGitTestUtil.getTestResourceFile(n + ".pack"), new File(packDir, n + ".pack")); - copyFile(JGitTestUtil.getTestResourceFile(n + ".idx"), new File(packDir, n + ".idx")); + JGitTestUtil.copyTestResource(n + ".pack", new File(packDir, n + ".pack")); + JGitTestUtil.copyTestResource(n + ".idx", new File(packDir, n + ".idx")); } - copyFile(JGitTestUtil.getTestResourceFile("packed-refs"), new File(db - .getDirectory(), "packed-refs")); + JGitTestUtil.copyTestResource("packed-refs", + new File(db.getDirectory(), "packed-refs")); } } |