diff options
author | 2024-01-04 09:37:36 +0000 | |
---|---|---|
committer | 2024-01-04 09:37:36 +0000 | |
commit | 77e105628f3bb2f8e2d53b5a27bf0e3f03c81206 (patch) | |
tree | 4f790440353cf73cf5dcf6ebbc6b1e909e5d34b9 /java/sdk_version_test.go | |
parent | b284c72d66b4435ed07e62cf564d7a31373e65d3 (diff) | |
parent | ec47e99b4dac54b9f7afe1d28530e0291425ed2b (diff) |
Merge "Limit System SDK to 34 for Java modules in the vendor partition" into main
Diffstat (limited to 'java/sdk_version_test.go')
-rw-r--r-- | java/sdk_version_test.go | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/java/sdk_version_test.go b/java/sdk_version_test.go new file mode 100644 index 000000000..88351d2ef --- /dev/null +++ b/java/sdk_version_test.go @@ -0,0 +1,66 @@ +// Copyright 2024 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 ( + "testing" + + "android/soong/android" +) + +func stringPtr(v string) *string { + return &v +} + +func TestSystemSdkFromVendor(t *testing.T) { + fixtures := android.GroupFixturePreparers( + PrepareForTestWithJavaDefaultModules, + android.FixtureModifyProductVariables(func(variables android.FixtureProductVariables) { + variables.Platform_sdk_version = intPtr(34) + variables.Platform_sdk_codename = stringPtr("VanillaIceCream") + variables.Platform_version_active_codenames = []string{"VanillaIceCream"} + variables.Platform_systemsdk_versions = []string{"33", "34", "VanillaIceCream"} + variables.DeviceSystemSdkVersions = []string{"VanillaIceCream"} + }), + FixtureWithPrebuiltApis(map[string][]string{ + "33": {}, + "34": {}, + "35": {}, + }), + ) + + fixtures.ExtendWithErrorHandler(android.FixtureExpectsAtLeastOneErrorMatchingPattern("incompatible sdk version")). + RunTestWithBp(t, ` + android_app { + name: "foo", + srcs: ["a.java"], + vendor: true, + sdk_version: "system_35", + }`) + + result := fixtures.RunTestWithBp(t, ` + android_app { + name: "foo", + srcs: ["a.java"], + vendor: true, + sdk_version: "system_current", + }`) + fooModule := result.ModuleForTests("foo", "android_common") + fooClasspath := fooModule.Rule("javac").Args["classpath"] + + android.AssertStringDoesContain(t, "foo classpath", fooClasspath, "prebuilts/sdk/34/system/android.jar") + android.AssertStringDoesNotContain(t, "foo classpath", fooClasspath, "prebuilts/sdk/35/system/android.jar") + android.AssertStringDoesNotContain(t, "foo classpath", fooClasspath, "prebuilts/sdk/current/system/android.jar") +} |