Skip to content

Commit

Permalink
[6.4.0] Add contains method inside PackageSpecificationProvider (b…
Browse files Browse the repository at this point in the history
…azelbuild#19425)

This method checks if a target exists inside an allowlist.

Cherry picking 8828015.
  • Loading branch information
kotlaja authored and keith committed Sep 8, 2023
1 parent 8e28723 commit e511aa4
Show file tree
Hide file tree
Showing 3 changed files with 189 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
package com.google.devtools.build.lib.analysis;

import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.cmdline.LabelSyntaxException;
import com.google.devtools.build.lib.collect.nestedset.NestedSet;
import com.google.devtools.build.lib.collect.nestedset.NestedSetBuilder;
import com.google.devtools.build.lib.collect.nestedset.Order;
Expand All @@ -26,6 +27,8 @@
import com.google.devtools.build.lib.packages.Provider;
import com.google.devtools.build.lib.starlarkbuildapi.PackageSpecificationProviderApi;
import java.util.Optional;
import net.starlark.java.eval.EvalException;
import net.starlark.java.eval.Starlark;

/**
* A {@link TransitiveInfoProvider} that describes a set of transitive package specifications used
Expand Down Expand Up @@ -92,4 +95,19 @@ private static NestedSet<PackageGroupContents> getPackageSpecifications(
builder.add(packageGroup.getPackageSpecifications());
return builder.build();
}

@Override
public boolean targetInAllowlist(Object target) throws EvalException, LabelSyntaxException {
Label targetLabel;
if (target instanceof String) {
targetLabel = Label.parseCanonical((String) target);
} else if (target instanceof Label) {
targetLabel = (Label) target;
} else {
throw Starlark.errorf(
"expected string or label for 'target' instead of %s", Starlark.type(target));
}

return Allowlist.isAvailableFor(packageSpecifications, targetLabel);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,30 @@
package com.google.devtools.build.lib.starlarkbuildapi;

import com.google.devtools.build.docgen.annot.DocCategory;
import com.google.devtools.build.lib.cmdline.Label;
import com.google.devtools.build.lib.cmdline.LabelSyntaxException;
import com.google.devtools.build.lib.starlarkbuildapi.core.StructApi;
import net.starlark.java.annot.Param;
import net.starlark.java.annot.ParamType;
import net.starlark.java.annot.StarlarkBuiltin;
import net.starlark.java.annot.StarlarkMethod;
import net.starlark.java.eval.EvalException;

/** Provider which describes a set of transitive package specifications used in package groups. */
@StarlarkBuiltin(
name = "PackageSpecificationInfo",
doc = "Information about transitive package specifications used in package groups.",
category = DocCategory.PROVIDER)
public interface PackageSpecificationProviderApi extends StructApi {}
public interface PackageSpecificationProviderApi extends StructApi {
@StarlarkMethod(
name = "contains",
doc = "Checks if a target exists in a package group.",
parameters = {
@Param(
name = "target",
positional = true,
doc = "A target which is checked if it exists inside the package group.",
allowedTypes = {@ParamType(type = Label.class), @ParamType(type = String.class)})
})
public boolean targetInAllowlist(Object target) throws EvalException, LabelSyntaxException;
}
Original file line number Diff line number Diff line change
Expand Up @@ -125,4 +125,156 @@ public void testIncludes() throws Exception {
getConfiguredTarget("//x:x");
assertNoEvents();
}

@Test
public void targetInAllowlist_targetAsStringParameter() throws Exception {
scratch.file(
"allowlist/BUILD",
"package_group(",
" name='allowlist',",
" packages=[",
" '//direct',",
" ])");
scratch.file(
"test/rule.bzl",
"def _impl(ctx):",
" target = '//direct:rule_from_allowlist'",
" target_in_allowlist ="
+ " ctx.attr._allowlist_test[PackageSpecificationInfo].contains(target)",
" if not target_in_allowlist:",
" fail('Target should be in the allowlist')",
" return []",
"custom_rule = rule(",
" implementation = _impl,",
" attrs = {",
" '_allowlist_test': attr.label(",
" default = '//allowlist:allowlist',",
" cfg = 'exec',",
" providers = ['PackageSpecificationInfo']",
" ),",
" },",
")");
scratch.file(
"test/BUILD",
"load('//test:rule.bzl', 'custom_rule')",
"custom_rule(name='allowlist_rule')");

getConfiguredTarget("//test:allowlist_rule");

assertNoEvents();
}

@Test
public void targetInAllowlist_targetAsLabelParameter() throws Exception {
scratch.file(
"allowlist/BUILD",
"package_group(",
" name='allowlist',",
" packages=[",
" '//test',",
" ])");
scratch.file(
"test/rule.bzl",
"def _impl(ctx):",
" target = ctx.label",
" target_in_allowlist ="
+ " ctx.attr._allowlist_test[PackageSpecificationInfo].contains(target)",
" if not target_in_allowlist:",
" fail('Target should be in the allowlist')",
" return []",
"custom_rule = rule(",
" implementation = _impl,",
" attrs = {",
" '_allowlist_test': attr.label(",
" default = '//allowlist:allowlist',",
" cfg = 'exec',",
" providers = [PackageSpecificationInfo]",
" ),",
" },",
")");
scratch.file(
"test/BUILD",
"load('//test:rule.bzl', 'custom_rule')",
"custom_rule(name='allowlist_rule')");

getConfiguredTarget("//test:allowlist_rule");

assertNoEvents();
}

@Test
public void targetNotInAllowlist() throws Exception {
scratch.file(
"allowlist/BUILD",
"package_group(",
" name='allowlist',",
" packages=[",
" '//direct',",
" ])");
scratch.file(
"test/rule.bzl",
"def _impl(ctx):",
" target = '//non_direct:rule_not_from_allowlist'",
" target_in_allowlist ="
+ " ctx.attr._allowlist_test[PackageSpecificationInfo].contains(target)",
" if target_in_allowlist:",
" fail('Target should not be in the allowlist')",
" return []",
"custom_rule = rule(",
" implementation = _impl,",
" attrs = {",
" '_allowlist_test': attr.label(",
" default = '//allowlist:allowlist',",
" cfg = 'exec',",
" providers = [PackageSpecificationInfo]",
" ),",
" },",
")");
scratch.file(
"test/BUILD",
"load('//test:rule.bzl', 'custom_rule')",
"custom_rule(name='allowlist_rule')");

getConfiguredTarget("//test:allowlist_rule");

assertNoEvents();
}

@Test
public void targetNotInAllowlist_negativePath() throws Exception {
scratch.file(
"allowlist/BUILD",
"package_group(",
" name='allowlist',",
" packages=[",
" '-//direct',",
" ])");
scratch.file(
"test/rule.bzl",
"def _impl(ctx):",
" target = '//direct:rule_from_allowlist'",
" target_in_allowlist ="
+ " ctx.attr._allowlist_test[PackageSpecificationInfo].contains(target)",
" if target_in_allowlist:",
" fail('Target should not be in the allowlist (negative path)')",
" return []",
"custom_rule = rule(",
" implementation = _impl,",
" attrs = {",
" '_allowlist_test': attr.label(",
" default = '//allowlist:allowlist',",
" cfg = 'exec',",
" providers = [PackageSpecificationInfo]",
" ),",
" },",
")");
scratch.file(
"test/BUILD",
"load('//test:rule.bzl', 'custom_rule')",
"custom_rule(name='allowlist_rule')");

getConfiguredTarget("//test:allowlist_rule");

assertNoEvents();
}
}

0 comments on commit e511aa4

Please sign in to comment.