summaryrefslogtreecommitdiffstats
path: root/jack-tests
diff options
context:
space:
mode:
authormikaelpeltier <mikaelpeltier@google.com>2015-04-28 16:18:21 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2015-04-28 16:18:22 +0000
commitf03842a985338e6a874e20a0e7f2b95257c09116 (patch)
tree57236efc66a8dbff5550e3f59062c5ddb2b9e53b /jack-tests
parent9b8ac29d65bdff2c09ae14376ff4c93af6ddaa3a (diff)
parentc286179a426370e325480449fa803e5a93a3b9d8 (diff)
downloadtoolchain_jack-f03842a985338e6a874e20a0e7f2b95257c09116.tar.gz
toolchain_jack-f03842a985338e6a874e20a0e7f2b95257c09116.tar.bz2
toolchain_jack-f03842a985338e6a874e20a0e7f2b95257c09116.zip
Merge "Add new Shrinking tests" into ub-jack
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();