aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java')
-rw-r--r--src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java113
1 files changed, 113 insertions, 0 deletions
diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java
new file mode 100644
index 0000000000..ee96569b72
--- /dev/null
+++ b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidCommonTest.java
@@ -0,0 +1,113 @@
+// Copyright 2017 The Bazel Authors. All rights reserved.
+//
+// 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 com.google.devtools.build.lib.rules.android;
+
+import static com.google.common.truth.Truth.assertThat;
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertSame;
+
+import com.google.devtools.build.lib.analysis.util.BuildViewTestCase;
+import com.google.devtools.build.lib.rules.android.AndroidRuleClasses.MultidexMode;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.junit.runners.JUnit4;
+
+/**
+ * Tests common for Android rules.
+ */
+@RunWith(JUnit4.class)
+public class AndroidCommonTest extends BuildViewTestCase {
+
+ @Before
+ public final void createFile() throws Exception {
+ scratch.file("java/srcs/a.properties", "foo");
+ }
+
+ // regression test for #3169099
+ @Test
+ public void testLibrarySrcs() throws Exception {
+ scratch.file("java/srcs/BUILD",
+ "android_library(name = 'valid', srcs = ['a.java', 'b.srcjar', ':gvalid', ':gmix'])",
+ "android_library(name = 'invalid', srcs = ['a.properties', ':ginvalid'])",
+ "android_library(name = 'mix', srcs = ['a.java', 'a.properties'])",
+ "genrule(name = 'gvalid', srcs = ['a.java'], outs = ['b.java'], cmd = '')",
+ "genrule(name = 'ginvalid', srcs = ['a.java'], outs = ['b.properties'], cmd = '')",
+ "genrule(name = 'gmix', srcs = ['a.java'], outs = ['c.java', 'c.properties'], cmd = '')"
+ );
+ assertSrcsValidityForRuleType("android_library", ".java or .srcjar");
+ }
+
+ // regression test for #3169099
+ @Test
+ public void testBinarySrcs() throws Exception {
+ scratch.file("java/srcs/BUILD",
+ "android_binary(name = 'empty', manifest = 'AndroidManifest.xml', srcs = [])",
+ "android_binary(name = 'valid', manifest = 'AndroidManifest.xml', "
+ + "srcs = ['a.java', 'b.srcjar', ':gvalid', ':gmix'])",
+ "android_binary(name = 'invalid', manifest = 'AndroidManifest.xml', "
+ + "srcs = ['a.properties', ':ginvalid'])",
+ "android_binary(name = 'mix', manifest = 'AndroidManifest.xml', "
+ + "srcs = ['a.java', 'a.properties'])",
+ "genrule(name = 'gvalid', srcs = ['a.java'], outs = ['b.java'], cmd = '')",
+ "genrule(name = 'ginvalid', srcs = ['a.java'], outs = ['b.properties'], cmd = '')",
+ "genrule(name = 'gmix', srcs = ['a.java'], outs = ['c.java', 'c.properties'], cmd = '')"
+ );
+ assertSrcsValidityForRuleType("android_binary", ".java or .srcjar");
+ }
+
+ private void assertSrcsValidityForRuleType(String rule, String expectedTypes) throws Exception {
+ reporter.removeHandler(failFastHandler);
+ String descriptionSingle = rule + " srcs file (expected " + expectedTypes + ")";
+ String descriptionPlural = rule + " srcs files (expected " + expectedTypes + ")";
+ String descriptionPluralFile = "(expected " + expectedTypes + ")";
+ assertSrcsValidity(rule, "//java/srcs:valid", false, "need at least one " + descriptionSingle,
+ "'//java/srcs:gvalid' is misplaced " + descriptionPlural,
+ "'//java/srcs:gmix' does not produce any " + descriptionPlural);
+ assertSrcsValidity(rule, "//java/srcs:invalid", true,
+ "file '//java/srcs:a.properties' is misplaced here " + descriptionPluralFile,
+ "'//java/srcs:ginvalid' does not produce any " + descriptionPlural);
+ assertSrcsValidity(rule, "//java/srcs:mix", true,
+ "'//java/srcs:a.properties' does not produce any " + descriptionPlural);
+ }
+
+ /**
+ * Tests expected values of
+ * {@link com.google.devtools.build.lib.rules.android.AndroidRuleClasses.MultidexMode}.
+ */
+ @Test
+ public void testMultidexModeEnum() throws Exception {
+ assertThat(MultidexMode.getValidValues()).containsExactly("native", "legacy", "manual_main_dex",
+ "off");
+ assertSame(MultidexMode.NATIVE, MultidexMode.fromValue("native"));
+ assertEquals("native", MultidexMode.NATIVE.getAttributeValue());
+ assertSame(MultidexMode.LEGACY, MultidexMode.fromValue("legacy"));
+ assertEquals("legacy", MultidexMode.LEGACY.getAttributeValue());
+ assertSame(MultidexMode.MANUAL_MAIN_DEX, MultidexMode.fromValue("manual_main_dex"));
+ assertEquals("manual_main_dex", MultidexMode.MANUAL_MAIN_DEX.getAttributeValue());
+ assertSame(MultidexMode.OFF, MultidexMode.fromValue("off"));
+ assertEquals("off", MultidexMode.OFF.getAttributeValue());
+ }
+
+ /**
+ * Tests that each multidex mode produces the expected output dex classes file name.
+ */
+ @Test
+ public void testOutputDexforMultidexModes() throws Exception {
+ assertEquals("classes.dex", MultidexMode.OFF.getOutputDexFilename());
+ assertEquals("classes.dex.zip", MultidexMode.LEGACY.getOutputDexFilename());
+ assertEquals("classes.dex.zip", MultidexMode.NATIVE.getOutputDexFilename());
+ }
+}