a4e0a0f7f6
bug: NA test: manually ran build/soong/run_integration_tests.sh and verified all tests ran Change-Id: I1a0a2e227888efc2e7fd7f718b8e534e6dbdbcf1
66 lines
No EOL
1.5 KiB
Bash
Executable file
66 lines
No EOL
1.5 KiB
Bash
Executable file
#!/bin/bash -eu
|
|
|
|
set -o pipefail
|
|
|
|
# This test exercises mixed builds where Soong and Bazel cooperate in building
|
|
# Android.
|
|
#
|
|
# When the execroot is deleted, the Bazel server process will automatically
|
|
# terminate itself.
|
|
|
|
source "$(dirname "$0")/lib.sh"
|
|
|
|
function test_bazel_smoke {
|
|
setup
|
|
|
|
run_soong bp2build
|
|
|
|
run_bazel info --config=bp2build
|
|
}
|
|
|
|
function test_add_irrelevant_file {
|
|
setup
|
|
|
|
mkdir -p soong_tests/a/b
|
|
touch soong_tests/a/b/c.txt
|
|
cat > soong_tests/a/b/Android.bp <<'EOF'
|
|
filegroup {
|
|
name: "c",
|
|
srcs: ["c.txt"],
|
|
bazel_module: { bp2build_available: true },
|
|
}
|
|
EOF
|
|
|
|
run_soong --bazel-mode-staging nothing
|
|
|
|
if [[ ! -e out/soong/bp2build/soong_tests/a/b/BUILD.bazel ]]; then
|
|
fail "BUILD.bazel not created"
|
|
fi
|
|
|
|
if [[ ! -e out/soong/build.ninja ]]; then
|
|
fail "build.ninja not created"
|
|
fi
|
|
|
|
local mtime_build1=$(stat -c "%y" out/soong/bp2build/soong_tests/a/b/BUILD.bazel)
|
|
local mtime_ninja1=$(stat -c "%y" out/soong/build.ninja)
|
|
|
|
touch soong_tests/a/irrelevant.txt
|
|
|
|
run_soong --bazel-mode-staging nothing
|
|
local mtime_build2=$(stat -c "%y" out/soong/bp2build/soong_tests/a/b/BUILD.bazel)
|
|
local mtime_ninja2=$(stat -c "%y" out/soong/build.ninja)
|
|
|
|
if [[ "$mtime_build1" != "$mtime_build2" ]]; then
|
|
fail "BUILD.bazel was generated"
|
|
fi
|
|
|
|
if [[ "$mtime_ninja1" != "$mtime_ninja2" ]]; then
|
|
fail "build.ninja was regenerated"
|
|
fi
|
|
|
|
if [[ ! -e out/soong/workspace/soong_tests/a/irrelevant.txt ]]; then
|
|
fail "new file was not symlinked"
|
|
fi
|
|
}
|
|
|
|
scan_and_run_tests |