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