Skip to content

Commit d78ab05

Browse files
committed
Merge branch 'fix-test-utils'
The goodies ported from MiniMaven's TestUtils class actually had a bug, now unfortunately in the scijava-common version 2.20.0. This bug was identified when trying to run imagej-updater's test suite against said version, and have been fixed in this topic branch. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
2 parents 3bed0ce + 1871a8b commit d78ab05

File tree

2 files changed

+70
-1
lines changed

2 files changed

+70
-1
lines changed

src/main/java/org/scijava/test/TestUtils.java

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -81,9 +81,11 @@ public static File createTemporaryDirectory(final String prefix) throws IOExcept
8181
public static File createTemporaryDirectory(final String prefix,
8282
final Class<?> forClass) throws IOException
8383
{
84-
return createTemporaryDirectory(prefix, forClass, "");
84+
return createTemporaryDirectory(prefix, forClass, "" + temporaryDirectoryCounter++);
8585
}
8686

87+
private static int temporaryDirectoryCounter = 1;
88+
8789
/**
8890
* Makes a temporary directory for use with unit tests.
8991
* <p>
@@ -163,6 +165,7 @@ public static Map.Entry<Class<?>, String> getCallingCodeLocation(final Class<?>
163165
final String thatClassName = element.getClassName();
164166
if (thatClassName == null || thatClassName.equals(thisClassName) ||
165167
thatClassName.equals(thisClassName2) ||
168+
thatClassName.endsWith("TestUtils") ||
166169
thatClassName.startsWith("java.lang.")) {
167170
continue;
168171
}
Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
/*
2+
* #%L
3+
* SciJava Common shared library for SciJava software.
4+
* %%
5+
* Copyright (C) 2009 - 2014 Board of Regents of the University of
6+
* Wisconsin-Madison, Broad Institute of MIT and Harvard, and Max Planck
7+
* Institute of Molecular Cell Biology and Genetics.
8+
* %%
9+
* Redistribution and use in source and binary forms, with or without
10+
* modification, are permitted provided that the following conditions are met:
11+
*
12+
* 1. Redistributions of source code must retain the above copyright notice,
13+
* this list of conditions and the following disclaimer.
14+
* 2. Redistributions in binary form must reproduce the above copyright notice,
15+
* this list of conditions and the following disclaimer in the documentation
16+
* and/or other materials provided with the distribution.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21+
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
22+
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23+
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24+
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25+
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26+
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27+
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28+
* POSSIBILITY OF SUCH DAMAGE.
29+
* #L%
30+
*/
31+
32+
package org.scijava.util;
33+
34+
import static org.junit.Assert.assertTrue;
35+
36+
import java.io.File;
37+
import java.io.IOException;
38+
39+
import org.junit.Test;
40+
import org.scijava.test.TestUtils;
41+
42+
/**
43+
* Tests the {@link TestUtilsTest}.
44+
*
45+
* @author Johannes Schindelin
46+
*/
47+
public class TestUtilsTest {
48+
49+
@Test
50+
public void testCreateTemporaryDirectory() throws IOException {
51+
final File tmp1 = TestUtils.createTemporaryDirectory("test-utils-test-");
52+
assertTrue("Not in target/: " + tmp1.getAbsolutePath(), tmp1
53+
.getAbsolutePath().contains("/target/"));
54+
final File tmp2 = TestUtils.createTemporaryDirectory("test-utils-test-");
55+
assertTrue(!tmp1.getAbsolutePath().equals(tmp2.getAbsolutePath()));
56+
57+
final File tmp3 =
58+
TestUtils.createTemporaryDirectory("test-utils-test-", getClass());
59+
assertTrue("Not in target/: " + tmp3.getAbsolutePath(), tmp3
60+
.getAbsolutePath().contains("/target/"));
61+
final File tmp4 =
62+
TestUtils.createTemporaryDirectory("test-utils-test-", getClass());
63+
assertTrue(!tmp3.getAbsolutePath().equals(tmp4.getAbsolutePath()));
64+
65+
}
66+
}

0 commit comments

Comments
 (0)