Cleanup (test extracted to make option setting per-class instead of per-test)

master
Roman Shevchenko 10 years ago
parent 22ceacc969
commit b3681fe952
  1. 33
      test/org/jetbrains/java/decompiler/BytecodeToSourceMappingTest.java
  2. 9
      test/org/jetbrains/java/decompiler/SingleClassesTest.java
  3. 26
      test/org/jetbrains/java/decompiler/SingleClassesTestBase.java

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

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

Loading…
Cancel
Save