Cleanup (test extracted to make option setting per-class instead of per-test)
This commit is contained in:
@@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2000-2014 JetBrains s.r.o.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
package org.jetbrains.java.decompiler;
|
||||||
|
|
||||||
|
import org.jetbrains.java.decompiler.main.extern.IFernflowerPreferences;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class BytecodeToSourceMappingTest extends SingleClassesTestBase {
|
||||||
|
@Override
|
||||||
|
protected Map<String, Object> getDecompilerOptions() {
|
||||||
|
return new HashMap<String, Object>() {{
|
||||||
|
put(IFernflowerPreferences.BYTECODE_SOURCE_MAPPING, "1");
|
||||||
|
}};
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test public void testSimpleBytecodeMapping() { doTest("pkg/TestClassSimpleBytecodeMapping"); }
|
||||||
|
}
|
||||||
@@ -30,4 +30,4 @@ public class LineNumbersMatchTest extends SingleClassesTestBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test public void testMatch1() { doTest("pkg/TestLineNumbersMatch"); }
|
@Test public void testMatch1() { doTest("pkg/TestLineNumbersMatch"); }
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,9 +15,6 @@
|
|||||||
*/
|
*/
|
||||||
package org.jetbrains.java.decompiler;
|
package org.jetbrains.java.decompiler;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
import org.jetbrains.java.decompiler.main.extern.IFernflowerPreferences;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class SingleClassesTest extends SingleClassesTestBase {
|
public class SingleClassesTest extends SingleClassesTestBase {
|
||||||
@@ -39,10 +36,4 @@ public class SingleClassesTest extends SingleClassesTestBase {
|
|||||||
@Test public void testInvalidMethodSignature() { doTest("InvalidMethodSignature"); }
|
@Test public void testInvalidMethodSignature() { doTest("InvalidMethodSignature"); }
|
||||||
@Test public void testInnerClassConstructor() { doTest("pkg/TestInnerClassConstructor"); }
|
@Test public void testInnerClassConstructor() { doTest("pkg/TestInnerClassConstructor"); }
|
||||||
@Test public void testInnerClassConstructor11() { doTest("v11/TestInnerClassConstructor"); }
|
@Test public void testInnerClassConstructor11() { doTest("v11/TestInnerClassConstructor"); }
|
||||||
@Test
|
|
||||||
public void testSimpleBytecodeMapping() {
|
|
||||||
doTest("pkg/TestClassSimpleBytecodeMapping", new HashMap<String, Object>(){{
|
|
||||||
put(IFernflowerPreferences.BYTECODE_SOURCE_MAPPING, "1");}});
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,24 +15,21 @@
|
|||||||
*/
|
*/
|
||||||
package org.jetbrains.java.decompiler;
|
package org.jetbrains.java.decompiler;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import org.jetbrains.java.decompiler.main.decompiler.ConsoleDecompiler;
|
||||||
import static org.junit.Assert.assertTrue;
|
import org.jetbrains.java.decompiler.util.InterpreterUtil;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Before;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FilenameFilter;
|
import java.io.FilenameFilter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
|
||||||
|
|
||||||
import org.jetbrains.java.decompiler.main.DecompilerContext;
|
import static org.junit.Assert.assertEquals;
|
||||||
import org.jetbrains.java.decompiler.main.decompiler.ConsoleDecompiler;
|
import static org.junit.Assert.assertTrue;
|
||||||
import org.jetbrains.java.decompiler.util.InterpreterUtil;
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Before;
|
|
||||||
|
|
||||||
public abstract class SingleClassesTestBase {
|
public abstract class SingleClassesTestBase {
|
||||||
private DecompilerTestFixture fixture;
|
private DecompilerTestFixture fixture;
|
||||||
@@ -54,23 +51,12 @@ public abstract class SingleClassesTestBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void doTest(String testFile) {
|
protected void doTest(String testFile) {
|
||||||
doTest(testFile, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void doTest(String testFile, Map<String, Object> options) {
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
File classFile = new File(fixture.getTestDataDir(), "/classes/" + testFile + ".class");
|
File classFile = new File(fixture.getTestDataDir(), "/classes/" + testFile + ".class");
|
||||||
assertTrue(classFile.isFile());
|
assertTrue(classFile.isFile());
|
||||||
String testName = classFile.getName().substring(0, classFile.getName().length() - 6);
|
String testName = classFile.getName().substring(0, classFile.getName().length() - 6);
|
||||||
|
|
||||||
ConsoleDecompiler decompiler = fixture.getDecompiler();
|
ConsoleDecompiler decompiler = fixture.getDecompiler();
|
||||||
if(options != null) {
|
|
||||||
for(Entry<String, Object> option : options.entrySet()) {
|
|
||||||
// overwrite with user-supplied value
|
|
||||||
DecompilerContext.setProperty(option.getKey(), option.getValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (File file : collectClasses(classFile)) decompiler.addSpace(file, true);
|
for (File file : collectClasses(classFile)) decompiler.addSpace(file, true);
|
||||||
decompiler.decompileContext();
|
decompiler.decompileContext();
|
||||||
|
|||||||
Reference in New Issue
Block a user