Merge "Add jarjar_rename property to java modules." into main

This commit is contained in:
Treehugger Robot
2024-07-22 14:04:06 +00:00
committed by Gerrit Code Review
3 changed files with 102 additions and 3 deletions

View File

@@ -101,6 +101,7 @@ bootstrap_go_package {
"hiddenapi_singleton_test.go",
"jacoco_test.go",
"java_test.go",
"jarjar_test.go",
"jdeps_test.go",
"kotlin_test.go",
"lint_test.go",

View File

@@ -91,6 +91,10 @@ type CommonProperties struct {
// if not blank, run jarjar using the specified rules file
Jarjar_rules *string `android:"path,arch_variant"`
// java class names to rename with jarjar when a reverse dependency has a jarjar_prefix
// property.
Jarjar_rename []string
// if not blank, used as prefix to generate repackage rule
Jarjar_prefix *string
@@ -2655,8 +2659,7 @@ func (module *Module) collectJarJarRules(ctx android.ModuleContext) *JarJarProvi
// Gather repackage information from deps
result := collectDirectDepsProviders(ctx)
// Update that with entries we've stored for ourself
for orig, renamed := range module.jarjarRenameRules {
add := func(orig string, renamed string) {
if result == nil {
result = &JarJarProviderData{
Rename: make(map[string]string),
@@ -2665,12 +2668,22 @@ func (module *Module) collectJarJarRules(ctx android.ModuleContext) *JarJarProvi
if renamed != "" {
if preexisting, exists := (*result).Rename[orig]; exists && preexisting != renamed {
ctx.ModuleErrorf("Conflicting jarjar rules inherited for class: %s (%s and %s)", orig, renamed, preexisting)
continue
return
}
}
(*result).Rename[orig] = renamed
}
// Update that with entries we've stored for ourself
for orig, renamed := range module.jarjarRenameRules {
add(orig, renamed)
}
// Update that with entries given in the jarjar_rename property.
for _, orig := range module.properties.Jarjar_rename {
add(orig, "")
}
// If there are no renamings, then jarjar_prefix does nothing, so skip the extra work.
if result == nil {
return nil

85
java/jarjar_test.go Normal file
View File

@@ -0,0 +1,85 @@
// Copyright 2018 Google Inc. 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 java
import (
"fmt"
"testing"
"android/soong/android"
)
func AssertJarJarRename(t *testing.T, result *android.TestResult, libName, original, expectedRename string) {
module := result.ModuleForTests(libName, "android_common")
provider, found := android.OtherModuleProvider(result.OtherModuleProviderAdaptor(), module.Module(), JarJarProvider)
android.AssertBoolEquals(t, fmt.Sprintf("found provider (%s)", libName), true, found)
renamed, found := provider.Rename[original]
android.AssertBoolEquals(t, fmt.Sprintf("found rename (%s)", libName), true, found)
android.AssertStringEquals(t, fmt.Sprintf("renamed (%s)", libName), expectedRename, renamed)
}
func TestJarJarRenameDifferentModules(t *testing.T) {
t.Parallel()
result := android.GroupFixturePreparers(
prepareForJavaTest,
).RunTestWithBp(t, `
java_library {
name: "their_lib",
jarjar_rename: ["com.example.a"],
}
java_library {
name: "boundary_lib",
jarjar_prefix: "RENAME",
static_libs: ["their_lib"],
}
java_library {
name: "my_lib",
static_libs: ["boundary_lib"],
}
`)
original := "com.example.a"
renamed := "RENAME.com.example.a"
AssertJarJarRename(t, result, "their_lib", original, "")
AssertJarJarRename(t, result, "boundary_lib", original, renamed)
AssertJarJarRename(t, result, "my_lib", original, renamed)
}
func TestJarJarRenameSameModule(t *testing.T) {
t.Parallel()
result := android.GroupFixturePreparers(
prepareForJavaTest,
).RunTestWithBp(t, `
java_library {
name: "their_lib",
jarjar_rename: ["com.example.a"],
jarjar_prefix: "RENAME",
}
java_library {
name: "my_lib",
static_libs: ["their_lib"],
}
`)
original := "com.example.a"
renamed := "RENAME.com.example.a"
AssertJarJarRename(t, result, "their_lib", original, renamed)
AssertJarJarRename(t, result, "my_lib", original, renamed)
}