diff options
author | vladmos <vladmos@google.com> | 2017-12-02 14:15:32 -0800 |
---|---|---|
committer | Copybara-Service <copybara-piper@google.com> | 2017-12-02 14:17:32 -0800 |
commit | 076977e019ebcb8b822e7727d292636fadcafcca (patch) | |
tree | 4251c2f6bfebec7efd940419ce727eaa4fe1df8b /src/test/java/com/google/devtools | |
parent | ff1b77e6e28b03592f2b5efb3f06bcf58a7d75b5 (diff) |
Fix missing print statements in output functions
PiperOrigin-RevId: 177708823
Diffstat (limited to 'src/test/java/com/google/devtools')
3 files changed, 31 insertions, 2 deletions
diff --git a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java index 571fe2345a..efdd13dcd7 100644 --- a/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java +++ b/src/test/java/com/google/devtools/build/lib/analysis/util/BuildViewTestCase.java @@ -1917,7 +1917,7 @@ public abstract class BuildViewTestCase extends FoundationTestCase { RawAttributeMapper attr = RawAttributeMapper.of(associatedRule); - String path = Iterables.getOnlyElement(outputFunction.getImplicitOutputs(attr)); + String path = Iterables.getOnlyElement(outputFunction.getImplicitOutputs(eventCollector, attr)); return view.getArtifactFactory() .getDerivedArtifact( diff --git a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkIntegrationTest.java b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkIntegrationTest.java index 8b2770a90a..8039563a44 100644 --- a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkIntegrationTest.java +++ b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkIntegrationTest.java @@ -915,6 +915,35 @@ public class SkylarkIntegrationTest extends BuildViewTestCase { } @Test + public void testRuleClassImplicitOutputFunctionPrints() throws Exception { + scratch.file( + "test/skylark/extension.bzl", + "def custom_rule_impl(ctx):", + " print('implementation', ctx.label)", + " files = [ctx.outputs.o]", + " ctx.actions.run_shell(", + " outputs = files,", + " command = 'echo')", + "", + "def output_func(name):", + " print('output function', name)", + " return {'o': name + '.txt'}", + "", + "custom_rule = rule(implementation = custom_rule_impl,", + " outputs = output_func)"); + + scratch.file( + "test/skylark/BUILD", + "load('/test/skylark/extension', 'custom_rule')", + "", + "custom_rule(name = 'cr')"); + + getConfiguredTarget("//test/skylark:cr"); + assertContainsEvent("output function cr"); + assertContainsEvent("implementation //test/skylark:cr"); + } + + @Test public void testRuleClassNonMandatoryEmptyOutputs() throws Exception { scratch.file( "test/skylark/extension.bzl", diff --git a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkRuleClassFunctionsTest.java b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkRuleClassFunctionsTest.java index 0371315830..d947562206 100644 --- a/src/test/java/com/google/devtools/build/lib/skylark/SkylarkRuleClassFunctionsTest.java +++ b/src/test/java/com/google/devtools/build/lib/skylark/SkylarkRuleClassFunctionsTest.java @@ -701,7 +701,7 @@ public class SkylarkRuleClassFunctionsTest extends SkylarkTestCase { "r1 = rule(impl, outputs = {'a': 'a.txt'})"); RuleClass c = ((SkylarkRuleFunction) lookup("r1")).getRuleClass(); ImplicitOutputsFunction function = c.getDefaultImplicitOutputsFunction(); - assertThat(function.getImplicitOutputs(null)).containsExactly("a.txt"); + assertThat(function.getImplicitOutputs(ev.getEventHandler(), null)).containsExactly("a.txt"); } @Test |