TestCommon.gmk revision 2716:d48c70fef706
190075Sobrien# 2169689Skan# Copyright (c) 1995, 2017, Oracle and/or its affiliates. All rights reserved. 390075Sobrien# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 490075Sobrien# 5132718Skan# This code is free software; you can redistribute it and/or modify it 690075Sobrien# under the terms of the GNU General Public License version 2 only, as 7132718Skan# published by the Free Software Foundation. Oracle designates this 890075Sobrien# particular file as subject to the "Classpath" exception as provided 990075Sobrien# by Oracle in the LICENSE file that accompanied this code. 1090075Sobrien# 1190075Sobrien# This code is distributed in the hope that it will be useful, but WITHOUT 12132718Skan# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 1390075Sobrien# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 1490075Sobrien# version 2 for more details (a copy is included in the LICENSE file that 1590075Sobrien# accompanied this code). 1690075Sobrien# 1790075Sobrien# You should have received a copy of the GNU General Public License version 18132718Skan# 2 along with this work; if not, write to the Free Software Foundation, 19169689Skan# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 20169689Skan# 2190075Sobrien# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 2290075Sobrien# or visit www.oracle.com if you need additional information or have any 2390075Sobrien# questions. 24132718Skan# 25132718Skan 2690075Sobrien# 2790075Sobrien# Common logic to run various tests for a component, to be included by the 2890075Sobrien# component specific test makefiles. 2990075Sobrien# 3090075Sobrien 3190075Sobrien# Default values for some properties that can be overridden by components. 32132718SkanUSE_JTREG_VERSION ?= 4.2 33169689SkanJTREG_VM_TYPE ?= -agentvm 34169689SkanUSE_JTREG_ASSERT ?= true 35169689SkanLIMIT_JTREG_VM_MEMORY ?= true 3690075Sobrien 37132718Skan.DEFAULT : all 38169689Skan 3990075Sobrien# Empty these to get rid of some default rules 40169689Skan.SUFFIXES: 41169689Skan.SUFFIXES: .java 42132718SkanCO= 4390075SobrienGET= 4490075Sobrien 4590075Sobrien# Utilities used 4690075SobrienAWK = awk 47259269SpfgCAT = cat 48259269SpfgCD = cd 49117395SkanCHMOD = chmod 50117395SkanCP = cp 51169689SkanCUT = cut 52169689SkanDIRNAME = dirname 53169689SkanECHO = echo 54169689SkanEGREP = egrep 5590075SobrienEXPAND = expand 56169689SkanFIND = find 5790075SobrienMKDIR = mkdir 5890075SobrienPWD = pwd 59117395SkanRM = rm -f 60117395SkanSED = sed 61117395SkanSORT = sort 62117395SkanTEE = tee 63169689SkanUNAME = uname 64117395SkanUNIQ = uniq 65169689SkanWC = wc 66117395SkanZIPEXE = zip 67169689Skan 68117395Skan# Get OS name from uname (Cygwin inexplicably adds _NT-5.1) 69117395SkanUNAME_S := $(shell $(UNAME) -s | $(CUT) -f1 -d_) 70117395Skan 71117395Skan# Commands to run on paths to make mixed paths for java on windows 72117395Skanifeq ($(findstring CYGWIN,$(UNAME_S)), CYGWIN) 73117395Skan # Location of developer shared files 74117395Skan SLASH_JAVA = J: 75117395Skan GETMIXEDPATH = cygpath -m 76117395Skan PLATFORM = windows 77117395Skanelse 78117395Skan # Location of developer shared files 79117395Skan SLASH_JAVA = /java 80117395Skan GETMIXEDPATH = $(ECHO) 81117395Skan PLATFORM = unix # we only care about windows or bsd. 82117395Skan ifeq ($(UNAME_S), Darwin) 83117395Skan PLATFORM = bsd 84117395Skan endif 85117395Skan ifeq ($(findstring BSD,$(UNAME_S)), BSD) 86117395Skan PLATFORM = bsd 87117395Skan endif 88117395Skanendif 89117395Skan 90117395Skanifdef ALT_SLASH_JAVA 91117395Skan SLASH_JAVA = $(ALT_SLASH_JAVA) 92117395Skanendif 93117395Skan 94117395Skan# Root of this test area (important to use full paths in some places) 95117395SkanTEST_ROOT := $(shell $(PWD)) 96117395Skan 97117395Skan# Root of all test results 98117395Skanifdef TEST_OUTPUT_DIR 99117395Skan $(shell $(MKDIR) -p $(TEST_OUTPUT_DIR)/jtreg) 100169689Skan ABS_TEST_OUTPUT_DIR := \ 101169689Skan $(shell $(CD) $(TEST_OUTPUT_DIR)/jtreg && $(PWD)) 102117395Skanelse 103169689Skan ifdef ALT_OUTPUTDIR 104117395Skan ABS_OUTPUTDIR = $(shell $(CD) $(ALT_OUTPUTDIR) && $(PWD)) 105169689Skan else 106169689Skan ABS_OUTPUTDIR = $(shell $(CD) $(TEST_ROOT)/.. && $(PWD)) 107169689Skan endif 108169689Skan 109169689Skan ABS_PLATFORM_BUILD_ROOT = $(ABS_OUTPUTDIR) 110169689Skan ABS_TEST_OUTPUT_DIR := $(ABS_PLATFORM_BUILD_ROOT)/testoutput/$(UNIQUE_DIR) 11190075Sobrienendif 112169689Skan 11390075Sobrien# Expect JPRT to set PRODUCT_HOME (the product or jdk in this case to test) 114102780Skanifndef PRODUCT_HOME 115117395Skan # Try to use images/jdk if it exists 116169689Skan ABS_JDK_IMAGE = $(ABS_PLATFORM_BUILD_ROOT)/images/jdk 117169689Skan PRODUCT_HOME := \ 118117395Skan $(shell \ 119169689Skan if [ -d $(ABS_JDK_IMAGE) ] ; then \ 120169689Skan $(ECHO) "$(ABS_JDK_IMAGE)"; \ 121169689Skan else \ 122117395Skan $(ECHO) "$(ABS_PLATFORM_BUILD_ROOT)"; \ 123169689Skan fi) 124169689Skan PRODUCT_HOME := $(PRODUCT_HOME) 125169689Skanendif 126117395Skan 127169689Skan# Expect JPRT to set JAVA_ARGS (e.g. -server etc.) 128169689Skanifdef JAVA_ARGS 129169689Skan JAVA_OPTIONS := $(JAVA_ARGS) 130117395Skanelse 131169689Skan JAVA_OPTIONS := 132169689Skanendif 133169689Skan 134102780Skan# Expect JPRT to set JPRT_PRODUCT_ARGS (e.g. -server etc.) 135169689Skan# Should be passed into 'java' only. 136169689Skan# Could include: -d64 -server -client OR any java option 137169689Skanifdef JPRT_PRODUCT_ARGS 138107590Sobrien JAVA_ARGS = $(JPRT_PRODUCT_ARGS) 139169689Skanendif 140132718Skan 141107590Sobrien# Expect JPRT to set JPRT_PRODUCT_VM_ARGS (e.g. -Xcomp etc.) 142107590Sobrien# Should be passed into anything running the vm (java, javac, javadoc, ...). 143132718Skanifdef JPRT_PRODUCT_VM_ARGS 144169689Skan JAVA_VM_ARGS = $(JPRT_PRODUCT_VM_ARGS) 145132718Skanendif 146169689Skan 147132718Skanifneq ($(NATIVE_TEST_PATH), ) 148132718Skan # jtreg -nativepath <dir> 149169689Skan # 150 # Local make tests will be TEST_IMAGE_DIR and JPRT with jprt.use.reg.test.bundle=true 151 # should be JPRT_TESTNATIVE_PATH 152 ifdef TEST_IMAGE_DIR 153 TESTNATIVE_DIR = $(TEST_IMAGE_DIR) 154 else ifdef JPRT_TESTNATIVE_PATH 155 TESTNATIVE_DIR = $(JPRT_TESTNATIVE_PATH) 156 endif 157 ifdef TESTNATIVE_DIR 158 JTREG_NATIVE_PATH = -nativepath:$(shell $(GETMIXEDPATH) "$(TESTNATIVE_DIR)/$(NATIVE_TEST_PATH)") 159 endif 160endif 161 162ifeq ($(USE_FAILURE_HANDLER), true) 163 # jtreg failure handler config 164 ifeq ($(FAILURE_HANDLER_DIR), ) 165 ifneq ($(TESTNATIVE_DIR), ) 166 FAILURE_HANDLER_DIR := $(TESTNATIVE_DIR)/failure_handler 167 endif 168 endif 169 ifneq ($(FAILURE_HANDLER_DIR), ) 170 FAILURE_HANDLER_DIR_MIXED := $(shell $(GETMIXEDPATH) "$(FAILURE_HANDLER_DIR)") 171 JTREG_FAILURE_HANDLER_OPTIONS := \ 172 -timeoutHandlerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \ 173 -observerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \ 174 -timeoutHandler:jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler \ 175 -observer:jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver \ 176 -timeoutHandlerTimeout:0 177 ifeq ($(PLATFORM), windows) 178 JTREG_FAILURE_HANDLER_OPTIONS += -J-Djava.library.path="$(FAILURE_HANDLER_DIR_MIXED)" 179 endif 180 endif 181endif 182 183# Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results) 184ifdef JPRT_ARCHIVE_BUNDLE 185 ARCHIVE_BUNDLE = $(JPRT_ARCHIVE_BUNDLE) 186else 187 ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip 188endif 189 190# How to create the test bundle (pass or fail, we want to create this) 191# Follow command with ";$(BUNDLE_UP_AND_EXIT)", so it always gets executed. 192ZIP_UP_RESULTS = ( $(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)` \ 193 && $(CD) $(ABS_TEST_OUTPUT_DIR) \ 194 && $(CHMOD) -R a+r . \ 195 && $(ZIPEXE) -q -r $(ARCHIVE_BUNDLE) . ) 196 197# important results files 198SUMMARY_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport/text/summary.txt") 199STATS_TXT_NAME = Stats.txt 200STATS_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/$(STATS_TXT_NAME)") 201RUNLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/runlist.txt") 202PASSLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/passlist.txt") 203FAILLIST = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/faillist.txt") 204EXITCODE = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/exitcode.txt") 205 206TESTEXIT = \ 207 if [ ! -s $(EXITCODE) ] ; then \ 208 $(ECHO) "ERROR: EXITCODE file not filled in."; \ 209 $(ECHO) "1" > $(EXITCODE); \ 210 fi ; \ 211 testExitCode=`$(CAT) $(EXITCODE)`; \ 212 $(ECHO) "EXIT CODE: $${testExitCode}"; \ 213 exit $${testExitCode} 214 215ifeq ($(TREAT_EXIT_CODE_1_AS_0), true) 216 ADJUST_EXIT_CODE := \ 217 if [ $${jtregExitCode} = 1 ] ; then \ 218 jtregExitCode=0; \ 219 fi 220else 221 # colon is the shell no-op 222 ADJUST_EXIT_CODE := : 223endif 224 225BUNDLE_UP_AND_EXIT = \ 226( \ 227 jtregExitCode=$$? && \ 228 _summary="$(SUMMARY_TXT)"; \ 229 $(ADJUST_EXIT_CODE) ; \ 230 $(RM) -f $(STATS_TXT) $(RUNLIST) $(PASSLIST) $(FAILLIST) $(EXITCODE); \ 231 $(ECHO) "$${jtregExitCode}" > $(EXITCODE); \ 232 if [ -r "$${_summary}" ] ; then \ 233 $(ECHO) "Summary: $(UNIQUE_DIR)" > $(STATS_TXT); \ 234 $(EXPAND) $${_summary} | $(EGREP) -v ' Not run\.' > $(RUNLIST); \ 235 $(EGREP) ' Passed\.' $(RUNLIST) \ 236 | $(EGREP) -v ' Error\.' \ 237 | $(EGREP) -v ' Failed\.' > $(PASSLIST); \ 238 ( $(EGREP) ' Failed\.' $(RUNLIST); \ 239 $(EGREP) ' Error\.' $(RUNLIST); \ 240 $(EGREP) -v ' Passed\.' $(RUNLIST) ) \ 241 | $(SORT) | $(UNIQ) > $(FAILLIST); \ 242 if [ $${jtregExitCode} != 0 -o -s $(FAILLIST) ] ; then \ 243 $(EXPAND) $(FAILLIST) \ 244 | $(CUT) -d' ' -f1 \ 245 | $(SED) -e 's@^@FAILED: @' >> $(STATS_TXT); \ 246 if [ $${jtregExitCode} = 0 ] ; then \ 247 jtregExitCode=1; \ 248 fi; \ 249 fi; \ 250 runc="`$(CAT) $(RUNLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \ 251 passc="`$(CAT) $(PASSLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \ 252 failc="`$(CAT) $(FAILLIST) | $(WC) -l | $(AWK) '{print $$1;}'`"; \ 253 exclc="FIXME CODETOOLS-7900176"; \ 254 $(ECHO) "TEST STATS: name=$(UNIQUE_DIR) run=$${runc} pass=$${passc} fail=$${failc}" \ 255 >> $(STATS_TXT); \ 256 else \ 257 $(ECHO) "Missing file: $${_summary}" >> $(STATS_TXT); \ 258 fi; \ 259 if [ -f $(STATS_TXT) ] ; then \ 260 $(CAT) $(STATS_TXT); \ 261 fi; \ 262 $(ZIP_UP_RESULTS) ; \ 263 $(TESTEXIT) \ 264) 265 266################################################################ 267 268# Prep for output 269# Change execute permissions on shared library files. 270# Files in repositories should never have execute permissions, but 271# there are some tests that have pre-built shared libraries, and these 272# windows dll files must have execute permission. Adding execute 273# permission may happen automatically on windows when using certain 274# versions of mercurial but it cannot be guaranteed. And blindly 275# adding execute permission might be seen as a mercurial 'change', so 276# we avoid adding execute permission to repository files. But testing 277# from a plain source tree needs the chmod a+rx. Applying the chmod to 278# all shared libraries not just dll files. And with CYGWIN and sshd 279# service, you may need CYGWIN=ntsec for this to work. 280prep: 281 @$(MKDIR) -p $(ABS_TEST_OUTPUT_DIR) 282 @$(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)` 283 @if [ ! -d $(TEST_ROOT)/../.hg ] ; then \ 284 $(FIND) $(TEST_ROOT) \( -name \*.dll -o -name \*.DLL -o -name \*.so \) \ 285 -exec $(CHMOD) a+rx {} \; ; \ 286 fi 287 288ifeq ($(CLEAN_BEFORE_PREP), true) 289prep: clean 290 291endif 292 293# Cleanup 294clean: 295 @$(RM) -r $(ABS_TEST_OUTPUT_DIR) 296 @$(RM) $(ARCHIVE_BUNDLE) 297 298################################################################ 299 300# jtreg tests 301 302# Expect JT_HOME to be set for jtreg tests. (home for jtreg) 303ifndef JT_HOME 304 JT_HOME = $(SLASH_JAVA)/re/jtreg/$(USE_JTREG_VERSION)/promoted/latest/binaries/jtreg 305 ifdef JPRT_JTREG_HOME 306 JT_HOME = $(JPRT_JTREG_HOME) 307 endif 308endif 309 310# Problematic tests to be excluded 311PROBLEM_LISTS=$(call MixedDirs,$(wildcard ProblemList.txt closed/ProblemList.txt)) 312 313# Create exclude list for this platform and arch 314ifdef NO_EXCLUDES 315 JTREG_EXCLUSIONS = 316else 317 JTREG_EXCLUSIONS = $(PROBLEM_LISTS:%=-exclude:%) 318endif 319 320# convert list of directories to dos paths 321define MixedDirs 322$(foreach i,$1,$(shell $(GETMIXEDPATH) "${i}")) 323endef 324 325# ------------------------------------------------------------------ 326 327# When called from JPRT the TESTDIRS variable is set to the jtreg tests to run 328ifdef TESTDIRS 329 TEST_SELECTION = $(TESTDIRS) 330endif 331 332ifdef CONCURRENCY 333 JTREG_BASIC_OPTIONS += -concurrency:$(CONCURRENCY) 334endif 335ifdef EXTRA_JTREG_OPTIONS 336 JTREG_BASIC_OPTIONS += $(EXTRA_JTREG_OPTIONS) 337endif 338 339# Default JTREG to run 340JTREG = $(JT_HOME)/bin/jtreg 341# run in agentvm/othervm mode 342JTREG_BASIC_OPTIONS += $(JTREG_VM_TYPE) 343# Only run automatic tests 344JTREG_BASIC_OPTIONS += -a 345# Always turn on assertions 346ifeq ($(USE_JTREG_ASSERT), true) 347 JTREG_ASSERT_OPTION = -ea -esa 348endif 349JTREG_BASIC_OPTIONS += $(JTREG_ASSERT_OPTION) 350# jtreg verbosity setting 351# Default is to report details on all failed or error tests, times too 352JTREG_VERBOSE ?= fail,error,time 353JTREG_BASIC_OPTIONS += $(if $(JTREG_VERBOSE),-v:$(JTREG_VERBOSE)) 354# Retain all files for failing tests 355JTREG_BASIC_OPTIONS += -retain:fail,error 356# Ignore tests are not run and completely silent about it 357JTREG_IGNORE_OPTION = -ignore:quiet 358JTREG_BASIC_OPTIONS += $(JTREG_IGNORE_OPTION) 359# Multiply by 4 the timeout factor 360JTREG_TIMEOUT_OPTION = -timeoutFactor:4 361JTREG_BASIC_OPTIONS += $(JTREG_TIMEOUT_OPTION) 362ifeq ($(LIMIT_JTREG_VM_MEMORY), true) 363 # Set the max memory for jtreg control vm 364 JTREG_MEMORY_OPTION = -J-Xmx512m 365 JTREG_BASIC_OPTIONS += $(JTREG_MEMORY_OPTION) 366 # Set the max memory for jtreg target test vms 367 JTREG_TESTVM_MEMORY_OPTION = -vmoption:-Xmx512m 368 JTREG_TEST_OPTIONS += $(JTREG_TESTVM_MEMORY_OPTION) 369endif 370# Give tests access to JT_JAVA, see JDK-8141609 371JTREG_BASIC_OPTIONS += -e:JDK8_HOME=${JT_JAVA} 372# Give aot tests access to Visual Studio installation 373ifneq ($(VS120COMNTOOLS), ) 374 JTREG_BASIC_OPTIONS += -e:VS120COMNTOOLS=$(shell $(GETMIXEDPATH) "$(VS120COMNTOOLS)") 375endif 376# Set other vm and test options 377JTREG_TEST_OPTIONS += $(JAVA_ARGS:%=-javaoptions:%) $(JAVA_OPTIONS:%=-vmoption:%) $(JAVA_VM_ARGS:%=-vmoption:%) 378ifneq ($(JIB_JAR), ) 379 JTREG_BASIC_OPTIONS += -cpa:$(shell $(GETMIXEDPATH) "$(JIB_JAR)") 380endif 381ifeq ($(IGNORE_MARKED_TESTS), true) 382 # Option to tell jtreg to not run tests marked with "ignore" 383 ifeq ($(PLATFORM), windows) 384 JTREG_KEY_OPTION = -k:!ignore 385 else 386 JTREG_KEY_OPTION = -k:\!ignore 387 endif 388 JTREG_BASIC_OPTIONS += $(JTREG_KEY_OPTION) 389endif 390 391# Make sure jtreg exists 392ifeq ($(USE_WINDOWS_EXISTENCE_CHECK), true) 393 jtreg_exists: 394 test -d $(shell $(GETMIXEDPATH) "$(JT_HOME)") 395 test -f $(shell $(GETMIXEDPATH) "$(JTREG)") 396 397else 398 jtreg_exists: $(JT_HOME) 399endif 400PHONY_LIST += jtreg_exists 401 402# Run jtreg 403jtreg_tests: prep jtreg_exists $(PRODUCT_HOME) 404 ( \ 405 ( JT_HOME=$(shell $(GETMIXEDPATH) "$(JT_HOME)"); \ 406 export JT_HOME; \ 407 $(shell $(GETMIXEDPATH) "$(JTREG)") \ 408 $(JTREG_BASIC_OPTIONS) \ 409 -r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport") \ 410 -w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork") \ 411 -jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)") \ 412 $(JTREG_NATIVE_PATH) \ 413 $(JTREG_FAILURE_HANDLER_OPTIONS) \ 414 $(JTREG_EXCLUSIONS) \ 415 $(JTREG_TEST_OPTIONS) \ 416 $(TEST_SELECTION) \ 417 ) ; \ 418 $(BUNDLE_UP_AND_EXIT) \ 419 ) 2>&1 | $(TEE) $(ABS_TEST_OUTPUT_DIR)/output.txt ; $(TESTEXIT) 420 421PHONY_LIST += jtreg_tests 422 423################################################################ 424 425# Phony targets (e.g. these are not filenames) 426.PHONY: all clean prep $(PHONY_LIST) 427 428################################################################ 429