summaryrefslogtreecommitdiffstats
path: root/test/org/jetbrains/java/decompiler/SingleClassesTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'test/org/jetbrains/java/decompiler/SingleClassesTest.java')
-rw-r--r--test/org/jetbrains/java/decompiler/SingleClassesTest.java54
1 files changed, 9 insertions, 45 deletions
diff --git a/test/org/jetbrains/java/decompiler/SingleClassesTest.java b/test/org/jetbrains/java/decompiler/SingleClassesTest.java
index e251e91..9868011 100644
--- a/test/org/jetbrains/java/decompiler/SingleClassesTest.java
+++ b/test/org/jetbrains/java/decompiler/SingleClassesTest.java
@@ -16,49 +16,28 @@
package org.jetbrains.java.decompiler;
import org.jetbrains.java.decompiler.main.decompiler.ConsoleDecompiler;
-import org.jetbrains.java.decompiler.main.extern.IFernflowerPreferences;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import java.io.*;
-import java.util.HashMap;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;
public class SingleClassesTest {
- private File testDataDir;
- private File tempDir;
- private ConsoleDecompiler decompiler;
+ private DecompilerTestFixture fixture;
@Before
public void setUp() throws IOException {
- testDataDir = new File("testData");
- if (!isTestDataDir(testDataDir)) testDataDir = new File("community/plugins/java-decompiler/engine/testData");
- if (!isTestDataDir(testDataDir)) testDataDir = new File("plugins/java-decompiler/engine/testData");
- assertTrue(isTestDataDir(testDataDir));
-
- //noinspection SSBasedInspection
- tempDir = File.createTempFile("decompiler_test_", "_dir");
- assertTrue(tempDir.delete());
- assertTrue(tempDir.mkdirs());
-
- decompiler = new ConsoleDecompiler(tempDir, new HashMap<String, Object>() {{
- put(IFernflowerPreferences.LOG_LEVEL, "warn");
- put(IFernflowerPreferences.DECOMPILE_GENERIC_SIGNATURES, "1");
- put(IFernflowerPreferences.REMOVE_SYNTHETIC, "1");
- put(IFernflowerPreferences.REMOVE_BRIDGE, "1");
- put(IFernflowerPreferences.LITERALS_AS_IS, "1");
- }});
+ fixture = new DecompilerTestFixture();
+ fixture.setUp();
}
@After
public void tearDown() {
- decompiler = null;
- delete(tempDir);
- tempDir = null;
- testDataDir = null;
+ fixture.tearDown();
+ fixture = null;
}
@Test public void testClassFields() { doTest("TestClassFields"); }
@@ -77,9 +56,10 @@ public class SingleClassesTest {
private void doTest(final String testName) {
try {
- File classFile = new File(testDataDir, "/classes/pkg/" + testName + ".class");
+ File classFile = new File(fixture.getTestDataDir(), "/classes/pkg/" + testName + ".class");
assertTrue(classFile.isFile());
+ ConsoleDecompiler decompiler = fixture.getDecompiler();
decompiler.addSpace(classFile, true);
File[] innerClasses = classFile.getParentFile().listFiles(new FilenameFilter() {
@Override
@@ -93,10 +73,10 @@ public class SingleClassesTest {
decompiler.decompileContext();
- File decompiledFile = new File(tempDir, testName + ".java");
+ File decompiledFile = new File(fixture.getTargetDir(), testName + ".java");
assertTrue(decompiledFile.isFile());
- File referenceFile = new File(testDataDir, "results/" + testName + ".dec");
+ File referenceFile = new File(fixture.getTestDataDir(), "results/" + testName + ".dec");
assertTrue(referenceFile.isFile());
String decompiledContent = getContent(decompiledFile);
@@ -108,10 +88,6 @@ public class SingleClassesTest {
}
}
- private static boolean isTestDataDir(File dir) {
- return dir.isDirectory() && new File(dir, "classes").isDirectory() && new File(dir, "results").isDirectory();
- }
-
private static String getContent(File file) throws IOException {
Reader reader = new InputStreamReader(new FileInputStream(file), "UTF-8");
try {
@@ -127,16 +103,4 @@ public class SingleClassesTest {
reader.close();
}
}
-
- private static void delete(File file) {
- if (file.isDirectory()) {
- File[] files = file.listFiles();
- if (files != null) {
- for (File f : files) delete(f);
- }
- }
- else {
- assertTrue(file.delete());
- }
- }
}