java-decompiler: bulk decompilation test added

This commit is contained in:
Roman Shevchenko
2014-09-07 16:13:52 +04:00
parent ff382a6fdf
commit 7a8097321f
9 changed files with 216 additions and 50 deletions

View File

@@ -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());
}
}
}