2019-10-25 05:47:54 +02:00
|
|
|
// Copyright 2019 The Android Open Source Project
|
|
|
|
//
|
|
|
|
// 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 rust
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
2020-09-08 18:46:52 +02:00
|
|
|
|
|
|
|
"android/soong/android"
|
2019-10-25 05:47:54 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestRustTest(t *testing.T) {
|
|
|
|
ctx := testRust(t, `
|
|
|
|
rust_test_host {
|
|
|
|
name: "my_test",
|
2019-11-01 04:56:47 +01:00
|
|
|
srcs: ["foo.rs"],
|
2021-01-29 18:48:05 +01:00
|
|
|
data: ["data.txt"],
|
2019-11-01 04:56:47 +01:00
|
|
|
}`)
|
|
|
|
|
2020-06-11 19:25:36 +02:00
|
|
|
testingModule := ctx.ModuleForTests("my_test", "linux_glibc_x86_64")
|
|
|
|
expectedOut := "my_test/linux_glibc_x86_64/my_test"
|
|
|
|
outPath := testingModule.Output("my_test").Output.String()
|
|
|
|
if !strings.Contains(outPath, expectedOut) {
|
|
|
|
t.Errorf("wrong output path: %v; expected: %v", outPath, expectedOut)
|
2019-11-01 04:56:47 +01:00
|
|
|
}
|
2021-01-29 18:48:05 +01:00
|
|
|
|
|
|
|
dataPaths := testingModule.Module().(*Module).compiler.(*testDecorator).dataPaths()
|
|
|
|
if len(dataPaths) != 1 {
|
|
|
|
t.Errorf("expected exactly one test data file. test data files: [%s]", dataPaths)
|
|
|
|
return
|
|
|
|
}
|
2019-11-01 04:56:47 +01:00
|
|
|
}
|
2020-09-08 18:46:52 +02:00
|
|
|
|
|
|
|
func TestRustTestLinkage(t *testing.T) {
|
|
|
|
ctx := testRust(t, `
|
|
|
|
rust_test {
|
|
|
|
name: "my_test",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
rustlibs: ["libfoo"],
|
|
|
|
rlibs: ["libbar"],
|
|
|
|
}
|
|
|
|
rust_library {
|
|
|
|
name: "libfoo",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
crate_name: "foo",
|
|
|
|
}
|
|
|
|
rust_library {
|
|
|
|
name: "libbar",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
crate_name: "bar",
|
|
|
|
}`)
|
|
|
|
|
|
|
|
testingModule := ctx.ModuleForTests("my_test", "android_arm64_armv8-a").Module().(*Module)
|
|
|
|
|
|
|
|
if !android.InList("libfoo.rlib-std", testingModule.Properties.AndroidMkRlibs) {
|
|
|
|
t.Errorf("rlib-std variant for libfoo not detected as a rustlib-defined rlib dependency for device rust_test module")
|
|
|
|
}
|
|
|
|
if !android.InList("libbar.rlib-std", testingModule.Properties.AndroidMkRlibs) {
|
|
|
|
t.Errorf("rlib-std variant for libbar not detected as an rlib dependency for device rust_test module")
|
|
|
|
}
|
|
|
|
if !android.InList("libstd", testingModule.Properties.AndroidMkRlibs) {
|
|
|
|
t.Errorf("Device rust_test module 'my_test' does not link libstd as an rlib")
|
|
|
|
}
|
|
|
|
}
|
2021-11-04 19:09:38 +01:00
|
|
|
|
|
|
|
func TestDataLibs(t *testing.T) {
|
|
|
|
bp := `
|
|
|
|
cc_library {
|
|
|
|
name: "test_lib",
|
|
|
|
srcs: ["test_lib.cpp"],
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_binary {
|
|
|
|
name: "rusty",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
compile_multilib: "both",
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_ffi {
|
|
|
|
name: "librust_test_lib",
|
|
|
|
crate_name: "rust_test_lib",
|
|
|
|
srcs: ["test_lib.rs"],
|
|
|
|
relative_install_path: "foo/bar/baz",
|
|
|
|
compile_multilib: "64",
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_test {
|
|
|
|
name: "main_test",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
data_libs: ["test_lib"],
|
|
|
|
data_bins: ["rusty"],
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
|
|
|
ctx := testRust(t, bp)
|
|
|
|
|
|
|
|
module := ctx.ModuleForTests("main_test", "android_arm64_armv8-a").Module()
|
|
|
|
testBinary := module.(*Module).compiler.(*testDecorator)
|
|
|
|
outputFiles, err := module.(android.OutputFileProducer).OutputFiles("")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Expected rust_test to produce output files, error: %s", err)
|
|
|
|
}
|
|
|
|
if len(outputFiles) != 1 {
|
|
|
|
t.Fatalf("expected exactly one output file. output files: [%s]", outputFiles)
|
|
|
|
}
|
|
|
|
if len(testBinary.dataPaths()) != 2 {
|
|
|
|
t.Fatalf("expected exactly two test data files. test data files: [%s]", testBinary.dataPaths())
|
|
|
|
}
|
|
|
|
|
|
|
|
outputPath := outputFiles[0].String()
|
|
|
|
dataLibraryPath := testBinary.dataPaths()[0].SrcPath.String()
|
|
|
|
dataBinaryPath := testBinary.dataPaths()[1].SrcPath.String()
|
|
|
|
|
|
|
|
if !strings.HasSuffix(outputPath, "/main_test") {
|
|
|
|
t.Errorf("expected test output file to be 'main_test', but was '%s'", outputPath)
|
|
|
|
}
|
|
|
|
if !strings.HasSuffix(dataLibraryPath, "/test_lib.so") {
|
|
|
|
t.Errorf("expected test data file to be 'test_lib.so', but was '%s'", dataLibraryPath)
|
|
|
|
}
|
|
|
|
if !strings.HasSuffix(dataBinaryPath, "/rusty") {
|
|
|
|
t.Errorf("expected test data file to be 'test_lib.so', but was '%s'", dataBinaryPath)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDataLibsRelativeInstallPath(t *testing.T) {
|
|
|
|
bp := `
|
|
|
|
cc_library {
|
|
|
|
name: "test_lib",
|
|
|
|
srcs: ["test_lib.cpp"],
|
|
|
|
relative_install_path: "foo/bar/baz",
|
|
|
|
compile_multilib: "64",
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_ffi {
|
|
|
|
name: "librust_test_lib",
|
|
|
|
crate_name: "rust_test_lib",
|
|
|
|
srcs: ["test_lib.rs"],
|
|
|
|
relative_install_path: "foo/bar/baz",
|
|
|
|
compile_multilib: "64",
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_binary {
|
|
|
|
name: "rusty",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
relative_install_path: "foo/bar/baz",
|
|
|
|
compile_multilib: "64",
|
|
|
|
}
|
|
|
|
|
|
|
|
rust_test {
|
|
|
|
name: "main_test",
|
|
|
|
srcs: ["foo.rs"],
|
|
|
|
data_libs: ["test_lib", "librust_test_lib"],
|
|
|
|
data_bins: ["rusty"],
|
|
|
|
compile_multilib: "64",
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
|
|
|
ctx := testRust(t, bp)
|
|
|
|
module := ctx.ModuleForTests("main_test", "android_arm64_armv8-a").Module()
|
|
|
|
testBinary := module.(*Module).compiler.(*testDecorator)
|
|
|
|
outputFiles, err := module.(android.OutputFileProducer).OutputFiles("")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Expected rust_test to produce output files, error: %s", err)
|
|
|
|
}
|
|
|
|
if len(outputFiles) != 1 {
|
|
|
|
t.Fatalf("expected exactly one output file. output files: [%s]", outputFiles)
|
|
|
|
}
|
|
|
|
if len(testBinary.dataPaths()) != 3 {
|
|
|
|
t.Fatalf("expected exactly two test data files. test data files: [%s]", testBinary.dataPaths())
|
|
|
|
}
|
|
|
|
|
|
|
|
outputPath := outputFiles[0].String()
|
|
|
|
|
|
|
|
if !strings.HasSuffix(outputPath, "/main_test") {
|
|
|
|
t.Errorf("expected test output file to be 'main_test', but was '%s'", outputPath)
|
|
|
|
}
|
|
|
|
entries := android.AndroidMkEntriesForTest(t, ctx, module)[0]
|
|
|
|
if !strings.HasSuffix(entries.EntryMap["LOCAL_TEST_DATA"][0], ":test_lib.so:foo/bar/baz") {
|
|
|
|
t.Errorf("expected LOCAL_TEST_DATA to end with `:test_lib.so:foo/bar/baz`,"+
|
|
|
|
" but was '%s'", entries.EntryMap["LOCAL_TEST_DATA"][0])
|
|
|
|
}
|
|
|
|
if !strings.HasSuffix(entries.EntryMap["LOCAL_TEST_DATA"][1], ":librust_test_lib.so:foo/bar/baz") {
|
|
|
|
t.Errorf("expected LOCAL_TEST_DATA to end with `:librust_test_lib.so:foo/bar/baz`,"+
|
|
|
|
" but was '%s'", entries.EntryMap["LOCAL_TEST_DATA"][1])
|
|
|
|
}
|
|
|
|
if !strings.HasSuffix(entries.EntryMap["LOCAL_TEST_DATA"][2], ":rusty:foo/bar/baz") {
|
|
|
|
t.Errorf("expected LOCAL_TEST_DATA to end with `:rusty:foo/bar/baz`,"+
|
|
|
|
" but was '%s'", entries.EntryMap["LOCAL_TEST_DATA"][2])
|
|
|
|
}
|
|
|
|
}
|