Remove unnecessary core library neverallow rules

The rules that restricted access to core library targets are no longer
required as they have been replaced with visibility rules. The
visibility rules are safer because they check all dependencies whereas
the neverallow rules that have been removed only checked dependencies
in the libs property and so missed dependencies in static_libs and
java_libs properties.

(cherry picked from 8e8c01c382)

Bug: 112158820
Test: m core-tests
Change-Id: I3b50b705b7cd6fcdc55d26cd71b9149b3abd2b88
Merged-In: Ibfef74db0769992266ebadf445836d2a183df3f7
This commit is contained in:
Paul Duffin
2019-04-30 13:13:39 +01:00
parent 77b3fec7c1
commit ff5a177879
2 changed files with 3 additions and 31 deletions

View File

@@ -97,32 +97,15 @@ func createLibcoreRules() []*rule {
"external/wycheproof",
}
var coreModules = []string{
"core-all",
"core-oj",
"core-libart",
"okhttp",
"bouncycastle",
"conscrypt",
"apache-xml",
}
// Core library constraints. Prevent targets adding dependencies on core
// library internals, which could lead to compatibility issues with the ART
// mainline module. They should use core.platform.api.stubs instead.
// Core library constraints. The no_standard_libs can only be used in core
// library projects. Access to core library targets is restricted using
// visibility rules.
rules := []*rule{
neverallow().
notIn(append(coreLibraryProjects, "development")...).
with("no_standard_libs", "true"),
}
for _, m := range coreModules {
r := neverallow().
notIn(coreLibraryProjects...).
with("libs", m).
because("Only core libraries projects can depend on " + m)
rules = append(rules, r)
}
return rules
}

View File

@@ -137,17 +137,6 @@ var neverallowTests = []struct {
},
expectedError: "",
},
{
name: "dependency on core-libart",
fs: map[string][]byte{
"Blueprints": []byte(`
java_library {
name: "needs_core_libart",
libs: ["core-libart"],
}`),
},
expectedError: "Only core libraries projects can depend on core-libart",
},
{
name: "java_device_for_host",
fs: map[string][]byte{