Merge "Add a test for boot.zip (zip archive with boot image files)." am: 7bdb5e5aaa
am: acdab217ac
Change-Id: I0e3d9bd7c428a634a8912cca05d5ee1e2bbfef12
This commit is contained in:
commit
ab254eb634
|
@ -24,7 +24,7 @@ import (
|
||||||
"android/soong/dexpreopt"
|
"android/soong/dexpreopt"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDexpreoptBootJars(t *testing.T) {
|
func testDexpreoptBoot(t *testing.T, ruleFile string, expectedInputs, expectedOutputs []string) {
|
||||||
bp := `
|
bp := `
|
||||||
java_sdk_library {
|
java_sdk_library {
|
||||||
name: "foo",
|
name: "foo",
|
||||||
|
@ -52,14 +52,39 @@ func TestDexpreoptBootJars(t *testing.T) {
|
||||||
dexpreopt.SetTestGlobalConfig(config, dexpreoptConfig)
|
dexpreopt.SetTestGlobalConfig(config, dexpreoptConfig)
|
||||||
|
|
||||||
ctx := testContext()
|
ctx := testContext()
|
||||||
|
|
||||||
RegisterDexpreoptBootJarsComponents(ctx)
|
RegisterDexpreoptBootJarsComponents(ctx)
|
||||||
|
|
||||||
run(t, ctx, config)
|
run(t, ctx, config)
|
||||||
|
|
||||||
dexpreoptBootJars := ctx.SingletonForTests("dex_bootjars")
|
dexpreoptBootJars := ctx.SingletonForTests("dex_bootjars")
|
||||||
|
rule := dexpreoptBootJars.Output(ruleFile)
|
||||||
|
|
||||||
bootArt := dexpreoptBootJars.Output("boot-foo.art")
|
for i := range expectedInputs {
|
||||||
|
expectedInputs[i] = filepath.Join(buildDir, "test_device", expectedInputs[i])
|
||||||
|
}
|
||||||
|
|
||||||
|
for i := range expectedOutputs {
|
||||||
|
expectedOutputs[i] = filepath.Join(buildDir, "test_device", expectedOutputs[i])
|
||||||
|
}
|
||||||
|
|
||||||
|
inputs := rule.Implicits.Strings()
|
||||||
|
sort.Strings(inputs)
|
||||||
|
sort.Strings(expectedInputs)
|
||||||
|
|
||||||
|
outputs := append(android.WritablePaths{rule.Output}, rule.ImplicitOutputs...).Strings()
|
||||||
|
sort.Strings(outputs)
|
||||||
|
sort.Strings(expectedOutputs)
|
||||||
|
|
||||||
|
if !reflect.DeepEqual(inputs, expectedInputs) {
|
||||||
|
t.Errorf("want inputs %q\n got inputs %q", expectedInputs, inputs)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !reflect.DeepEqual(outputs, expectedOutputs) {
|
||||||
|
t.Errorf("want outputs %q\n got outputs %q", expectedOutputs, outputs)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDexpreoptBootJars(t *testing.T) {
|
||||||
|
ruleFile := "boot-foo.art"
|
||||||
|
|
||||||
expectedInputs := []string{
|
expectedInputs := []string{
|
||||||
"dex_artjars/android/apex/com.android.art/javalib/arm64/boot.art",
|
"dex_artjars/android/apex/com.android.art/javalib/arm64/boot.art",
|
||||||
|
@ -68,47 +93,71 @@ func TestDexpreoptBootJars(t *testing.T) {
|
||||||
"dex_bootjars_input/baz.jar",
|
"dex_bootjars_input/baz.jar",
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := range expectedInputs {
|
|
||||||
expectedInputs[i] = filepath.Join(buildDir, "test_device", expectedInputs[i])
|
|
||||||
}
|
|
||||||
|
|
||||||
inputs := bootArt.Implicits.Strings()
|
|
||||||
sort.Strings(inputs)
|
|
||||||
sort.Strings(expectedInputs)
|
|
||||||
|
|
||||||
if !reflect.DeepEqual(inputs, expectedInputs) {
|
|
||||||
t.Errorf("want inputs %q\n got inputs %q", expectedInputs, inputs)
|
|
||||||
}
|
|
||||||
|
|
||||||
expectedOutputs := []string{
|
expectedOutputs := []string{
|
||||||
"dex_bootjars/android/system/framework/arm64/boot.invocation",
|
"dex_bootjars/android/system/framework/arm64/boot.invocation",
|
||||||
|
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-foo.art",
|
"dex_bootjars/android/system/framework/arm64/boot-foo.art",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-bar.art",
|
"dex_bootjars/android/system/framework/arm64/boot-bar.art",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-baz.art",
|
"dex_bootjars/android/system/framework/arm64/boot-baz.art",
|
||||||
|
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-foo.oat",
|
"dex_bootjars/android/system/framework/arm64/boot-foo.oat",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-bar.oat",
|
"dex_bootjars/android/system/framework/arm64/boot-bar.oat",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-baz.oat",
|
"dex_bootjars/android/system/framework/arm64/boot-baz.oat",
|
||||||
|
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-foo.vdex",
|
"dex_bootjars/android/system/framework/arm64/boot-foo.vdex",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-bar.vdex",
|
"dex_bootjars/android/system/framework/arm64/boot-bar.vdex",
|
||||||
"dex_bootjars/android/system/framework/arm64/boot-baz.vdex",
|
"dex_bootjars/android/system/framework/arm64/boot-baz.vdex",
|
||||||
|
|
||||||
"dex_bootjars_unstripped/android/system/framework/arm64/boot-foo.oat",
|
"dex_bootjars_unstripped/android/system/framework/arm64/boot-foo.oat",
|
||||||
"dex_bootjars_unstripped/android/system/framework/arm64/boot-bar.oat",
|
"dex_bootjars_unstripped/android/system/framework/arm64/boot-bar.oat",
|
||||||
"dex_bootjars_unstripped/android/system/framework/arm64/boot-baz.oat",
|
"dex_bootjars_unstripped/android/system/framework/arm64/boot-baz.oat",
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := range expectedOutputs {
|
testDexpreoptBoot(t, ruleFile, expectedInputs, expectedOutputs)
|
||||||
expectedOutputs[i] = filepath.Join(buildDir, "test_device", expectedOutputs[i])
|
}
|
||||||
}
|
|
||||||
|
// Changes to the boot.zip structure may break the ART APK scanner.
|
||||||
outputs := append(android.WritablePaths{bootArt.Output}, bootArt.ImplicitOutputs...).Strings()
|
func TestDexpreoptBootZip(t *testing.T) {
|
||||||
sort.Strings(outputs)
|
ruleFile := "boot.zip"
|
||||||
sort.Strings(expectedOutputs)
|
|
||||||
|
expectedInputs := []string{
|
||||||
if !reflect.DeepEqual(outputs, expectedOutputs) {
|
"dex_bootjars/android/system/framework/arm/boot-foo.art",
|
||||||
t.Errorf("want outputs %q\n got outputs %q", expectedOutputs, outputs)
|
"dex_bootjars/android/system/framework/arm/boot-bar.art",
|
||||||
}
|
"dex_bootjars/android/system/framework/arm/boot-baz.art",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-foo.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-bar.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-baz.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-foo.vdex",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-bar.vdex",
|
||||||
|
"dex_bootjars/android/system/framework/arm/boot-baz.vdex",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-foo.art",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-bar.art",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-baz.art",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-foo.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-bar.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-baz.oat",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-foo.vdex",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-bar.vdex",
|
||||||
|
"dex_bootjars/android/system/framework/arm64/boot-baz.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-foo.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-bar.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-baz.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-foo.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-bar.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-baz.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-foo.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-bar.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86/boot-baz.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-foo.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-bar.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-baz.art",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-foo.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-bar.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-baz.oat",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-foo.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-bar.vdex",
|
||||||
|
"dex_bootjars/linux_glibc/system/framework/x86_64/boot-baz.vdex",
|
||||||
|
}
|
||||||
|
|
||||||
|
expectedOutputs := []string{
|
||||||
|
"dex_bootjars/boot.zip",
|
||||||
|
}
|
||||||
|
|
||||||
|
testDexpreoptBoot(t, ruleFile, expectedInputs, expectedOutputs)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue