blob: 445e096e6b784b69a4355ceaa78b65312dd27c85 [file] [log] [blame]
Colin Crossb1974532019-02-15 10:37:39 -08001// Copyright 2019 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15package java
16
17import (
18 "fmt"
Paul Duffincee7e662020-07-09 17:32:57 +010019 "reflect"
Paul Duffin51d7da22021-06-16 02:04:13 +010020 "regexp"
Paul Duffincee7e662020-07-09 17:32:57 +010021 "sort"
Paul Duffin4fd997b2021-02-03 20:06:33 +000022 "strings"
Paul Duffincee7e662020-07-09 17:32:57 +010023 "testing"
Colin Crossb1974532019-02-15 10:37:39 -080024
25 "android/soong/android"
Colin Crossf28329d2020-02-15 11:00:10 -080026 "android/soong/cc"
Ulya Trafimovich24813e12020-10-07 15:05:21 +010027 "android/soong/dexpreopt"
Martin Stjernholm0e4cceb2021-05-13 02:38:35 +010028
Paul Duffincee7e662020-07-09 17:32:57 +010029 "github.com/google/blueprint"
Colin Crossb1974532019-02-15 10:37:39 -080030)
31
Paul Duffin95bdab42021-03-08 21:48:46 +000032const defaultJavaDir = "default/java"
Colin Cross98be1bb2019-12-13 20:41:13 -080033
Paul Duffin95bdab42021-03-08 21:48:46 +000034// Test fixture preparer that will register most java build components.
35//
36// Singletons and mutators should only be added here if they are needed for a majority of java
37// module types, otherwise they should be added under a separate preparer to allow them to be
38// selected only when needed to reduce test execution time.
39//
40// Module types do not have much of an overhead unless they are used so this should include as many
41// module types as possible. The exceptions are those module types that require mutators and/or
42// singletons in order to function in which case they should be kept together in a separate
43// preparer.
Paul Duffince5a4542021-03-15 12:17:54 +000044var PrepareForTestWithJavaBuildComponents = android.GroupFixturePreparers(
45 // Make sure that mutators and module types, e.g. prebuilt mutators available.
46 android.PrepareForTestWithAndroidBuildComponents,
47 // Make java build components available to the test.
Paul Duffin3c84eaa2021-03-23 15:23:33 +000048 android.FixtureRegisterWithContext(registerRequiredBuildComponentsForTest),
Paul Duffinc029c432021-03-22 15:00:28 +000049 android.FixtureRegisterWithContext(registerJavaPluginBuildComponents),
Paul Duffin76e5c8a2021-03-20 14:19:46 +000050 // Additional files needed in tests that disallow non-existent source files.
51 // This includes files that are needed by all, or at least most, instances of a java module type.
52 android.MockFS{
53 // Needed for linter used by java_library.
54 "build/soong/java/lint_defaults.txt": nil,
Paul Duffin27819362024-07-22 21:03:50 +010055 // Needed for java components that invoke Metalava.
56 "build/soong/java/metalava/Android.bp": []byte(`filegroup {name: "metalava-config-files"}`),
Paul Duffin76e5c8a2021-03-20 14:19:46 +000057 // Needed for apps that do not provide their own.
58 "build/make/target/product/security": nil,
Matt Banda8c801262022-04-01 17:48:31 +000059 // Required to generate Java used-by API coverage
60 "build/soong/scripts/gen_java_usedby_apex.sh": nil,
mattgilbride5aecabe2022-11-29 20:16:36 +000061 // Needed for the global lint checks provided from frameworks/base
62 "prebuilts/cmdline-tools/AndroidGlobalLintChecker.jar": nil,
Paul Duffin76e5c8a2021-03-20 14:19:46 +000063 }.AddToFixture(),
Paul Duffince5a4542021-03-15 12:17:54 +000064)
Paul Duffin95bdab42021-03-08 21:48:46 +000065
Sam Delmerico1e3f78f2022-09-07 12:07:07 -040066var prepareForTestWithFrameworkDeps = android.GroupFixturePreparers(
67 // The java default module definitions.
68 android.FixtureAddTextFile(defaultJavaDir+"/Android.bp", gatherRequiredDepsForTest()),
Paul Duffin76e5c8a2021-03-20 14:19:46 +000069 // Additional files needed when test disallows non-existent source.
70 android.MockFS{
71 // Needed for framework-res
72 defaultJavaDir + "/AndroidManifest.xml": nil,
73 // Needed for framework
74 defaultJavaDir + "/framework/aidl": nil,
75 // Needed for various deps defined in GatherRequiredDepsForTest()
Jihoon Kang795319f2023-05-17 00:23:38 +000076 defaultJavaDir + "/a.java": nil,
77 defaultJavaDir + "/api/current.txt": nil,
Jihoon Kang8f83dcd2023-10-09 17:53:04 +000078 defaultJavaDir + "/api/removed.txt": nil,
Jihoon Kang795319f2023-05-17 00:23:38 +000079 defaultJavaDir + "/api/system-current.txt": nil,
Jihoon Kang8f83dcd2023-10-09 17:53:04 +000080 defaultJavaDir + "/api/system-removed.txt": nil,
Jihoon Kang795319f2023-05-17 00:23:38 +000081 defaultJavaDir + "/api/test-current.txt": nil,
Jihoon Kang8f83dcd2023-10-09 17:53:04 +000082 defaultJavaDir + "/api/test-removed.txt": nil,
Jihoon Kang795319f2023-05-17 00:23:38 +000083 defaultJavaDir + "/api/module-lib-current.txt": nil,
Jihoon Kang8f83dcd2023-10-09 17:53:04 +000084 defaultJavaDir + "/api/module-lib-removed.txt": nil,
Jihoon Kang795319f2023-05-17 00:23:38 +000085 defaultJavaDir + "/api/system-server-current.txt": nil,
Jihoon Kang8f83dcd2023-10-09 17:53:04 +000086 defaultJavaDir + "/api/system-server-removed.txt": nil,
Colin Crossabc0dab2022-04-07 17:39:21 -070087
88 // Needed for R8 rules on apps
89 "build/make/core/proguard.flags": nil,
90 "build/make/core/proguard_basic_keeps.flags": nil,
Jared Duke51b0a102022-09-27 16:53:11 -070091 "prebuilts/cmdline-tools/shrinker.xml": nil,
Paul Duffin76e5c8a2021-03-20 14:19:46 +000092 }.AddToFixture(),
Sam Delmerico1e3f78f2022-09-07 12:07:07 -040093)
94
Jiakai Zhangb95998b2023-05-11 16:39:27 +010095var prepareForTestWithJavaDefaultModulesBase = android.GroupFixturePreparers(
Sam Delmerico1e3f78f2022-09-07 12:07:07 -040096 // Make sure that all the module types used in the defaults are registered.
97 PrepareForTestWithJavaBuildComponents,
98 prepareForTestWithFrameworkDeps,
Paul Duffin9fc9f532021-03-23 15:41:11 +000099 // Add dexpreopt compat libs (android.test.base, etc.) and a fake dex2oatd module.
100 dexpreopt.PrepareForTestWithDexpreoptCompatLibs,
Martin Stjernholm0e4cceb2021-05-13 02:38:35 +0100101)
102
103// Test fixture preparer that will define default java modules, e.g. standard prebuilt modules.
104var PrepareForTestWithJavaDefaultModules = android.GroupFixturePreparers(
Jiakai Zhangb95998b2023-05-11 16:39:27 +0100105 prepareForTestWithJavaDefaultModulesBase,
106 dexpreopt.FixtureDisableDexpreoptBootImages(true),
107 dexpreopt.FixtureDisableDexpreopt(true),
Paul Duffin9fc9f532021-03-23 15:41:11 +0000108)
109
110// Provides everything needed by dexpreopt.
111var PrepareForTestWithDexpreopt = android.GroupFixturePreparers(
Jiakai Zhangb95998b2023-05-11 16:39:27 +0100112 prepareForTestWithJavaDefaultModulesBase,
113 dexpreopt.PrepareForTestWithFakeDex2oatd,
114 dexpreopt.PrepareForTestByEnablingDexpreopt,
115)
116
117// Provides everything needed by dexpreopt except the fake_tool_binary for dex2oatd.
118var PrepareForTestWithDexpreoptWithoutFakeDex2oatd = android.GroupFixturePreparers(
119 prepareForTestWithJavaDefaultModulesBase,
Paul Duffin9fc9f532021-03-23 15:41:11 +0000120 dexpreopt.PrepareForTestByEnablingDexpreopt,
Paul Duffin95bdab42021-03-08 21:48:46 +0000121)
122
123// Prepare a fixture to use all java module types, mutators and singletons fully.
124//
125// This should only be used by tests that want to run with as much of the build enabled as possible.
126var PrepareForIntegrationTestWithJava = android.GroupFixturePreparers(
127 cc.PrepareForIntegrationTestWithCc,
128 PrepareForTestWithJavaDefaultModules,
129)
130
Paul Duffinbf028b52021-03-13 22:19:17 +0000131// Prepare a fixture with the standard files required by a java_sdk_library module.
Paul Duffin1efdb302021-03-14 00:04:51 +0000132var PrepareForTestWithJavaSdkLibraryFiles = android.FixtureMergeMockFs(android.MockFS{
Paul Duffinbf028b52021-03-13 22:19:17 +0000133 "api/current.txt": nil,
134 "api/removed.txt": nil,
135 "api/system-current.txt": nil,
136 "api/system-removed.txt": nil,
137 "api/test-current.txt": nil,
138 "api/test-removed.txt": nil,
139 "api/module-lib-current.txt": nil,
140 "api/module-lib-removed.txt": nil,
141 "api/system-server-current.txt": nil,
142 "api/system-server-removed.txt": nil,
Paul Duffin1efdb302021-03-14 00:04:51 +0000143})
Paul Duffinbf028b52021-03-13 22:19:17 +0000144
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000145// FixtureWithLastReleaseApis creates a preparer that creates prebuilt versions of the specified
146// modules for the `last` API release. By `last` it just means last in the list of supplied versions
147// and as this only provides one version it can be any value.
148//
149// This uses FixtureWithPrebuiltApis under the covers so the limitations of that apply to this.
150func FixtureWithLastReleaseApis(moduleNames ...string) android.FixturePreparer {
151 return FixtureWithPrebuiltApis(map[string][]string{
152 "30": moduleNames,
153 })
154}
155
156// PrepareForTestWithPrebuiltsOfCurrentApi is a preparer that creates prebuilt versions of the
157// standard modules for the current version.
158//
159// This uses FixtureWithPrebuiltApis under the covers so the limitations of that apply to this.
160var PrepareForTestWithPrebuiltsOfCurrentApi = FixtureWithPrebuiltApis(map[string][]string{
161 "current": {},
162 // Can't have current on its own as it adds a prebuilt_apis module but doesn't add any
163 // .txt files which causes the prebuilt_apis module to fail.
164 "30": {},
165})
166
Sam Delmerico1e3f78f2022-09-07 12:07:07 -0400167var prepareForTestWithFrameworkJacocoInstrumentation = android.GroupFixturePreparers(
168 android.FixtureMergeEnv(map[string]string{
169 "EMMA_INSTRUMENT_FRAMEWORK": "true",
170 }),
171 PrepareForTestWithJacocoInstrumentation,
172)
173
174// PrepareForTestWithJacocoInstrumentation creates a mock jacocoagent library that can be
175// depended on as part of the build process for instrumented Java modules.
176var PrepareForTestWithJacocoInstrumentation = android.GroupFixturePreparers(
177 android.FixtureMergeEnv(map[string]string{
178 "EMMA_INSTRUMENT": "true",
179 }),
180 android.FixtureAddFile("jacocoagent/Test.java", nil),
181 android.FixtureAddFile("jacocoagent/Android.bp", []byte(`
182 java_library {
183 name: "jacocoagent",
184 host_supported: true,
185 srcs: ["Test.java"],
186 sdk_version: "current",
187 }
188 `)),
189)
190
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000191// FixtureWithPrebuiltApis creates a preparer that will define prebuilt api modules for the
192// specified releases and modules.
193//
194// The supplied map keys are the releases, e.g. current, 29, 30, etc. The values are a list of
195// modules for that release. Due to limitations in the prebuilt_apis module which this preparer
196// uses the set of releases must include at least one numbered release, i.e. it cannot just include
197// "current".
198//
199// This defines a file in the mock file system in a predefined location (prebuilts/sdk/Android.bp)
200// and so only one instance of this can be used in each fixture.
201func FixtureWithPrebuiltApis(release2Modules map[string][]string) android.FixturePreparer {
Anton Hansson3a3f1692022-02-15 12:55:11 +0000202 return FixtureWithPrebuiltApisAndExtensions(release2Modules, nil)
203}
204
205func FixtureWithPrebuiltApisAndExtensions(apiLevel2Modules map[string][]string, extensionLevel2Modules map[string][]string) android.FixturePreparer {
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000206 mockFS := android.MockFS{}
207 path := "prebuilts/sdk/Android.bp"
208
209 bp := fmt.Sprintf(`
210 prebuilt_apis {
211 name: "sdk",
212 api_dirs: ["%s"],
Anton Hansson3a3f1692022-02-15 12:55:11 +0000213 extensions_dir: "extensions",
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000214 imports_sdk_version: "none",
215 imports_compile_dex: true,
216 }
Cole Faust18994c72023-02-28 16:02:16 -0800217 `, strings.Join(android.SortedKeys(apiLevel2Modules), `", "`))
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000218
Anton Hansson3a3f1692022-02-15 12:55:11 +0000219 for release, modules := range apiLevel2Modules {
Paul Duffin1cad3a52021-10-29 13:30:59 +0100220 mockFS.Merge(prebuiltApisFilesForModules([]string{release}, modules))
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000221 }
Anton Hansson3a3f1692022-02-15 12:55:11 +0000222 if extensionLevel2Modules != nil {
223 for release, modules := range extensionLevel2Modules {
224 mockFS.Merge(prebuiltExtensionApiFiles([]string{release}, modules))
225 }
226 }
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000227 return android.GroupFixturePreparers(
Paul Duffin2ff6d1b2021-03-13 22:37:27 +0000228 android.FixtureAddTextFile(path, bp),
229 android.FixtureMergeMockFs(mockFS),
230 )
231}
232
Todd Lee2ec7e1c2023-08-25 18:02:13 +0000233func FixtureWithPrebuiltIncrementalApis(apiLevel2Modules map[string][]string) android.FixturePreparer {
234 mockFS := android.MockFS{}
235 path := "prebuilts/sdk/Android.bp"
236
237 bp := fmt.Sprintf(`
238 prebuilt_apis {
239 name: "sdk",
240 api_dirs: ["%s"],
241 allow_incremental_platform_api: true,
242 imports_sdk_version: "none",
243 imports_compile_dex: true,
244 }
245 `, strings.Join(android.SortedKeys(apiLevel2Modules), `", "`))
246
247 for release, modules := range apiLevel2Modules {
248 mockFS.Merge(prebuiltApisFilesForModules([]string{release}, modules))
249 }
250 return android.GroupFixturePreparers(
251 android.FixtureAddTextFile(path, bp),
252 android.FixtureMergeMockFs(mockFS),
253 )
254}
255
Paul Duffin1cad3a52021-10-29 13:30:59 +0100256func prebuiltApisFilesForModules(apiLevels []string, modules []string) map[string][]byte {
257 libs := append([]string{"android"}, modules...)
258
Anton Hanssondff2c782020-12-21 17:10:01 +0000259 fs := make(map[string][]byte)
260 for _, level := range apiLevels {
Paul Duffin004547f2021-10-29 13:50:24 +0100261 apiLevel := android.ApiLevelForTest(level)
Paul Duffin1cad3a52021-10-29 13:30:59 +0100262 for _, sdkKind := range []android.SdkKind{android.SdkPublic, android.SdkSystem, android.SdkModule, android.SdkSystemServer, android.SdkTest} {
263 // A core-for-system-modules file must only be created for the sdk kind that supports it.
Paul Duffin004547f2021-10-29 13:50:24 +0100264 if sdkKind == systemModuleKind(sdkKind, apiLevel) {
Paul Duffin1cad3a52021-10-29 13:30:59 +0100265 fs[fmt.Sprintf("prebuilts/sdk/%s/%s/core-for-system-modules.jar", level, sdkKind)] = nil
266 }
267
268 for _, lib := range libs {
269 // Create a jar file for every library.
270 fs[fmt.Sprintf("prebuilts/sdk/%s/%s/%s.jar", level, sdkKind, lib)] = nil
271
Anton Hansson370fd0b2021-01-22 15:05:04 +0000272 // No finalized API files for "current"
273 if level != "current" {
Paul Duffin1cad3a52021-10-29 13:30:59 +0100274 fs[fmt.Sprintf("prebuilts/sdk/%s/%s/api/%s.txt", level, sdkKind, lib)] = nil
275 fs[fmt.Sprintf("prebuilts/sdk/%s/%s/api/%s-removed.txt", level, sdkKind, lib)] = nil
Anton Hansson370fd0b2021-01-22 15:05:04 +0000276 }
Anton Hanssondff2c782020-12-21 17:10:01 +0000277 }
278 }
Paul Duffin132c3e62021-10-28 18:16:14 +0100279 if level == "current" {
280 fs["prebuilts/sdk/current/core/android.jar"] = nil
281 }
Anton Hanssondff2c782020-12-21 17:10:01 +0000282 fs[fmt.Sprintf("prebuilts/sdk/%s/public/framework.aidl", level)] = nil
283 }
284 return fs
285}
286
Anton Hansson3a3f1692022-02-15 12:55:11 +0000287func prebuiltExtensionApiFiles(extensionLevels []string, modules []string) map[string][]byte {
288 fs := make(map[string][]byte)
289 for _, level := range extensionLevels {
290 for _, sdkKind := range []android.SdkKind{android.SdkPublic, android.SdkSystem, android.SdkModule, android.SdkSystemServer} {
291 for _, lib := range modules {
292 fs[fmt.Sprintf("prebuilts/sdk/extensions/%s/%s/api/%s.txt", level, sdkKind, lib)] = nil
293 fs[fmt.Sprintf("prebuilts/sdk/extensions/%s/%s/api/%s-removed.txt", level, sdkKind, lib)] = nil
294 }
295 }
296 }
297 return fs
298}
299
Paul Duffin60264a02021-04-12 20:02:36 +0100300// FixtureConfigureBootJars configures the boot jars in both the dexpreopt.GlobalConfig and
301// Config.productVariables structs. As a side effect that enables dexpreopt.
302func FixtureConfigureBootJars(bootJars ...string) android.FixturePreparer {
303 artBootJars := []string{}
304 for _, j := range bootJars {
305 artApex := false
306 for _, artApexName := range artApexNames {
307 if strings.HasPrefix(j, artApexName+":") {
308 artApex = true
309 break
310 }
311 }
312 if artApex {
313 artBootJars = append(artBootJars, j)
314 }
315 }
316 return android.GroupFixturePreparers(
317 android.FixtureModifyProductVariables(func(variables android.FixtureProductVariables) {
318 variables.BootJars = android.CreateTestConfiguredJarList(bootJars)
319 }),
320 dexpreopt.FixtureSetBootJars(bootJars...),
321 dexpreopt.FixtureSetArtBootJars(artBootJars...),
Paul Duffina57835e2021-04-19 13:23:06 +0100322
323 // Add a fake dex2oatd module.
324 dexpreopt.PrepareForTestWithFakeDex2oatd,
Paul Duffin60264a02021-04-12 20:02:36 +0100325 )
326}
327
satayevd604b212021-07-21 14:23:52 +0100328// FixtureConfigureApexBootJars configures the apex boot jars in both the
Paul Duffin60264a02021-04-12 20:02:36 +0100329// dexpreopt.GlobalConfig and Config.productVariables structs. As a side effect that enables
330// dexpreopt.
satayevd604b212021-07-21 14:23:52 +0100331func FixtureConfigureApexBootJars(bootJars ...string) android.FixturePreparer {
Paul Duffin60264a02021-04-12 20:02:36 +0100332 return android.GroupFixturePreparers(
333 android.FixtureModifyProductVariables(func(variables android.FixtureProductVariables) {
satayevd604b212021-07-21 14:23:52 +0100334 variables.ApexBootJars = android.CreateTestConfiguredJarList(bootJars)
Paul Duffin60264a02021-04-12 20:02:36 +0100335 }),
satayevd604b212021-07-21 14:23:52 +0100336 dexpreopt.FixtureSetApexBootJars(bootJars...),
Paul Duffina57835e2021-04-19 13:23:06 +0100337
338 // Add a fake dex2oatd module.
339 dexpreopt.PrepareForTestWithFakeDex2oatd,
Paul Duffin60264a02021-04-12 20:02:36 +0100340 )
341}
342
Paul Duffin1ea7c9f2021-03-15 09:39:13 +0000343// FixtureUseLegacyCorePlatformApi prepares the fixture by setting the exception list of those
344// modules that are allowed to use the legacy core platform API to be the ones supplied.
345func FixtureUseLegacyCorePlatformApi(moduleNames ...string) android.FixturePreparer {
346 lookup := make(map[string]struct{})
347 for _, moduleName := range moduleNames {
348 lookup[moduleName] = struct{}{}
349 }
350 return android.FixtureModifyConfig(func(config android.Config) {
351 // Try and set the legacyCorePlatformApiLookup in the config, the returned value will be the
352 // actual value that is set.
353 cached := config.Once(legacyCorePlatformApiLookupKey, func() interface{} {
354 return lookup
355 })
356 // Make sure that the cached value is the one we need.
357 if !reflect.DeepEqual(cached, lookup) {
358 panic(fmt.Errorf("attempting to set legacyCorePlatformApiLookupKey to %q but it has already been set to %q", lookup, cached))
359 }
360 })
361}
362
Paul Duffin3c84eaa2021-03-23 15:23:33 +0000363// registerRequiredBuildComponentsForTest registers the build components used by
364// PrepareForTestWithJavaDefaultModules.
365//
366// As functionality is moved out of here into separate FixturePreparer instances they should also
367// be moved into GatherRequiredDepsForTest for use by tests that have not yet switched to use test
368// fixtures.
369func registerRequiredBuildComponentsForTest(ctx android.RegistrationContext) {
Paul Duffinc059c8c2021-01-20 17:13:52 +0000370 RegisterAARBuildComponents(ctx)
371 RegisterAppBuildComponents(ctx)
372 RegisterAppImportBuildComponents(ctx)
373 RegisterAppSetBuildComponents(ctx)
Paul Duffin4994d262021-04-22 12:08:59 +0100374 registerBootclasspathBuildComponents(ctx)
Paul Duffin7771eba2021-04-23 14:25:28 +0100375 registerBootclasspathFragmentBuildComponents(ctx)
Paul Duffinc059c8c2021-01-20 17:13:52 +0000376 RegisterDexpreoptBootJarsComponents(ctx)
377 RegisterDocsBuildComponents(ctx)
378 RegisterGenRuleBuildComponents(ctx)
Paul Duffin535e0a12021-03-30 23:34:32 +0100379 registerJavaBuildComponents(ctx)
Paul Duffinbb7f1ac2021-03-29 22:18:45 +0100380 registerPlatformBootclasspathBuildComponents(ctx)
Paul Duffinc059c8c2021-01-20 17:13:52 +0000381 RegisterPrebuiltApisBuildComponents(ctx)
382 RegisterRuntimeResourceOverlayBuildComponents(ctx)
383 RegisterSdkLibraryBuildComponents(ctx)
384 RegisterStubsBuildComponents(ctx)
385 RegisterSystemModulesBuildComponents(ctx)
satayev95e9c5b2021-04-29 11:50:26 +0100386 registerSystemserverClasspathBuildComponents(ctx)
Jaewoong Jung476b9d62021-05-10 15:30:00 -0700387 registerLintBuildComponents(ctx)
Spandan Dasda739a32023-12-13 00:06:32 +0000388 android.RegisterApexContributionsBuildComponents(ctx)
Paul Duffinc059c8c2021-01-20 17:13:52 +0000389}
390
Paul Duffin3c84eaa2021-03-23 15:23:33 +0000391// gatherRequiredDepsForTest gathers the module definitions used by
392// PrepareForTestWithJavaDefaultModules.
393//
394// As functionality is moved out of here into separate FixturePreparer instances they should also
395// be moved into GatherRequiredDepsForTest for use by tests that have not yet switched to use test
396// fixtures.
397func gatherRequiredDepsForTest() string {
Colin Crossb1974532019-02-15 10:37:39 -0800398 var bp string
399
400 extraModules := []string{
401 "core-lambda-stubs",
Colin Crossb1974532019-02-15 10:37:39 -0800402 "ext",
Colin Crossb1974532019-02-15 10:37:39 -0800403 "android_stubs_current",
404 "android_system_stubs_current",
405 "android_test_stubs_current",
Jiyong Park50146e92020-01-30 18:00:15 +0900406 "android_module_lib_stubs_current",
Anton Hanssonba6ab2e2020-03-19 15:23:38 +0000407 "android_system_server_stubs_current",
Colin Crossb1974532019-02-15 10:37:39 -0800408 "core.current.stubs",
Pete Gillin1f41dbf2020-06-02 15:59:45 +0100409 "legacy.core.platform.api.stubs",
410 "stable.core.platform.api.stubs",
Spandan Das6bd19dd2023-03-30 17:54:58 +0000411
Jihoon Kangbd093452023-12-26 19:08:01 +0000412 "android_stubs_current_exportable",
413 "android_system_stubs_current_exportable",
414 "android_test_stubs_current_exportable",
415 "android_module_lib_stubs_current_exportable",
416 "android_system_server_stubs_current_exportable",
417 "core.current.stubs.exportable",
418 "legacy.core.platform.api.stubs.exportable",
419
Colin Crossb1974532019-02-15 10:37:39 -0800420 "kotlin-stdlib",
Colin Cross0b03d972019-05-13 11:06:25 -0700421 "kotlin-stdlib-jdk7",
422 "kotlin-stdlib-jdk8",
Colin Crossb1974532019-02-15 10:37:39 -0800423 "kotlin-annotations",
Anton Hanssond78eb762021-09-21 15:25:12 +0100424 "stub-annotations",
Joe Onorato8f755852023-08-25 20:23:32 -0700425
426 "aconfig-annotations-lib",
Zhi Dou96124802024-07-30 14:15:36 +0000427 "aconfig_storage_reader_java",
Zhi Dou1b052b02023-10-06 07:28:48 +0000428 "unsupportedappusage",
Colin Crossb1974532019-02-15 10:37:39 -0800429 }
430
431 for _, extra := range extraModules {
432 bp += fmt.Sprintf(`
433 java_library {
434 name: "%s",
435 srcs: ["a.java"],
Paul Duffin52d398a2019-06-11 12:31:14 +0100436 sdk_version: "none",
Pete Gillin84c38072020-07-09 18:03:41 +0100437 system_modules: "stable-core-platform-api-stubs-system-modules",
Liz Kammer5ca3a622020-08-05 15:40:41 -0700438 compile_dex: true,
Colin Crossb1974532019-02-15 10:37:39 -0800439 }
440 `, extra)
441 }
442
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000443 type droidstubsStruct struct {
444 name string
445 apiSurface string
446 apiFile string
447 removedFile string
Jihoon Kangc0a24202023-04-04 22:04:43 +0000448 }
449
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000450 var publicDroidstubs = droidstubsStruct{
451 name: "api-stubs-docs-non-updatable",
452 apiSurface: "public",
453 apiFile: "api/current.txt",
454 removedFile: "api/removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000455 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000456 var systemDroidstubs = droidstubsStruct{
457 name: "system-api-stubs-docs-non-updatable",
458 apiSurface: "system",
459 apiFile: "api/system-current.txt",
460 removedFile: "api/system-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000461 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000462 var testDroidstubs = droidstubsStruct{
463 name: "test-api-stubs-docs-non-updatable",
464 apiSurface: "test",
465 apiFile: "api/test-current.txt",
466 removedFile: "api/test-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000467 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000468 var moduleLibDroidstubs = droidstubsStruct{
469 name: "module-lib-api-stubs-docs-non-updatable",
470 apiSurface: "module-lib",
471 apiFile: "api/module-lib-current.txt",
472 removedFile: "api/module-lib-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000473 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000474 var systemServerDroidstubs = droidstubsStruct{
Jihoon Kang6be0f002023-09-20 23:03:01 +0000475 // This module does not exist but is named this way for consistency
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000476 name: "system-server-api-stubs-docs-non-updatable",
477 apiSurface: "system-server",
478 apiFile: "api/system-server-current.txt",
479 removedFile: "api/system-server-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000480 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000481 var droidstubsStructs = []droidstubsStruct{
482 publicDroidstubs,
483 systemDroidstubs,
484 testDroidstubs,
485 moduleLibDroidstubs,
486 systemServerDroidstubs,
Jihoon Kang6be0f002023-09-20 23:03:01 +0000487 }
488
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000489 extraApiLibraryModules := map[string]droidstubsStruct{
490 "android_stubs_current.from-text": publicDroidstubs,
491 "android_system_stubs_current.from-text": systemDroidstubs,
492 "android_test_stubs_current.from-text": testDroidstubs,
493 "android_module_lib_stubs_current.from-text": moduleLibDroidstubs,
494 "android_module_lib_stubs_current_full.from-text": moduleLibDroidstubs,
495 "android_system_server_stubs_current.from-text": systemServerDroidstubs,
496 "core.current.stubs.from-text": publicDroidstubs,
497 "legacy.core.platform.api.stubs.from-text": publicDroidstubs,
498 "stable.core.platform.api.stubs.from-text": publicDroidstubs,
499 "core-lambda-stubs.from-text": publicDroidstubs,
500 "android-non-updatable.stubs.from-text": publicDroidstubs,
501 "android-non-updatable.stubs.system.from-text": systemDroidstubs,
502 "android-non-updatable.stubs.test.from-text": testDroidstubs,
503 "android-non-updatable.stubs.module_lib.from-text": moduleLibDroidstubs,
Jihoon Kang244d42a2023-10-06 16:54:58 +0000504 "android-non-updatable.stubs.test_module_lib": moduleLibDroidstubs,
Jihoon Kang6be0f002023-09-20 23:03:01 +0000505 }
506
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000507 for _, droidstubs := range droidstubsStructs {
Jihoon Kang6be0f002023-09-20 23:03:01 +0000508 bp += fmt.Sprintf(`
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000509 droidstubs {
Jihoon Kang6be0f002023-09-20 23:03:01 +0000510 name: "%s",
511 api_surface: "%s",
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000512 check_api: {
513 current: {
514 api_file: "%s",
515 removed_api_file: "%s",
516 }
517 }
Jihoon Kang6be0f002023-09-20 23:03:01 +0000518 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000519 `,
520 droidstubs.name,
521 droidstubs.apiSurface,
522 droidstubs.apiFile,
523 droidstubs.removedFile,
524 )
Jihoon Kang6be0f002023-09-20 23:03:01 +0000525 }
526
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000527 for libName, droidstubs := range extraApiLibraryModules {
Jihoon Kangc0a24202023-04-04 22:04:43 +0000528 bp += fmt.Sprintf(`
Jihoon Kang5d701272024-02-15 21:53:49 +0000529 java_api_library {
530 name: "%s",
531 api_contributions: ["%s"],
532 stubs_type: "everything",
533 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000534 `, libName, droidstubs.name+".api.contribution")
Jihoon Kangc0a24202023-04-04 22:04:43 +0000535 }
536
Colin Crossb1974532019-02-15 10:37:39 -0800537 bp += `
Colin Cross3047fa22019-04-18 10:56:44 -0700538 java_library {
539 name: "framework",
540 srcs: ["a.java"],
Paul Duffina3d09862019-06-11 13:40:47 +0100541 sdk_version: "none",
Pete Gillin84c38072020-07-09 18:03:41 +0100542 system_modules: "stable-core-platform-api-stubs-system-modules",
Colin Cross3047fa22019-04-18 10:56:44 -0700543 aidl: {
544 export_include_dirs: ["framework/aidl"],
545 },
Paul Duffin8eb45732022-10-04 19:03:31 +0100546 compile_dex: true,
Colin Cross3047fa22019-04-18 10:56:44 -0700547 }
548
Colin Crossb1974532019-02-15 10:37:39 -0800549 android_app {
550 name: "framework-res",
Paul Duffin50c217c2019-06-12 13:25:22 +0100551 sdk_version: "core_platform",
Ulya Trafimovich24813e12020-10-07 15:05:21 +0100552 }`
Colin Crossb1974532019-02-15 10:37:39 -0800553
554 systemModules := []string{
Paul Duffin10fb76f2021-11-03 16:53:31 +0000555 "core-public-stubs-system-modules",
Victor Changb54f5aa2021-06-29 22:05:58 +0100556 "core-module-lib-stubs-system-modules",
Pete Gillin1f41dbf2020-06-02 15:59:45 +0100557 "legacy-core-platform-api-stubs-system-modules",
Pete Gillin40a06422020-07-01 10:59:00 +0100558 "stable-core-platform-api-stubs-system-modules",
Spandan Das6bd19dd2023-03-30 17:54:58 +0000559 "core-public-stubs-system-modules.from-text",
560 "core-module-lib-stubs-system-modules.from-text",
561 "legacy-core-platform-api-stubs-system-modules.from-text",
562 "stable-core-platform-api-stubs-system-modules.from-text",
Colin Crossb1974532019-02-15 10:37:39 -0800563 }
564
565 for _, extra := range systemModules {
566 bp += fmt.Sprintf(`
567 java_system_modules {
Paul Duffin68289b02019-09-20 13:50:52 +0100568 name: "%[1]s",
569 libs: ["%[1]s-lib"],
570 }
571 java_library {
572 name: "%[1]s-lib",
573 sdk_version: "none",
574 system_modules: "none",
Colin Crossb1974532019-02-15 10:37:39 -0800575 }
576 `, extra)
577 }
578
Paul Duffin1ab61862021-01-20 17:44:53 +0000579 // Make sure that the dex_bootjars singleton module is instantiated for the tests.
580 bp += `
581 dex_bootjars {
582 name: "dex_bootjars",
583 }
584`
585
Spandan Dasda739a32023-12-13 00:06:32 +0000586 bp += `
587 all_apex_contributions {
588 name: "all_apex_contributions",
589 }
590`
Colin Crossb1974532019-02-15 10:37:39 -0800591 return bp
592}
Paul Duffincee7e662020-07-09 17:32:57 +0100593
Jihoon Kangf00200b2023-10-09 18:00:17 +0000594func getModuleDependencies(t *testing.T, ctx *android.TestContext, name, variant string) []string {
Paul Duffincee7e662020-07-09 17:32:57 +0100595 t.Helper()
596 module := ctx.ModuleForTests(name, variant).Module()
597 deps := []string{}
598 ctx.VisitDirectDeps(module, func(m blueprint.Module) {
599 deps = append(deps, m.Name())
600 })
601 sort.Strings(deps)
602
Jihoon Kangf00200b2023-10-09 18:00:17 +0000603 return deps
604}
605
606// CheckModuleDependencies checks if the expected dependencies of the module are
607// identical to the actual dependencies.
608func CheckModuleDependencies(t *testing.T, ctx *android.TestContext, name, variant string, expected []string) {
609 deps := getModuleDependencies(t, ctx, name, variant)
610
Paul Duffincee7e662020-07-09 17:32:57 +0100611 if actual := deps; !reflect.DeepEqual(expected, actual) {
612 t.Errorf("expected %#q, found %#q", expected, actual)
613 }
614}
Paul Duffin4fd997b2021-02-03 20:06:33 +0000615
Jihoon Kangf00200b2023-10-09 18:00:17 +0000616// CheckModuleHasDependency returns true if the module depends on the expected dependency.
617func CheckModuleHasDependency(t *testing.T, ctx *android.TestContext, name, variant string, expected string) bool {
618 for _, dep := range getModuleDependencies(t, ctx, name, variant) {
619 if dep == expected {
620 return true
621 }
622 }
623 return false
624}
625
Paul Duffinb432df92021-03-22 22:09:42 +0000626// CheckPlatformBootclasspathModules returns the apex:module pair for the modules depended upon by
627// the platform-bootclasspath module.
628func CheckPlatformBootclasspathModules(t *testing.T, result *android.TestResult, name string, expected []string) {
629 t.Helper()
630 platformBootclasspath := result.Module(name, "android_common").(*platformBootclasspathModule)
631 pairs := ApexNamePairsFromModules(result.TestContext, platformBootclasspath.configuredModules)
632 android.AssertDeepEquals(t, fmt.Sprintf("%s modules", "platform-bootclasspath"), expected, pairs)
633}
634
satayevb3090502021-06-15 17:49:10 +0100635func CheckClasspathFragmentProtoContentInfoProvider(t *testing.T, result *android.TestResult, generated bool, contents, outputFilename, installDir string) {
636 t.Helper()
637 p := result.Module("platform-bootclasspath", "android_common").(*platformBootclasspathModule)
Colin Cross5a377182023-12-14 14:46:23 -0800638 info, _ := android.SingletonModuleProvider(result, p, ClasspathFragmentProtoContentInfoProvider)
satayevb3090502021-06-15 17:49:10 +0100639
640 android.AssertBoolEquals(t, "classpath proto generated", generated, info.ClasspathFragmentProtoGenerated)
641 android.AssertStringEquals(t, "classpath proto contents", contents, info.ClasspathFragmentProtoContents.String())
642 android.AssertStringEquals(t, "output filepath", outputFilename, info.ClasspathFragmentProtoOutput.Base())
643 android.AssertPathRelativeToTopEquals(t, "install filepath", installDir, info.ClasspathFragmentProtoInstallDir)
644}
645
Paul Duffinb432df92021-03-22 22:09:42 +0000646// ApexNamePairsFromModules returns the apex:module pair for the supplied modules.
647func ApexNamePairsFromModules(ctx *android.TestContext, modules []android.Module) []string {
648 pairs := []string{}
649 for _, module := range modules {
650 pairs = append(pairs, apexNamePairFromModule(ctx, module))
651 }
652 return pairs
653}
654
655func apexNamePairFromModule(ctx *android.TestContext, module android.Module) string {
656 name := module.Name()
657 var apex string
Colin Cross5a377182023-12-14 14:46:23 -0800658 apexInfo, _ := android.SingletonModuleProvider(ctx, module, android.ApexInfoProvider)
Paul Duffinb432df92021-03-22 22:09:42 +0000659 if apexInfo.IsForPlatform() {
660 apex = "platform"
661 } else {
Jiyong Parkab50b072021-05-12 17:13:56 +0900662 apex = apexInfo.InApexVariants[0]
Paul Duffinb432df92021-03-22 22:09:42 +0000663 }
664
665 return fmt.Sprintf("%s:%s", apex, name)
666}
667
Paul Duffin62d8c3b2021-04-07 20:35:11 +0100668// CheckPlatformBootclasspathFragments returns the apex:module pair for the fragments depended upon
669// by the platform-bootclasspath module.
670func CheckPlatformBootclasspathFragments(t *testing.T, result *android.TestResult, name string, expected []string) {
671 t.Helper()
672 platformBootclasspath := result.Module(name, "android_common").(*platformBootclasspathModule)
673 pairs := ApexNamePairsFromModules(result.TestContext, platformBootclasspath.fragments)
674 android.AssertDeepEquals(t, fmt.Sprintf("%s fragments", "platform-bootclasspath"), expected, pairs)
675}
676
Paul Duffin51d7da22021-06-16 02:04:13 +0100677func CheckHiddenAPIRuleInputs(t *testing.T, message string, expected string, hiddenAPIRule android.TestingBuildParams) {
Paul Duffin37856732021-02-26 14:24:15 +0000678 t.Helper()
Paul Duffin51d7da22021-06-16 02:04:13 +0100679 inputs := android.Paths{}
680 if hiddenAPIRule.Input != nil {
681 inputs = append(inputs, hiddenAPIRule.Input)
682 }
683 inputs = append(inputs, hiddenAPIRule.Inputs...)
684 inputs = append(inputs, hiddenAPIRule.Implicits...)
685 inputs = android.SortedUniquePaths(inputs)
686 actual := strings.TrimSpace(strings.Join(inputs.RelativeToTop().Strings(), "\n"))
687 re := regexp.MustCompile(`\n\s+`)
688 expected = strings.TrimSpace(re.ReplaceAllString(expected, "\n"))
Paul Duffin4fd997b2021-02-03 20:06:33 +0000689 if actual != expected {
Paul Duffin51d7da22021-06-16 02:04:13 +0100690 t.Errorf("Expected hiddenapi rule inputs - %s:\n%s\nactual inputs:\n%s", message, expected, actual)
Paul Duffin4fd997b2021-02-03 20:06:33 +0000691 }
692}
Paul Duffin001b2342021-03-11 18:43:31 +0000693
694// Check that the merged file create by platform_compat_config_singleton has the correct inputs.
695func CheckMergedCompatConfigInputs(t *testing.T, result *android.TestResult, message string, expectedPaths ...string) {
696 sourceGlobalCompatConfig := result.SingletonForTests("platform_compat_config_singleton")
697 allOutputs := sourceGlobalCompatConfig.AllOutputs()
698 android.AssertIntEquals(t, message+": output len", 1, len(allOutputs))
699 output := sourceGlobalCompatConfig.Output(allOutputs[0])
700 android.AssertPathsRelativeToTopEquals(t, message+": inputs", expectedPaths, output.Implicits)
701}
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000702
703// Register the fake APEX mutator to `android.InitRegistrationContext` as if the real mutator exists
704// at runtime. This must be called in `init()` of a test if the test is going to use the fake APEX
705// mutator. Otherwise, we will be missing the runtime mutator because "soong-apex" is not a
706// dependency, which will cause an inconsistency between testing and runtime mutators.
707func RegisterFakeRuntimeApexMutator() {
708 registerFakeApexMutator(android.InitRegistrationContext)
709}
710
711var PrepareForTestWithFakeApexMutator = android.GroupFixturePreparers(
712 android.FixtureRegisterWithContext(registerFakeApexMutator),
713)
714
715func registerFakeApexMutator(ctx android.RegistrationContext) {
716 ctx.PostDepsMutators(func(ctx android.RegisterMutatorsContext) {
Colin Cross7c035062024-03-28 12:18:42 -0700717 ctx.Transition("apex", &fakeApexMutator{})
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000718 })
719}
720
721type apexModuleBase interface {
722 ApexAvailable() []string
723}
724
725var _ apexModuleBase = (*Library)(nil)
726var _ apexModuleBase = (*SdkLibrary)(nil)
727
728// A fake APEX mutator that creates a platform variant and an APEX variant for modules with
729// `apex_available`. It helps us avoid a dependency on the real mutator defined in "soong-apex",
730// which will cause a cyclic dependency, and it provides an easy way to create an APEX variant for
731// testing without dealing with all the complexities in the real mutator.
Colin Cross7c035062024-03-28 12:18:42 -0700732type fakeApexMutator struct{}
733
734func (f *fakeApexMutator) Split(ctx android.BaseModuleContext) []string {
735 switch ctx.Module().(type) {
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000736 case *Library, *SdkLibrary:
Colin Cross7c035062024-03-28 12:18:42 -0700737 return []string{"", "apex1000"}
738 }
739 return []string{""}
740}
741
742func (f *fakeApexMutator) OutgoingTransition(ctx android.OutgoingTransitionContext, sourceVariation string) string {
743 return sourceVariation
744}
745
746func (f *fakeApexMutator) IncomingTransition(ctx android.IncomingTransitionContext, incomingVariation string) string {
747 return incomingVariation
748}
749
750func (f *fakeApexMutator) Mutate(ctx android.BottomUpMutatorContext, variation string) {
751 if variation != "" {
752 apexInfo := android.ApexInfo{
753 ApexVariationName: "apex1000",
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000754 }
Colin Cross7c035062024-03-28 12:18:42 -0700755 android.SetProvider(ctx, android.ApexInfoProvider, apexInfo)
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000756 }
757}
Jiakai Zhang6decef92022-01-12 17:56:19 +0000758
759// Applies the given modifier on the boot image config with the given name.
760func FixtureModifyBootImageConfig(name string, configModifier func(*bootImageConfig)) android.FixturePreparer {
761 return android.FixtureModifyConfig(func(androidConfig android.Config) {
762 pathCtx := android.PathContextForTesting(androidConfig)
763 config := genBootImageConfigRaw(pathCtx)
764 configModifier(config[name])
765 })
766}
767
Jiakai Zhang09d88df2023-05-10 17:04:53 +0100768// Sets the value of `installDir` of the boot image config with the given name.
Jiakai Zhang6decef92022-01-12 17:56:19 +0000769func FixtureSetBootImageInstallDirOnDevice(name string, installDir string) android.FixturePreparer {
770 return FixtureModifyBootImageConfig(name, func(config *bootImageConfig) {
Jiakai Zhang09d88df2023-05-10 17:04:53 +0100771 config.installDir = installDir
Jiakai Zhang6decef92022-01-12 17:56:19 +0000772 })
773}