diff options
author | mikaelpeltier <mikaelpeltier@google.com> | 2015-04-28 16:18:21 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2015-04-28 16:18:22 +0000 |
commit | f03842a985338e6a874e20a0e7f2b95257c09116 (patch) | |
tree | 57236efc66a8dbff5550e3f59062c5ddb2b9e53b /jack-tests | |
parent | 9b8ac29d65bdff2c09ae14376ff4c93af6ddaa3a (diff) | |
parent | c286179a426370e325480449fa803e5a93a3b9d8 (diff) | |
download | toolchain_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.java | 52 |
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(); |