blob: 0e85022cefa50ccb02b8e554ac5febcf5d2895ee [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 Dou1b052b02023-10-06 07:28:48 +0000427 "unsupportedappusage",
Colin Crossb1974532019-02-15 10:37:39 -0800428 }
429
430 for _, extra := range extraModules {
431 bp += fmt.Sprintf(`
432 java_library {
433 name: "%s",
434 srcs: ["a.java"],
Paul Duffin52d398a2019-06-11 12:31:14 +0100435 sdk_version: "none",
Pete Gillin84c38072020-07-09 18:03:41 +0100436 system_modules: "stable-core-platform-api-stubs-system-modules",
Liz Kammer5ca3a622020-08-05 15:40:41 -0700437 compile_dex: true,
Colin Crossb1974532019-02-15 10:37:39 -0800438 }
439 `, extra)
440 }
441
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000442 type droidstubsStruct struct {
443 name string
444 apiSurface string
445 apiFile string
446 removedFile string
Jihoon Kangc0a24202023-04-04 22:04:43 +0000447 }
448
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000449 var publicDroidstubs = droidstubsStruct{
450 name: "api-stubs-docs-non-updatable",
451 apiSurface: "public",
452 apiFile: "api/current.txt",
453 removedFile: "api/removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000454 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000455 var systemDroidstubs = droidstubsStruct{
456 name: "system-api-stubs-docs-non-updatable",
457 apiSurface: "system",
458 apiFile: "api/system-current.txt",
459 removedFile: "api/system-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000460 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000461 var testDroidstubs = droidstubsStruct{
462 name: "test-api-stubs-docs-non-updatable",
463 apiSurface: "test",
464 apiFile: "api/test-current.txt",
465 removedFile: "api/test-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000466 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000467 var moduleLibDroidstubs = droidstubsStruct{
468 name: "module-lib-api-stubs-docs-non-updatable",
469 apiSurface: "module-lib",
470 apiFile: "api/module-lib-current.txt",
471 removedFile: "api/module-lib-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000472 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000473 var systemServerDroidstubs = droidstubsStruct{
Jihoon Kang6be0f002023-09-20 23:03:01 +0000474 // This module does not exist but is named this way for consistency
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000475 name: "system-server-api-stubs-docs-non-updatable",
476 apiSurface: "system-server",
477 apiFile: "api/system-server-current.txt",
478 removedFile: "api/system-server-removed.txt",
Jihoon Kang6be0f002023-09-20 23:03:01 +0000479 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000480 var droidstubsStructs = []droidstubsStruct{
481 publicDroidstubs,
482 systemDroidstubs,
483 testDroidstubs,
484 moduleLibDroidstubs,
485 systemServerDroidstubs,
Jihoon Kang6be0f002023-09-20 23:03:01 +0000486 }
487
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000488 extraApiLibraryModules := map[string]droidstubsStruct{
Jihoon Kangb0f4c022024-08-06 00:15:25 +0000489 "android_stubs_current.from-text": publicDroidstubs,
490 "android_system_stubs_current.from-text": systemDroidstubs,
491 "android_test_stubs_current.from-text": testDroidstubs,
492 "android_module_lib_stubs_current.from-text": moduleLibDroidstubs,
493 "android_module_lib_stubs_current_full.from-text": moduleLibDroidstubs,
494 "android_system_server_stubs_current.from-text": systemServerDroidstubs,
495 "core.current.stubs.from-text": publicDroidstubs,
496 "legacy.core.platform.api.stubs.from-text": publicDroidstubs,
497 "stable.core.platform.api.stubs.from-text": publicDroidstubs,
498 "core-lambda-stubs.from-text": publicDroidstubs,
499 "android-non-updatable.stubs.test_module_lib": moduleLibDroidstubs,
Jihoon Kang6be0f002023-09-20 23:03:01 +0000500 }
501
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000502 for _, droidstubs := range droidstubsStructs {
Jihoon Kang6be0f002023-09-20 23:03:01 +0000503 bp += fmt.Sprintf(`
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000504 droidstubs {
Jihoon Kang6be0f002023-09-20 23:03:01 +0000505 name: "%s",
506 api_surface: "%s",
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000507 check_api: {
508 current: {
509 api_file: "%s",
510 removed_api_file: "%s",
511 }
512 }
Jihoon Kang6be0f002023-09-20 23:03:01 +0000513 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000514 `,
515 droidstubs.name,
516 droidstubs.apiSurface,
517 droidstubs.apiFile,
518 droidstubs.removedFile,
519 )
Jihoon Kang6be0f002023-09-20 23:03:01 +0000520 }
521
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000522 for libName, droidstubs := range extraApiLibraryModules {
Jihoon Kangc0a24202023-04-04 22:04:43 +0000523 bp += fmt.Sprintf(`
Jihoon Kang5d701272024-02-15 21:53:49 +0000524 java_api_library {
525 name: "%s",
526 api_contributions: ["%s"],
527 stubs_type: "everything",
Jihoon Kangb0f4c022024-08-06 00:15:25 +0000528 sdk_version: "none",
529 system_modules: "none",
Jihoon Kang5d701272024-02-15 21:53:49 +0000530 }
Jihoon Kang8f83dcd2023-10-09 17:53:04 +0000531 `, libName, droidstubs.name+".api.contribution")
Jihoon Kangc0a24202023-04-04 22:04:43 +0000532 }
533
Colin Crossb1974532019-02-15 10:37:39 -0800534 bp += `
Colin Cross3047fa22019-04-18 10:56:44 -0700535 java_library {
536 name: "framework",
537 srcs: ["a.java"],
Paul Duffina3d09862019-06-11 13:40:47 +0100538 sdk_version: "none",
Pete Gillin84c38072020-07-09 18:03:41 +0100539 system_modules: "stable-core-platform-api-stubs-system-modules",
Colin Cross3047fa22019-04-18 10:56:44 -0700540 aidl: {
541 export_include_dirs: ["framework/aidl"],
542 },
Paul Duffin8eb45732022-10-04 19:03:31 +0100543 compile_dex: true,
Colin Cross3047fa22019-04-18 10:56:44 -0700544 }
Jihoon Kang0f3b1a72024-08-12 22:47:01 +0000545 java_library {
546 name: "framework-minus-apex",
547 srcs: ["a.java"],
548 sdk_version: "none",
549 system_modules: "stable-core-platform-api-stubs-system-modules",
550 aidl: {
551 export_include_dirs: ["framework/aidl"],
552 },
553 compile_dex: true,
554 }
Colin Cross3047fa22019-04-18 10:56:44 -0700555
Colin Crossb1974532019-02-15 10:37:39 -0800556 android_app {
557 name: "framework-res",
Paul Duffin50c217c2019-06-12 13:25:22 +0100558 sdk_version: "core_platform",
Ulya Trafimovich24813e12020-10-07 15:05:21 +0100559 }`
Colin Crossb1974532019-02-15 10:37:39 -0800560
561 systemModules := []string{
Paul Duffin10fb76f2021-11-03 16:53:31 +0000562 "core-public-stubs-system-modules",
Victor Changb54f5aa2021-06-29 22:05:58 +0100563 "core-module-lib-stubs-system-modules",
Pete Gillin1f41dbf2020-06-02 15:59:45 +0100564 "legacy-core-platform-api-stubs-system-modules",
Pete Gillin40a06422020-07-01 10:59:00 +0100565 "stable-core-platform-api-stubs-system-modules",
Spandan Das6bd19dd2023-03-30 17:54:58 +0000566 "core-public-stubs-system-modules.from-text",
567 "core-module-lib-stubs-system-modules.from-text",
568 "legacy-core-platform-api-stubs-system-modules.from-text",
569 "stable-core-platform-api-stubs-system-modules.from-text",
Colin Crossb1974532019-02-15 10:37:39 -0800570 }
571
572 for _, extra := range systemModules {
573 bp += fmt.Sprintf(`
574 java_system_modules {
Paul Duffin68289b02019-09-20 13:50:52 +0100575 name: "%[1]s",
576 libs: ["%[1]s-lib"],
577 }
578 java_library {
579 name: "%[1]s-lib",
580 sdk_version: "none",
581 system_modules: "none",
Colin Crossb1974532019-02-15 10:37:39 -0800582 }
583 `, extra)
584 }
585
Paul Duffin1ab61862021-01-20 17:44:53 +0000586 // Make sure that the dex_bootjars singleton module is instantiated for the tests.
587 bp += `
588 dex_bootjars {
589 name: "dex_bootjars",
590 }
591`
592
Spandan Dasda739a32023-12-13 00:06:32 +0000593 bp += `
594 all_apex_contributions {
595 name: "all_apex_contributions",
596 }
597`
Colin Crossb1974532019-02-15 10:37:39 -0800598 return bp
599}
Paul Duffincee7e662020-07-09 17:32:57 +0100600
Jihoon Kangf00200b2023-10-09 18:00:17 +0000601func getModuleDependencies(t *testing.T, ctx *android.TestContext, name, variant string) []string {
Paul Duffincee7e662020-07-09 17:32:57 +0100602 t.Helper()
603 module := ctx.ModuleForTests(name, variant).Module()
604 deps := []string{}
605 ctx.VisitDirectDeps(module, func(m blueprint.Module) {
606 deps = append(deps, m.Name())
607 })
608 sort.Strings(deps)
609
Jihoon Kangf00200b2023-10-09 18:00:17 +0000610 return deps
611}
612
613// CheckModuleDependencies checks if the expected dependencies of the module are
614// identical to the actual dependencies.
615func CheckModuleDependencies(t *testing.T, ctx *android.TestContext, name, variant string, expected []string) {
616 deps := getModuleDependencies(t, ctx, name, variant)
617
Paul Duffincee7e662020-07-09 17:32:57 +0100618 if actual := deps; !reflect.DeepEqual(expected, actual) {
619 t.Errorf("expected %#q, found %#q", expected, actual)
620 }
621}
Paul Duffin4fd997b2021-02-03 20:06:33 +0000622
Jihoon Kangf00200b2023-10-09 18:00:17 +0000623// CheckModuleHasDependency returns true if the module depends on the expected dependency.
624func CheckModuleHasDependency(t *testing.T, ctx *android.TestContext, name, variant string, expected string) bool {
625 for _, dep := range getModuleDependencies(t, ctx, name, variant) {
626 if dep == expected {
627 return true
628 }
629 }
630 return false
631}
632
Paul Duffinb432df92021-03-22 22:09:42 +0000633// CheckPlatformBootclasspathModules returns the apex:module pair for the modules depended upon by
634// the platform-bootclasspath module.
635func CheckPlatformBootclasspathModules(t *testing.T, result *android.TestResult, name string, expected []string) {
636 t.Helper()
637 platformBootclasspath := result.Module(name, "android_common").(*platformBootclasspathModule)
638 pairs := ApexNamePairsFromModules(result.TestContext, platformBootclasspath.configuredModules)
639 android.AssertDeepEquals(t, fmt.Sprintf("%s modules", "platform-bootclasspath"), expected, pairs)
640}
641
satayevb3090502021-06-15 17:49:10 +0100642func CheckClasspathFragmentProtoContentInfoProvider(t *testing.T, result *android.TestResult, generated bool, contents, outputFilename, installDir string) {
643 t.Helper()
644 p := result.Module("platform-bootclasspath", "android_common").(*platformBootclasspathModule)
Yu Liu663e4502024-08-12 18:23:59 +0000645 info, _ := android.OtherModuleProvider(result, p, ClasspathFragmentProtoContentInfoProvider)
satayevb3090502021-06-15 17:49:10 +0100646
647 android.AssertBoolEquals(t, "classpath proto generated", generated, info.ClasspathFragmentProtoGenerated)
648 android.AssertStringEquals(t, "classpath proto contents", contents, info.ClasspathFragmentProtoContents.String())
649 android.AssertStringEquals(t, "output filepath", outputFilename, info.ClasspathFragmentProtoOutput.Base())
650 android.AssertPathRelativeToTopEquals(t, "install filepath", installDir, info.ClasspathFragmentProtoInstallDir)
651}
652
Paul Duffinb432df92021-03-22 22:09:42 +0000653// ApexNamePairsFromModules returns the apex:module pair for the supplied modules.
654func ApexNamePairsFromModules(ctx *android.TestContext, modules []android.Module) []string {
655 pairs := []string{}
656 for _, module := range modules {
657 pairs = append(pairs, apexNamePairFromModule(ctx, module))
658 }
659 return pairs
660}
661
662func apexNamePairFromModule(ctx *android.TestContext, module android.Module) string {
663 name := module.Name()
664 var apex string
Yu Liu663e4502024-08-12 18:23:59 +0000665 apexInfo, _ := android.OtherModuleProvider(ctx, module, android.ApexInfoProvider)
Paul Duffinb432df92021-03-22 22:09:42 +0000666 if apexInfo.IsForPlatform() {
667 apex = "platform"
668 } else {
Jiyong Parkab50b072021-05-12 17:13:56 +0900669 apex = apexInfo.InApexVariants[0]
Paul Duffinb432df92021-03-22 22:09:42 +0000670 }
671
672 return fmt.Sprintf("%s:%s", apex, name)
673}
674
Paul Duffin62d8c3b2021-04-07 20:35:11 +0100675// CheckPlatformBootclasspathFragments returns the apex:module pair for the fragments depended upon
676// by the platform-bootclasspath module.
677func CheckPlatformBootclasspathFragments(t *testing.T, result *android.TestResult, name string, expected []string) {
678 t.Helper()
679 platformBootclasspath := result.Module(name, "android_common").(*platformBootclasspathModule)
680 pairs := ApexNamePairsFromModules(result.TestContext, platformBootclasspath.fragments)
681 android.AssertDeepEquals(t, fmt.Sprintf("%s fragments", "platform-bootclasspath"), expected, pairs)
682}
683
Paul Duffin51d7da22021-06-16 02:04:13 +0100684func CheckHiddenAPIRuleInputs(t *testing.T, message string, expected string, hiddenAPIRule android.TestingBuildParams) {
Paul Duffin37856732021-02-26 14:24:15 +0000685 t.Helper()
Paul Duffin51d7da22021-06-16 02:04:13 +0100686 inputs := android.Paths{}
687 if hiddenAPIRule.Input != nil {
688 inputs = append(inputs, hiddenAPIRule.Input)
689 }
690 inputs = append(inputs, hiddenAPIRule.Inputs...)
691 inputs = append(inputs, hiddenAPIRule.Implicits...)
692 inputs = android.SortedUniquePaths(inputs)
693 actual := strings.TrimSpace(strings.Join(inputs.RelativeToTop().Strings(), "\n"))
694 re := regexp.MustCompile(`\n\s+`)
695 expected = strings.TrimSpace(re.ReplaceAllString(expected, "\n"))
Paul Duffin4fd997b2021-02-03 20:06:33 +0000696 if actual != expected {
Paul Duffin51d7da22021-06-16 02:04:13 +0100697 t.Errorf("Expected hiddenapi rule inputs - %s:\n%s\nactual inputs:\n%s", message, expected, actual)
Paul Duffin4fd997b2021-02-03 20:06:33 +0000698 }
699}
Paul Duffin001b2342021-03-11 18:43:31 +0000700
701// Check that the merged file create by platform_compat_config_singleton has the correct inputs.
702func CheckMergedCompatConfigInputs(t *testing.T, result *android.TestResult, message string, expectedPaths ...string) {
703 sourceGlobalCompatConfig := result.SingletonForTests("platform_compat_config_singleton")
704 allOutputs := sourceGlobalCompatConfig.AllOutputs()
705 android.AssertIntEquals(t, message+": output len", 1, len(allOutputs))
706 output := sourceGlobalCompatConfig.Output(allOutputs[0])
707 android.AssertPathsRelativeToTopEquals(t, message+": inputs", expectedPaths, output.Implicits)
708}
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000709
710// Register the fake APEX mutator to `android.InitRegistrationContext` as if the real mutator exists
711// at runtime. This must be called in `init()` of a test if the test is going to use the fake APEX
712// mutator. Otherwise, we will be missing the runtime mutator because "soong-apex" is not a
713// dependency, which will cause an inconsistency between testing and runtime mutators.
714func RegisterFakeRuntimeApexMutator() {
715 registerFakeApexMutator(android.InitRegistrationContext)
716}
717
718var PrepareForTestWithFakeApexMutator = android.GroupFixturePreparers(
719 android.FixtureRegisterWithContext(registerFakeApexMutator),
720)
721
722func registerFakeApexMutator(ctx android.RegistrationContext) {
723 ctx.PostDepsMutators(func(ctx android.RegisterMutatorsContext) {
Colin Cross7c035062024-03-28 12:18:42 -0700724 ctx.Transition("apex", &fakeApexMutator{})
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000725 })
726}
727
728type apexModuleBase interface {
729 ApexAvailable() []string
730}
731
732var _ apexModuleBase = (*Library)(nil)
733var _ apexModuleBase = (*SdkLibrary)(nil)
734
735// A fake APEX mutator that creates a platform variant and an APEX variant for modules with
736// `apex_available`. It helps us avoid a dependency on the real mutator defined in "soong-apex",
737// which will cause a cyclic dependency, and it provides an easy way to create an APEX variant for
738// testing without dealing with all the complexities in the real mutator.
Colin Cross7c035062024-03-28 12:18:42 -0700739type fakeApexMutator struct{}
740
741func (f *fakeApexMutator) Split(ctx android.BaseModuleContext) []string {
742 switch ctx.Module().(type) {
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000743 case *Library, *SdkLibrary:
Colin Cross7c035062024-03-28 12:18:42 -0700744 return []string{"", "apex1000"}
745 }
746 return []string{""}
747}
748
749func (f *fakeApexMutator) OutgoingTransition(ctx android.OutgoingTransitionContext, sourceVariation string) string {
750 return sourceVariation
751}
752
753func (f *fakeApexMutator) IncomingTransition(ctx android.IncomingTransitionContext, incomingVariation string) string {
754 return incomingVariation
755}
756
757func (f *fakeApexMutator) Mutate(ctx android.BottomUpMutatorContext, variation string) {
758 if variation != "" {
759 apexInfo := android.ApexInfo{
760 ApexVariationName: "apex1000",
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000761 }
Colin Cross7c035062024-03-28 12:18:42 -0700762 android.SetProvider(ctx, android.ApexInfoProvider, apexInfo)
Jiakai Zhang519c5c82021-09-16 06:15:39 +0000763 }
764}
Jiakai Zhang6decef92022-01-12 17:56:19 +0000765
766// Applies the given modifier on the boot image config with the given name.
767func FixtureModifyBootImageConfig(name string, configModifier func(*bootImageConfig)) android.FixturePreparer {
768 return android.FixtureModifyConfig(func(androidConfig android.Config) {
769 pathCtx := android.PathContextForTesting(androidConfig)
770 config := genBootImageConfigRaw(pathCtx)
771 configModifier(config[name])
772 })
773}
774
Jiakai Zhang09d88df2023-05-10 17:04:53 +0100775// Sets the value of `installDir` of the boot image config with the given name.
Jiakai Zhang6decef92022-01-12 17:56:19 +0000776func FixtureSetBootImageInstallDirOnDevice(name string, installDir string) android.FixturePreparer {
777 return FixtureModifyBootImageConfig(name, func(config *bootImageConfig) {
Jiakai Zhang09d88df2023-05-10 17:04:53 +0100778 config.installDir = installDir
Jiakai Zhang6decef92022-01-12 17:56:19 +0000779 })
780}