xref: /aosp_15_r20/art/build/Android.common_test.mk (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker#
2*795d594fSAndroid Build Coastguard Worker# Copyright (C) 2011 The Android Open Source Project
3*795d594fSAndroid Build Coastguard Worker#
4*795d594fSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
5*795d594fSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
6*795d594fSAndroid Build Coastguard Worker# You may obtain a copy of the License at
7*795d594fSAndroid Build Coastguard Worker#
8*795d594fSAndroid Build Coastguard Worker#      http://www.apache.org/licenses/LICENSE-2.0
9*795d594fSAndroid Build Coastguard Worker#
10*795d594fSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
11*795d594fSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
12*795d594fSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*795d594fSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
14*795d594fSAndroid Build Coastguard Worker# limitations under the License.
15*795d594fSAndroid Build Coastguard Worker#
16*795d594fSAndroid Build Coastguard Worker
17*795d594fSAndroid Build Coastguard Workerifndef ART_ANDROID_COMMON_TEST_MK
18*795d594fSAndroid Build Coastguard WorkerART_ANDROID_COMMON_TEST_MK = true
19*795d594fSAndroid Build Coastguard Worker
20*795d594fSAndroid Build Coastguard Workerinclude art/build/Android.common_path.mk
21*795d594fSAndroid Build Coastguard Worker
22*795d594fSAndroid Build Coastguard Worker# Directory used for temporary test files on the host.
23*795d594fSAndroid Build Coastguard Worker# TMPDIR is always provided by the build system as $OUT_DIR-unique temporary directory.
24*795d594fSAndroid Build Coastguard WorkerART_HOST_TEST_DIR := $(TMPDIR)/test-art
25*795d594fSAndroid Build Coastguard Worker
26*795d594fSAndroid Build Coastguard Worker# List of known broken tests that we won't attempt to execute. The test name must be the full
27*795d594fSAndroid Build Coastguard Worker# rule name such as test-art-host-oat-optimizing-HelloWorld64.
28*795d594fSAndroid Build Coastguard WorkerART_TEST_KNOWN_BROKEN :=
29*795d594fSAndroid Build Coastguard Worker
30*795d594fSAndroid Build Coastguard Worker# List of known failing tests that when executed won't cause test execution to not finish.
31*795d594fSAndroid Build Coastguard Worker# The test name must be the full rule name such as test-art-host-oat-optimizing-HelloWorld64.
32*795d594fSAndroid Build Coastguard WorkerART_TEST_KNOWN_FAILING :=
33*795d594fSAndroid Build Coastguard Worker
34*795d594fSAndroid Build Coastguard Worker# Keep going after encountering a test failure?
35*795d594fSAndroid Build Coastguard WorkerART_TEST_KEEP_GOING ?= true
36*795d594fSAndroid Build Coastguard Worker
37*795d594fSAndroid Build Coastguard Worker# Do you want run-test to be quieter? run-tests will only show output if they fail.
38*795d594fSAndroid Build Coastguard WorkerART_TEST_QUIET ?= true
39*795d594fSAndroid Build Coastguard Worker
40*795d594fSAndroid Build Coastguard Worker# Define the command run on test failure. $(1) is the name of the test. Executed by the shell.
41*795d594fSAndroid Build Coastguard Worker# If the test was a top-level make target (e.g. `test-art-host-gtest-codegen_test64`), the command
42*795d594fSAndroid Build Coastguard Worker# fails with exit status 1 (returned by the last `grep` statement below).
43*795d594fSAndroid Build Coastguard Worker# Otherwise (e.g., if the test was run as a prerequisite of a compound test command, such as
44*795d594fSAndroid Build Coastguard Worker# `test-art-host-gtest-codegen_test`), the command does not fail, as this would break rules running
45*795d594fSAndroid Build Coastguard Worker# ART_TEST_PREREQ_FINISHED as one of their actions, which expects *all* prerequisites *not* to fail.
46*795d594fSAndroid Build Coastguard Workerdefine ART_TEST_FAILED
47*795d594fSAndroid Build Coastguard Worker  ( [ -f $(ART_HOST_TEST_DIR)/skipped/$(1) ] || \
48*795d594fSAndroid Build Coastguard Worker    (mkdir -p $(ART_HOST_TEST_DIR)/failed/ && touch $(ART_HOST_TEST_DIR)/failed/$(1) && \
49*795d594fSAndroid Build Coastguard Worker      echo $(ART_TEST_KNOWN_FAILING) | grep -q $(1) \
50*795d594fSAndroid Build Coastguard Worker        && (echo -e "$(1) \e[91mKNOWN FAILURE\e[0m") \
51*795d594fSAndroid Build Coastguard Worker        || (echo -e "$(1) \e[91mFAILED\e[0m" >&2; echo $(MAKECMDGOALS) | grep -q -v $(1))))
52*795d594fSAndroid Build Coastguard Workerendef
53*795d594fSAndroid Build Coastguard Worker
54*795d594fSAndroid Build Coastguard Workerifeq ($(ART_TEST_QUIET),true)
55*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_PASS := ( true )
56*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_RUN := ( true )
57*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_SKIP_FAILURE := ( true )
58*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_SKIP_BROKEN := ( true )
59*795d594fSAndroid Build Coastguard Workerelse
60*795d594fSAndroid Build Coastguard Worker  # Note the use of '=' and not ':=' is intentional since these are actually functions.
61*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_PASS = ( echo -e "$(1) \e[92mPASSED\e[0m" )
62*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_RUN = ( echo -e "$(1) \e[95mRUNNING\e[0m")
63*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_SKIP_FAILURE = ( echo -e "$(1) \e[93mSKIPPING DUE TO EARLIER FAILURE\e[0m" )
64*795d594fSAndroid Build Coastguard Worker  ART_TEST_ANNOUNCE_SKIP_BROKEN = ( echo -e "$(1) \e[93mSKIPPING BROKEN TEST\e[0m" )
65*795d594fSAndroid Build Coastguard Workerendif
66*795d594fSAndroid Build Coastguard Worker
67*795d594fSAndroid Build Coastguard Worker# Define the command run on test success. $(1) is the name of the test. Executed by the shell.
68*795d594fSAndroid Build Coastguard Worker# The command checks prints "PASSED" then checks to see if this was a top-level make target (e.g.
69*795d594fSAndroid Build Coastguard Worker# "mm test-art-host-oat-HelloWorld32"), if it was then it does nothing, otherwise it creates a file
70*795d594fSAndroid Build Coastguard Worker# to be printed in the passing test summary.
71*795d594fSAndroid Build Coastguard Workerdefine ART_TEST_PASSED
72*795d594fSAndroid Build Coastguard Worker  ( $(call ART_TEST_ANNOUNCE_PASS,$(1)) && \
73*795d594fSAndroid Build Coastguard Worker    (echo $(MAKECMDGOALS) | grep -q $(1) || \
74*795d594fSAndroid Build Coastguard Worker      (mkdir -p $(ART_HOST_TEST_DIR)/passed/ && touch $(ART_HOST_TEST_DIR)/passed/$(1))))
75*795d594fSAndroid Build Coastguard Workerendef
76*795d594fSAndroid Build Coastguard Worker
77*795d594fSAndroid Build Coastguard Worker# Define the command run on test success of multiple prerequisites. $(1) is the name of the test.
78*795d594fSAndroid Build Coastguard Worker# When the test is a top-level make target then a summary of the ran tests is produced. Executed by
79*795d594fSAndroid Build Coastguard Worker# the shell.
80*795d594fSAndroid Build Coastguard Workerdefine ART_TEST_PREREQ_FINISHED
81*795d594fSAndroid Build Coastguard Worker  (echo -e "$(1) \e[32mCOMPLETE\e[0m" && \
82*795d594fSAndroid Build Coastguard Worker    (echo $(MAKECMDGOALS) | grep -q -v $(1) || \
83*795d594fSAndroid Build Coastguard Worker      (([ -d $(ART_HOST_TEST_DIR)/passed/ ] \
84*795d594fSAndroid Build Coastguard Worker        && (echo -e "\e[92mPASSING TESTS\e[0m" && ls -1 $(ART_HOST_TEST_DIR)/passed/) \
85*795d594fSAndroid Build Coastguard Worker        || (echo -e "\e[91mNO TESTS PASSED\e[0m")) && \
86*795d594fSAndroid Build Coastguard Worker      ([ -d $(ART_HOST_TEST_DIR)/skipped/ ] \
87*795d594fSAndroid Build Coastguard Worker        && (echo -e "\e[93mSKIPPED TESTS\e[0m" && ls -1 $(ART_HOST_TEST_DIR)/skipped/) \
88*795d594fSAndroid Build Coastguard Worker        || (echo -e "\e[92mNO TESTS SKIPPED\e[0m")) && \
89*795d594fSAndroid Build Coastguard Worker      ([ -d $(ART_HOST_TEST_DIR)/failed/ ] \
90*795d594fSAndroid Build Coastguard Worker        && (echo -e "\e[91mFAILING TESTS\e[0m" >&2 && ls -1 $(ART_HOST_TEST_DIR)/failed/ >&2) \
91*795d594fSAndroid Build Coastguard Worker        || (echo -e "\e[92mNO TESTS FAILED\e[0m")) \
92*795d594fSAndroid Build Coastguard Worker      && ([ ! -d $(ART_HOST_TEST_DIR)/failed/ ] && rm -r $(ART_HOST_TEST_DIR) \
93*795d594fSAndroid Build Coastguard Worker          || (rm -r $(ART_HOST_TEST_DIR) && false)))))
94*795d594fSAndroid Build Coastguard Workerendef
95*795d594fSAndroid Build Coastguard Worker
96*795d594fSAndroid Build Coastguard Worker# Define the command executed by the shell ahead of running an art test. $(1) is the name of the
97*795d594fSAndroid Build Coastguard Worker# test.
98*795d594fSAndroid Build Coastguard Workerdefine ART_TEST_SKIP
99*795d594fSAndroid Build Coastguard Worker  ((echo $(ART_TEST_KNOWN_BROKEN) | grep -q -v $(1) \
100*795d594fSAndroid Build Coastguard Worker     && ([ ! -d $(ART_HOST_TEST_DIR)/failed/ ] || [ $(ART_TEST_KEEP_GOING) = true ])\
101*795d594fSAndroid Build Coastguard Worker     && $(call ART_TEST_ANNOUNCE_RUN,$(1)) ) \
102*795d594fSAndroid Build Coastguard Worker   || ((mkdir -p $(ART_HOST_TEST_DIR)/skipped/ && touch $(ART_HOST_TEST_DIR)/skipped/$(1) \
103*795d594fSAndroid Build Coastguard Worker     && ([ -d $(ART_HOST_TEST_DIR)/failed/ ] \
104*795d594fSAndroid Build Coastguard Worker       && $(call ART_TEST_ANNOUNCE_SKIP_FAILURE,$(1)) ) \
105*795d594fSAndroid Build Coastguard Worker     || $(call ART_TEST_ANNOUNCE_SKIP_BROKEN,$(1)) ) && false))
106*795d594fSAndroid Build Coastguard Workerendef
107*795d594fSAndroid Build Coastguard Worker
108*795d594fSAndroid Build Coastguard Workerendif # ART_ANDROID_COMMON_TEST_MK
109