Fix target gtest depenencies
The main ingredient was moving the include of Android.gest.mk earlier.
But then to keep host gtests dependencies working, their dependencies
were made to mirror how the target works, to hopefully avoid similar
issues in the future.
Change-Id: If7223b8a6f3a2fef449616494b14558e1752226d
diff --git a/Android.mk b/Android.mk
index a4e2797..fa13d8b 100644
--- a/Android.mk
+++ b/Android.mk
@@ -49,15 +49,15 @@
# test targets
include $(build_path)/Android.oattest.mk
+include $(build_path)/Android.gtest.mk
# The ART_*_TEST_DEPENDENCIES definitions:
# - depend on Android.oattest.mk above for ART_TEST_*_DEX_FILES
-# - are needed by Android.gtest.mk below
+# - depend on Android.gtest.mk above for ART_*_TEST_EXECUTABLES
ART_HOST_TEST_DEPENDENCIES := $(ART_HOST_DEPENDENCIES) $(ART_HOST_TEST_EXECUTABLES) $(ART_TEST_HOST_DEX_FILES) $(HOST_CORE_IMG_OUT)
ART_TARGET_TEST_DEPENDENCIES := $(ART_TARGET_DEPENDENCIES) $(ART_TARGET_TEST_EXECUTABLES) $(ART_TEST_TARGET_DEX_FILES) $(TARGET_CORE_IMG_OUT)
include $(build_path)/Android.libarttest.mk
-include $(build_path)/Android.gtest.mk
# "m build-art" for quick minimal build
.PHONY: build-art
@@ -88,6 +88,9 @@
test-art-host: test-art-host-gtest # test-art-host-oat # test-art-host-run-test
@echo test-art-host PASSED
+.PHONY: test-art-host-dependencies
+test-art-host-dependencies: $(ART_HOST_TEST_DEPENDENCIES) $(HOST_OUT_SHARED_LIBRARIES)/libarttest.so
+
.PHONY: test-art-host-gtest
test-art-host-gtest: $(ART_HOST_TEST_TARGETS)
@echo test-art-host-gtest PASSED
@@ -98,13 +101,13 @@
# "mm valgrind-test-art-host-gtest" to build and run the host gtests under valgrind.
.PHONY: valgrind-test-art-host-gtest
-valgrind-test-art-host-gtest: $(ART_HOST_TEST_DEPENDENCIES)
+valgrind-test-art-host-gtest: test-art-host-dependencies
$(call run-host-gtests-with,valgrind --leak-check=full)
@echo valgrind-test-art-host-gtest PASSED
# "mm tsan-test-art-host-gtest" to build and run the host gtests under tsan.
.PHONY: tsan-test-art-host-gtest
-tsan-test-art-host-gtest: $(ART_HOST_TEST_DEPENDENCIES)
+tsan-test-art-host-gtest: test-art-host-dependencies
$(call run-host-gtests-with,"tsan")
@echo tsan-test-art-host-gtest PASSED
@@ -114,7 +117,7 @@
define declare-test-art-host-run-test
.PHONY: test-art-host-run-test-$(1)
-test-art-host-run-test-$(1): $(ART_HOST_TEST_DEPENDENCIES) $(HOST_OUT_SHARED_LIBRARIES)/libarttest.so
+test-art-host-run-test-$(1): test-art-host-dependencies
art/test/run-test --host $(1)
@echo test-art-host-run-test-$(1) PASSED
@@ -135,8 +138,11 @@
test-art-target: test-art-target-gtest test-art-target-oat test-art-target-run-test
@echo test-art-target PASSED
+.PHONY: test-art-target-dependencies
+test-art-target-dependencies: $(ART_TARGET_TEST_DEPENDENCIES) $(ART_TEST_OUT)/libarttest.so
+
.PHONY: test-art-target-sync
-test-art-target-sync: $(ART_TARGET_TEST_DEPENDENCIES) $(ART_TEST_OUT)/libarttest.so
+test-art-target-sync: test-art-target-dependencies
adb remount
adb sync
adb shell mkdir -p $(ART_TEST_DIR)
diff --git a/build/Android.gtest.mk b/build/Android.gtest.mk
index b2313aa..3405e7e 100644
--- a/build/Android.gtest.mk
+++ b/build/Android.gtest.mk
@@ -102,7 +102,7 @@
ART_TARGET_TEST_TARGETS += $$(art_gtest_target)
else
.PHONY: $$(art_gtest_target)
-$$(art_gtest_target): $$(art_gtest_exe) $(ART_HOST_TEST_DEPENDENCIES)
+$$(art_gtest_target): $$(art_gtest_exe) test-art-host-dependencies
$$<
@echo $$@ PASSED
diff --git a/build/Android.oattest.mk b/build/Android.oattest.mk
index ea5502a..6897cd5 100644
--- a/build/Android.oattest.mk
+++ b/build/Android.oattest.mk
@@ -65,7 +65,7 @@
$(hide) rm /tmp/test-art-target-oat-$(1)
.PHONY: test-art-host-oat-$(1)
-test-art-host-oat-$(1): $(ART_TEST_OUT)/oat-test-dex-$(1).jar $(HOST_CORE_IMG_OUT)
+test-art-host-oat-$(1): $(ART_TEST_OUT)/oat-test-dex-$(1).jar test-art-host-dependencies
mkdir -p /tmp/android-data/test-art-host-oat-$(1)
$(DEX2OAT) --runtime-arg -Xms16m --runtime-arg -Xmx16m --boot-image=$(HOST_CORE_IMG_OUT) --dex-file=$(HOST_OUT_JAVA_LIBRARIES)/oat-test-dex-$(1).jar --oat-file=$(HOST_OUT_JAVA_LIBRARIES)/oat-test-dex-$(1).jar.oat --instruction-set=X86 --host-prefix=""
ANDROID_DATA=/tmp/android-data/test-art-host-oat-$(1) \