diff options
author | 2018-04-16 12:03:20 -0700 | |
---|---|---|
committer | 2018-04-16 12:04:37 -0700 | |
commit | fd84a1333a9b2c17a8347ef0b21859624c9869f9 (patch) | |
tree | b20991b30e34ef27a2a9abff81fc5719fd1f0995 /src/test/java/com/google/devtools | |
parent | 835814895fffef00fe88658f91e4550dc61546cf (diff) |
Independently parse assets
This is the first step in processing assets completely seperately from resources.
RELNOTES: none
PiperOrigin-RevId: 193076991
Diffstat (limited to 'src/test/java/com/google/devtools')
4 files changed, 156 insertions, 69 deletions
diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/AndroidAssetsTest.java b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidAssetsTest.java new file mode 100644 index 0000000000..401443d3b5 --- /dev/null +++ b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidAssetsTest.java @@ -0,0 +1,56 @@ +// Copyright 2018 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 com.google.common.collect.ImmutableList; +import com.google.devtools.build.lib.analysis.RuleContext; +import com.google.devtools.build.lib.vfs.PathFragment; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.JUnit4; + +/** Tests {@link AndroidAssets} */ +@RunWith(JUnit4.class) +public class AndroidAssetsTest extends ResourceTestBase { + @Test + public void testParse() throws Exception { + RuleContext ruleContext = getRuleContext(); + AndroidAssets assets = + new AndroidAssets( + ImmutableList.of(getResource("asset_1"), getResource("asset_2")), + ImmutableList.of(PathFragment.create("asset_dir"))); + ParsedAndroidAssets parsed = assets.parse(ruleContext); + + // Assets should be unchanged + assertThat(parsed.getAssets()).isEqualTo(assets.getAssets()); + assertThat(parsed.getAssetRoots()).isEqualTo(assets.getAssetRoots()); + + // Label should be correct + assertThat(parsed.getLabel()).isEqualTo(ruleContext.getLabel()); + + // Symbols file should be created from raw assets + assertActionArtifacts( + ruleContext, + /* inputs = */ assets.getAssets(), + /* outputs = */ ImmutableList.of(parsed.getSymbols())); + } + + private RuleContext getRuleContext() throws Exception { + return getRuleContextForActionTesting( + scratchConfiguredTarget("pkg", "r", "android_library(name='r')")); + } +} diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/AndroidResourcesTest.java b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidResourcesTest.java index 113847fb60..5a008e4a70 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/android/AndroidResourcesTest.java +++ b/src/test/java/com/google/devtools/build/lib/rules/android/AndroidResourcesTest.java @@ -19,42 +19,24 @@ import static com.google.common.truth.Truth.assertWithMessage; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableSet; import com.google.common.collect.Iterables; -import com.google.common.collect.Streams; -import com.google.devtools.build.lib.actions.ActionAnalysisMetadata; import com.google.devtools.build.lib.actions.Artifact; -import com.google.devtools.build.lib.analysis.CachingAnalysisEnvironment; import com.google.devtools.build.lib.analysis.ConfiguredTarget; import com.google.devtools.build.lib.analysis.RuleContext; -import com.google.devtools.build.lib.analysis.config.BuildConfigurationCollection; -import com.google.devtools.build.lib.events.ExtendedEventHandler; -import com.google.devtools.build.lib.events.StoredEventHandler; import com.google.devtools.build.lib.packages.RuleClass.ConfiguredTargetFactory.RuleErrorException; -import com.google.devtools.build.lib.skyframe.ConfiguredTargetKey; import com.google.devtools.build.lib.vfs.PathFragment; import java.util.Optional; -import java.util.stream.Collectors; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.junit.runners.JUnit4; -/** Tests {@link AndroidResourcesTest} */ +/** Tests {@link AndroidResources} */ @RunWith(JUnit4.class) public class AndroidResourcesTest extends ResourceTestBase { private static final PathFragment DEFAULT_RESOURCE_ROOT = PathFragment.create(RESOURCE_ROOT); private static final ImmutableList<PathFragment> RESOURCES_ROOTS = ImmutableList.of(DEFAULT_RESOURCE_ROOT); - private static final ImmutableSet<String> TOOL_FILENAMES = - ImmutableSet.of( - "static_aapt_tool", - "aapt.static", - "aapt", - "aapt2", - "empty.sh", - "android_blaze.jar", - "android.jar"); - @Before @Test public void testGetResourceRootsNoResources() throws Exception { @@ -434,38 +416,6 @@ public class AndroidResourcesTest extends ResourceTestBase { } /** - * Assets that the action used to generate the given outputs has the expected inputs and outputs. - */ - private void assertActionArtifacts( - RuleContext ruleContext, ImmutableList<Artifact> inputs, ImmutableList<Artifact> outputs) { - // Actions must have at least one output - assertThat(outputs).isNotEmpty(); - - // Get the action from one of the outputs - ActionAnalysisMetadata action = - ruleContext.getAnalysisEnvironment().getLocalGeneratingAction(outputs.get(0)); - assertThat(action).isNotNull(); - - assertThat(removeToolingArtifacts(action.getInputs())).containsExactlyElementsIn(inputs); - - assertThat(action.getOutputs()).containsExactlyElementsIn(outputs); - } - - /** Remove busybox and aapt2 tooling artifacts from a list of action inputs */ - private Iterable<Artifact> removeToolingArtifacts(Iterable<Artifact> inputArtifacts) { - return Streams.stream(inputArtifacts) - .filter( - artifact -> - // Not a known tool - !TOOL_FILENAMES.contains(artifact.getFilename()) - // Not one of the various busybox tools (we get different ones on different OSs) - && !artifact.getFilename().contains("busybox") - // Not a params file - && !artifact.getFilename().endsWith(".params")) - .collect(Collectors.toList()); - } - - /** * Validates that a parse action was invoked correctly. Returns the {@link ParsedAndroidResources} * for further validation. */ @@ -510,23 +460,6 @@ public class AndroidResourcesTest extends ResourceTestBase { "android_library(name = 'target',", useDataBinding ? " enable_data_binding = True" : "", ")"); - RuleContext dummy = getRuleContext(target); - - ExtendedEventHandler eventHandler = new StoredEventHandler(); - assertThat(targetConfig.isActionsEnabled()).isTrue(); - return view.getRuleContextForTesting( - eventHandler, - target, - new CachingAnalysisEnvironment( - view.getArtifactFactory(), - skyframeExecutor.getActionKeyContext(), - ConfiguredTargetKey.of(target.getLabel(), targetConfig), - /*isSystemEnv=*/ false, - targetConfig.extendedSanityChecks(), - eventHandler, - /*env=*/ null, - targetConfig.isActionsEnabled()), - new BuildConfigurationCollection( - ImmutableList.of(dummy.getConfiguration()), dummy.getHostConfiguration())); + return getRuleContextForActionTesting(target); } } diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/BUILD b/src/test/java/com/google/devtools/build/lib/rules/android/BUILD index f00d1e9941..f023920c7d 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/android/BUILD +++ b/src/test/java/com/google/devtools/build/lib/rules/android/BUILD @@ -120,11 +120,27 @@ java_test( ], ) +java_test( + name = "AndroidAssetsTest", + srcs = ["AndroidAssetsTest.java"], + deps = [ + ":ResourceTestBase", + "//src/main/java/com/google/devtools/build/lib:android-rules", + "//src/main/java/com/google/devtools/build/lib:build-base", + "//src/main/java/com/google/devtools/build/lib/vfs", + "//third_party:guava", + "//third_party:junit4", + "//third_party:truth", + ], +) + java_library( name = "ResourceTestBase", srcs = ["ResourceTestBase.java"], deps = [ ":AndroidBuildViewTestCase", + "//src/main/java/com/google/devtools/build/lib:build-base", + "//src/main/java/com/google/devtools/build/lib:events", "//src/main/java/com/google/devtools/build/lib:packages-internal", "//src/main/java/com/google/devtools/build/lib/actions", "//src/main/java/com/google/devtools/build/lib/vfs", diff --git a/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java b/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java index e7fd7d4ad3..50d92b0fa7 100644 --- a/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java +++ b/src/test/java/com/google/devtools/build/lib/rules/android/ResourceTestBase.java @@ -18,14 +18,24 @@ import static com.google.common.truth.Truth.assertWithMessage; import com.google.common.collect.ArrayListMultimap; import com.google.common.collect.ImmutableList; +import com.google.common.collect.ImmutableSet; import com.google.common.collect.Multimap; +import com.google.common.collect.Streams; +import com.google.devtools.build.lib.actions.ActionAnalysisMetadata; import com.google.devtools.build.lib.actions.Artifact; import com.google.devtools.build.lib.actions.ArtifactOwner; import com.google.devtools.build.lib.actions.ArtifactRoot; +import com.google.devtools.build.lib.analysis.CachingAnalysisEnvironment; +import com.google.devtools.build.lib.analysis.ConfiguredTarget; +import com.google.devtools.build.lib.analysis.RuleContext; +import com.google.devtools.build.lib.analysis.config.BuildConfigurationCollection; import com.google.devtools.build.lib.cmdline.Label; import com.google.devtools.build.lib.cmdline.LabelSyntaxException; +import com.google.devtools.build.lib.events.ExtendedEventHandler; +import com.google.devtools.build.lib.events.StoredEventHandler; import com.google.devtools.build.lib.packages.AbstractRuleErrorConsumer; import com.google.devtools.build.lib.packages.RuleErrorConsumer; +import com.google.devtools.build.lib.skyframe.ConfiguredTargetKey; import com.google.devtools.build.lib.vfs.FileSystem; import com.google.devtools.build.lib.vfs.Path; import com.google.devtools.build.lib.vfs.Root; @@ -33,6 +43,7 @@ import com.google.devtools.build.lib.vfs.inmemoryfs.InMemoryFileSystem; import java.util.ArrayList; import java.util.Collection; import java.util.List; +import java.util.stream.Collectors; import org.junit.After; import org.junit.Before; @@ -40,6 +51,16 @@ import org.junit.Before; public abstract class ResourceTestBase extends AndroidBuildViewTestCase { public static final String RESOURCE_ROOT = "java/android/res"; + private static final ImmutableSet<String> TOOL_FILENAMES = + ImmutableSet.of( + "static_aapt_tool", + "aapt.static", + "aapt", + "aapt2", + "empty.sh", + "android_blaze.jar", + "android.jar"); + private static final ArtifactOwner OWNER = () -> { try { return Label.create("java", "all"); @@ -185,4 +206,65 @@ public abstract class ResourceTestBase extends AndroidBuildViewTestCase { return new Artifact( root, root.getExecPath().getRelative(root.getRoot().relativize(path)), OWNER); } + + /** + * Gets a RuleContext that can be used to register actions and test that they are created + * correctly. + * + * <p>Takes in a dummy target which will be used to configure the RuleContext's {@link + * AndroidConfiguration}. + */ + public RuleContext getRuleContextForActionTesting(ConfiguredTarget dummyTarget) throws Exception { + + RuleContext dummy = getRuleContext(dummyTarget); + + ExtendedEventHandler eventHandler = new StoredEventHandler(); + assertThat(targetConfig.isActionsEnabled()).isTrue(); + return view.getRuleContextForTesting( + eventHandler, + dummyTarget, + new CachingAnalysisEnvironment( + view.getArtifactFactory(), + skyframeExecutor.getActionKeyContext(), + ConfiguredTargetKey.of(dummyTarget.getLabel(), targetConfig), + /*isSystemEnv=*/ false, + targetConfig.extendedSanityChecks(), + eventHandler, + /*env=*/ null, + targetConfig.isActionsEnabled()), + new BuildConfigurationCollection( + ImmutableList.of(dummy.getConfiguration()), dummy.getHostConfiguration())); + } + + /** + * Assets that the action used to generate the given outputs has the expected inputs and outputs. + */ + void assertActionArtifacts( + RuleContext ruleContext, ImmutableList<Artifact> inputs, ImmutableList<Artifact> outputs) { + // Actions must have at least one output + assertThat(outputs).isNotEmpty(); + + // Get the action from one of the outputs + ActionAnalysisMetadata action = + ruleContext.getAnalysisEnvironment().getLocalGeneratingAction(outputs.get(0)); + assertThat(action).isNotNull(); + + assertThat(removeToolingArtifacts(action.getInputs())).containsExactlyElementsIn(inputs); + + assertThat(action.getOutputs()).containsExactlyElementsIn(outputs); + } + + /** Remove busybox and aapt2 tooling artifacts from a list of action inputs */ + private Iterable<Artifact> removeToolingArtifacts(Iterable<Artifact> inputArtifacts) { + return Streams.stream(inputArtifacts) + .filter( + artifact -> + // Not a known tool + !TOOL_FILENAMES.contains(artifact.getFilename()) + // Not one of the various busybox tools (we get different ones on different OSs) + && !artifact.getFilename().contains("busybox") + // Not a params file + && !artifact.getFilename().endsWith(".params")) + .collect(Collectors.toList()); + } } |