2022-02-08 23:15:12 +01:00
|
|
|
// Copyright 2022 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 cc
|
|
|
|
|
|
|
|
import (
|
2022-10-07 23:44:50 +02:00
|
|
|
"android/soong/bazel/cquery"
|
2022-02-08 23:15:12 +01:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"android/soong/android"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCcBinaryWithBazel(t *testing.T) {
|
|
|
|
bp := `
|
|
|
|
cc_binary {
|
|
|
|
name: "foo",
|
|
|
|
srcs: ["foo.cc"],
|
|
|
|
bazel_module: { label: "//foo/bar:bar" },
|
|
|
|
}`
|
|
|
|
config := TestConfig(t.TempDir(), android.Android, nil, bp, nil)
|
|
|
|
config.BazelContext = android.MockBazelContext{
|
|
|
|
OutputBaseDir: "outputbase",
|
2022-10-07 23:44:50 +02:00
|
|
|
LabelToCcBinary: map[string]cquery.CcUnstrippedInfo{
|
|
|
|
"//foo/bar:bar": cquery.CcUnstrippedInfo{
|
|
|
|
OutputFile: "foo",
|
|
|
|
UnstrippedOutput: "foo.unstripped",
|
|
|
|
},
|
2022-02-08 23:15:12 +01:00
|
|
|
},
|
|
|
|
}
|
|
|
|
ctx := testCcWithConfig(t, config)
|
|
|
|
|
|
|
|
binMod := ctx.ModuleForTests("foo", "android_arm64_armv8-a").Module()
|
|
|
|
producer := binMod.(android.OutputFileProducer)
|
|
|
|
outputFiles, err := producer.OutputFiles("")
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Unexpected error getting cc_binary outputfiles %s", err)
|
|
|
|
}
|
|
|
|
expectedOutputFiles := []string{"outputbase/execroot/__main__/foo"}
|
|
|
|
android.AssertDeepEquals(t, "output files", expectedOutputFiles, outputFiles.Strings())
|
|
|
|
|
|
|
|
unStrippedFilePath := binMod.(*Module).UnstrippedOutputFile()
|
2022-10-07 23:44:50 +02:00
|
|
|
expectedUnStrippedFile := "outputbase/execroot/__main__/foo.unstripped"
|
2022-02-08 23:15:12 +01:00
|
|
|
android.AssertStringEquals(t, "Unstripped output file", expectedUnStrippedFile, unStrippedFilePath.String())
|
|
|
|
}
|
2022-04-22 16:17:54 +02:00
|
|
|
|
|
|
|
func TestBinaryLinkerScripts(t *testing.T) {
|
|
|
|
result := PrepareForIntegrationTestWithCc.RunTestWithBp(t, `
|
|
|
|
cc_binary {
|
|
|
|
name: "foo",
|
|
|
|
srcs: ["foo.cc"],
|
|
|
|
linker_scripts: ["foo.ld", "bar.ld"],
|
|
|
|
}`)
|
|
|
|
|
|
|
|
binFoo := result.ModuleForTests("foo", "android_arm64_armv8-a").Rule("ld")
|
|
|
|
|
|
|
|
android.AssertStringListContains(t, "missing dependency on linker_scripts",
|
|
|
|
binFoo.Implicits.Strings(), "foo.ld")
|
|
|
|
android.AssertStringListContains(t, "missing dependency on linker_scripts",
|
|
|
|
binFoo.Implicits.Strings(), "bar.ld")
|
|
|
|
android.AssertStringDoesContain(t, "missing flag for linker_scripts",
|
2022-05-09 20:35:10 +02:00
|
|
|
binFoo.Args["ldFlags"], "-Wl,--script,foo.ld")
|
2022-04-22 16:17:54 +02:00
|
|
|
android.AssertStringDoesContain(t, "missing flag for linker_scripts",
|
2022-05-09 20:35:10 +02:00
|
|
|
binFoo.Args["ldFlags"], "-Wl,--script,bar.ld")
|
2022-04-22 16:17:54 +02:00
|
|
|
}
|