summaryrefslogtreecommitdiffstats
path: root/jack-tests
diff options
context:
space:
mode:
authormikaelpeltier <mikaelpeltier@google.com>2015-04-10 16:47:45 +0200
committermikaelpeltier <mikaelpeltier@google.com>2015-04-28 09:37:47 +0200
commitc286179a426370e325480449fa803e5a93a3b9d8 (patch)
tree0cae733c106b4be5b2f6f75305336e8d5d7c5a3d /jack-tests
parent923fed570156cb3e14ae2cb21829bc0e70d3f9be (diff)
downloadtoolchain_jack-c286179a426370e325480449fa803e5a93a3b9d8.tar.gz
toolchain_jack-c286179a426370e325480449fa803e5a93a3b9d8.tar.bz2
toolchain_jack-c286179a426370e325480449fa803e5a93a3b9d8.zip
Add new Shrinking tests
- These test was written to show the different behavior between using imported jars or not. The class in lib contains a Class.ForName with an existing class that should be kept when the library is used as an imported library. Change-Id: I306ce629d27c4ee9c47f6203e05fc3fd1d2ee038
Diffstat (limited to 'jack-tests')
-rw-r--r--jack-tests/tests/com/android/jack/shrob/ShrinkTests.java52
1 files changed, 52 insertions, 0 deletions
diff --git a/jack-tests/tests/com/android/jack/shrob/ShrinkTests.java b/jack-tests/tests/com/android/jack/shrob/ShrinkTests.java
index 6ffa637c..c5fcfd6a 100644
--- a/jack-tests/tests/com/android/jack/shrob/ShrinkTests.java
+++ b/jack-tests/tests/com/android/jack/shrob/ShrinkTests.java
@@ -85,6 +85,58 @@ public class ShrinkTests extends AbstractTest {
candidateNodeListing));
}
+ private void runTestWithLib(@Nonnull String testNumber, @Nonnull String flagNumber,
+ boolean importLib) throws Exception {
+ File testFolder = new File(shrobTestsDir, "test" + testNumber);
+
+ File libOut = AbstractTestTools.createTempDir();
+ JackApiToolchainBase toolchainLib =
+ AbstractTestTools.getCandidateToolchain(JackApiToolchainBase.class);
+ toolchainLib.addToClasspath(toolchainLib.getDefaultBootClasspath()).srcToLib(libOut,
+ /* zipFiles = */false, new File(shrobTestsDir, "test" + testNumber + "/lib"));
+
+ JackBasedToolchain toolchain =
+ AbstractTestTools.getCandidateToolchain(JackBasedToolchain.class);
+
+ File refFolder = new File(testFolder, "refsShrinking");
+
+ File candidateNodeListing = AbstractTestTools.createTempFile("nodeListing", ".txt");
+ toolchain.addProperty(ShrinkStructurePrinter.STRUCTURE_PRINTING.getName(), "true");
+ toolchain.addProperty(ShrinkStructurePrinter.STRUCTURE_PRINTING_FILE.getName(),
+ candidateNodeListing.getPath());
+ toolchain.addProperty(Options.METHOD_FILTER.getName(), "supported-methods");
+ toolchain.disableDxOptimizations();
+ if (importLib) {
+ toolchain.addStaticLibs(libOut);
+ } else {
+ toolchain.addToClasspath(libOut);
+ }
+
+ File outFolder = AbstractTestTools.createTempDir();
+
+ SourceToDexComparisonTestHelper env =
+ new SourceToDexComparisonTestHelper(new File(testFolder, "jack"));
+
+ env.setWithDebugInfo(true);
+ env.setCandidateTestTools(toolchain);
+ env.setReferenceTestTools(new DummyToolchain());
+ env.setProguardFlags(dontObfuscateFlagFile,
+ new ProguardFlags(testFolder, "proguard.flags" + flagNumber));
+
+ env.runTest(new ComparatorMapping(new File(refFolder, "expected-" + flagNumber + ".txt"),
+ candidateNodeListing));
+ }
+
+ @Test
+ public void test003_001() throws Exception {
+ runTestWithLib("003", "001", false);
+ }
+
+ @Test
+ public void test003_002() throws Exception {
+ runTestWithLib("003", "002", true);
+ }
+
@Test
public void test020() throws Exception {
File libOut = AbstractTestTools.createTempDir();