jdk/test/Makefile
changeset 42439 ccef74161219
parent 42184 6965d53e507c
equal deleted inserted replaced
42438:34eaac353f05 42439:ccef74161219
    21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
    22 # or visit www.oracle.com if you need additional information or have any
    22 # or visit www.oracle.com if you need additional information or have any
    23 # questions.
    23 # questions.
    24 #
    24 #
    25 
    25 
    26 #
    26 default: all
    27 # Makefile to run various jdk tests
       
    28 #
       
    29 
    27 
    30 .DEFAULT : all
    28 NATIVE_TEST_PATH := jdk/jtreg/native
    31 
    29 
    32 # Empty these to get rid of some default rules
    30 USE_FAILURE_HANDLER := true
    33 .SUFFIXES:
       
    34 .SUFFIXES: .java
       
    35 CO=
       
    36 GET=
       
    37 
    31 
    38 # Utilities used
    32 TREAT_EXIT_CODE_1_AS_0 := true
    39 AWK       = awk
       
    40 CAT       = cat
       
    41 CD        = cd
       
    42 CHMOD     = chmod
       
    43 CP        = cp
       
    44 CUT       = cut
       
    45 DIRNAME   = dirname
       
    46 ECHO      = echo
       
    47 EGREP     = egrep
       
    48 EXPAND    = expand
       
    49 FIND      = find
       
    50 MKDIR     = mkdir
       
    51 PWD       = pwd
       
    52 SED       = sed
       
    53 SORT      = sort
       
    54 TEE       = tee
       
    55 UNAME     = uname
       
    56 UNIQ      = uniq
       
    57 WC        = wc
       
    58 ZIPEXE    = zip
       
    59 
    33 
    60 # Get OS name from uname (Cygwin inexplicably adds _NT-5.1)
    34 include ../../test/TestCommon.gmk
    61 UNAME_S := $(shell $(UNAME) -s | $(CUT) -f1 -d_)
       
    62 
       
    63 # Commands to run on paths to make mixed paths for java on windows
       
    64 ifeq ($(UNAME_S), CYGWIN)
       
    65   # Location of developer shared files
       
    66   SLASH_JAVA = J:
       
    67   GETMIXEDPATH = cygpath -m
       
    68 else
       
    69   # Location of developer shared files
       
    70   SLASH_JAVA = /java
       
    71 
       
    72   GETMIXEDPATH=$(ECHO)
       
    73 endif
       
    74 
       
    75 # Root of this test area (important to use full paths in some places)
       
    76 TEST_ROOT := $(shell $(PWD))
       
    77 
       
    78 # Root of all test results
       
    79 ifdef TEST_OUTPUT_DIR
       
    80   $(shell $(MKDIR) -p $(TEST_OUTPUT_DIR)/jtreg)
       
    81   ABS_TEST_OUTPUT_DIR := \
       
    82     $(shell $(CD) $(TEST_OUTPUT_DIR)/jtreg && $(PWD))
       
    83 else
       
    84   ifdef ALT_OUTPUTDIR
       
    85     ABS_OUTPUTDIR = $(shell $(CD) $(ALT_OUTPUTDIR) && $(PWD))
       
    86   else
       
    87     ABS_OUTPUTDIR = $(shell $(CD) $(TEST_ROOT)/.. && $(PWD))
       
    88   endif
       
    89 
       
    90   ABS_PLATFORM_BUILD_ROOT = $(ABS_OUTPUTDIR)
       
    91   ABS_TEST_OUTPUT_DIR := $(ABS_PLATFORM_BUILD_ROOT)/testoutput/$(UNIQUE_DIR)
       
    92 endif
       
    93 
       
    94 # Expect JPRT to set PRODUCT_HOME (the product or jdk in this case to test)
       
    95 ifndef PRODUCT_HOME
       
    96   # Try to use images/jdk if it exists
       
    97   ABS_JDK_IMAGE = $(ABS_PLATFORM_BUILD_ROOT)/images/jdk
       
    98   PRODUCT_HOME :=                       		\
       
    99     $(shell                             		\
       
   100       if [ -d $(ABS_JDK_IMAGE) ] ; then 		\
       
   101          $(ECHO) "$(ABS_JDK_IMAGE)";    		\
       
   102        else                             		\
       
   103          $(ECHO) "$(ABS_PLATFORM_BUILD_ROOT)";		\
       
   104        fi)
       
   105   PRODUCT_HOME := $(PRODUCT_HOME)
       
   106 endif
       
   107 
       
   108 # Expect JPRT to set JPRT_PRODUCT_ARGS (e.g. -server etc.)
       
   109 #   Should be passed into 'java' only.
       
   110 #   Could include: -d64 -server -client OR any java option
       
   111 ifdef JPRT_PRODUCT_ARGS
       
   112   JAVA_ARGS = $(JPRT_PRODUCT_ARGS)
       
   113 endif
       
   114 
       
   115 # Expect JPRT to set JPRT_PRODUCT_VM_ARGS (e.g. -Xcomp etc.)
       
   116 #   Should be passed into anything running the vm (java, javac, javadoc, ...).
       
   117 ifdef JPRT_PRODUCT_VM_ARGS
       
   118   JAVA_VM_ARGS = $(JPRT_PRODUCT_VM_ARGS)
       
   119 endif
       
   120 
       
   121 # jtreg -nativepath <dir>
       
   122 #
       
   123 # Local make tests will be TEST_IMAGE_DIR and JPRT with jprt.use.reg.test.bundle=true
       
   124 # should be JPRT_TESTNATIVE_PATH
       
   125 ifdef TEST_IMAGE_DIR
       
   126   TESTNATIVE_DIR = $(TEST_IMAGE_DIR)
       
   127 else ifdef JPRT_TESTNATIVE_PATH
       
   128   TESTNATIVE_DIR = $(JPRT_TESTNATIVE_PATH)
       
   129 endif
       
   130 ifdef TESTNATIVE_DIR
       
   131   JTREG_NATIVE_PATH = -nativepath:$(shell $(GETMIXEDPATH) "$(TESTNATIVE_DIR)/jdk/jtreg/native")
       
   132 endif
       
   133 
       
   134 # jtreg failure handler config
       
   135 ifeq ($(FAILURE_HANDLER_DIR), )
       
   136   ifneq ($(TESTNATIVE_DIR), )
       
   137     FAILURE_HANDLER_DIR := $(TESTNATIVE_DIR)/failure_handler
       
   138   endif
       
   139 endif
       
   140 ifneq ($(FAILURE_HANDLER_DIR), )
       
   141   FAILURE_HANDLER_DIR_MIXED := $(shell $(GETMIXEDPATH) "$(FAILURE_HANDLER_DIR)")
       
   142   JTREG_FAILURE_HANDLER_OPTIONS := \
       
   143       -timeoutHandlerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \
       
   144       -observerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \
       
   145       -timeoutHandler:jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler \
       
   146       -observer:jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver \
       
   147       -timeoutHandlerTimeout:0
       
   148   ifeq ($(UNAME_S), CYGWIN)
       
   149     JTREG_FAILURE_HANDLER_OPTIONS += -J-Djava.library.path="$(FAILURE_HANDLER_DIR_MIXED)"
       
   150   endif
       
   151 endif
       
   152 
       
   153 # Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results)
       
   154 ifdef JPRT_ARCHIVE_BUNDLE
       
   155   ARCHIVE_BUNDLE = $(JPRT_ARCHIVE_BUNDLE)
       
   156 else
       
   157   ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip
       
   158 endif
       
   159 
       
   160 # How to create the test bundle (pass or fail, we want to create this)
       
   161 #   Follow command with ";$(BUNDLE_UP_AND_EXIT)", so it always gets executed.
       
   162 ZIP_UP_RESULTS = ( $(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`     \
       
   163 	           && $(CD) $(ABS_TEST_OUTPUT_DIR)             \
       
   164 	           && $(CHMOD) -R a+r . \
       
   165 	           && $(ZIPEXE) -q -r $(ARCHIVE_BUNDLE) . )
       
   166 
       
   167 # important results files
       
   168 SUMMARY_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport/text/summary.txt")
       
   169 STATS_TXT_NAME = Stats.txt
       
   170 STATS_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/$(STATS_TXT_NAME)")
       
   171 RUNLIST   = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/runlist.txt")
       
   172 PASSLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/passlist.txt")
       
   173 FAILLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/faillist.txt")
       
   174 EXITCODE  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/exitcode.txt")
       
   175 
       
   176 TESTEXIT = \
       
   177   if [ ! -s $(EXITCODE) ] ; then \
       
   178     $(ECHO) "ERROR: EXITCODE file not filled in."; \
       
   179     $(ECHO) "1" > $(EXITCODE); \
       
   180   fi ; \
       
   181   testExitCode=`$(CAT) $(EXITCODE)`; \
       
   182   $(ECHO) "EXIT CODE: $${testExitCode}"; \
       
   183   exit $${testExitCode}
       
   184 
       
   185 BUNDLE_UP_AND_EXIT = \
       
   186 ( \
       
   187   jtregExitCode=$$? && \
       
   188   _summary="$(SUMMARY_TXT)"; \
       
   189   if [ $${jtregExitCode} = 1 ] ; then \
       
   190     jtregExitCode=0; \
       
   191   fi; \
       
   192   $(RM) -f $(STATS_TXT) $(RUNLIST) $(PASSLIST) $(FAILLIST) $(EXITCODE); \
       
   193   $(ECHO) "$${jtregExitCode}" > $(EXITCODE); \
       
   194   if [ -r "$${_summary}" ] ; then \
       
   195     $(ECHO) "Summary: $(UNIQUE_DIR)" > $(STATS_TXT); \
       
   196     $(EXPAND) $${_summary} | $(EGREP) -v ' Not run\.' > $(RUNLIST); \
       
   197     $(EGREP) ' Passed\.' $(RUNLIST) \
       
   198       | $(EGREP) -v ' Error\.' \
       
   199       | $(EGREP) -v ' Failed\.' > $(PASSLIST); \
       
   200     ( $(EGREP) ' Failed\.' $(RUNLIST); \
       
   201       $(EGREP) ' Error\.' $(RUNLIST); \
       
   202       $(EGREP) -v ' Passed\.' $(RUNLIST) ) \
       
   203       | $(SORT) | $(UNIQ) > $(FAILLIST); \
       
   204     if [ $${jtregExitCode} != 0 -o -s $(FAILLIST) ] ; then \
       
   205       $(EXPAND) $(FAILLIST) \
       
   206         | $(CUT) -d' ' -f1 \
       
   207         | $(SED) -e 's@^@FAILED: @' >> $(STATS_TXT); \
       
   208       if [ $${jtregExitCode} = 0 ] ; then \
       
   209         jtregExitCode=1; \
       
   210       fi; \
       
   211     fi; \
       
   212     runc="`$(CAT) $(RUNLIST)      | $(WC) -l | $(AWK) '{print $$1;}'`"; \
       
   213     passc="`$(CAT) $(PASSLIST)    | $(WC) -l | $(AWK) '{print $$1;}'`"; \
       
   214     failc="`$(CAT) $(FAILLIST)    | $(WC) -l | $(AWK) '{print $$1;}'`"; \
       
   215     exclc="FIXME CODETOOLS-7900176"; \
       
   216     $(ECHO) "TEST STATS: name=$(UNIQUE_DIR)  run=$${runc}  pass=$${passc}  fail=$${failc}" \
       
   217       >> $(STATS_TXT); \
       
   218   else \
       
   219     $(ECHO) "Missing file: $${_summary}" >> $(STATS_TXT); \
       
   220   fi; \
       
   221   if [ -f $(STATS_TXT) ] ; then \
       
   222     $(CAT) $(STATS_TXT); \
       
   223   fi; \
       
   224   $(ZIP_UP_RESULTS) ; \
       
   225   $(TESTEXIT) \
       
   226 )
       
   227 
       
   228 ################################################################
       
   229 
    35 
   230 # Default make rule (runs default jdk tests)
    36 # Default make rule (runs default jdk tests)
   231 all: jdk_default
    37 all: jdk_default
   232 	@$(ECHO) "Testing completed successfully"
    38 	@$(ECHO) "Testing completed successfully"
   233 
       
   234 # Prep for output
       
   235 # Change execute permissions on shared library files.
       
   236 # Files in repositories should never have execute permissions, but
       
   237 # there are some tests that have pre-built shared libraries, and these
       
   238 # windows dll files must have execute permission. Adding execute
       
   239 # permission may happen automatically on windows when using certain
       
   240 # versions of mercurial but it cannot be guaranteed. And blindly
       
   241 # adding execute permission might be seen as a mercurial 'change', so
       
   242 # we avoid adding execute permission to repository files. But testing
       
   243 # from a plain source tree needs the chmod a+rx. Applying the chmod to
       
   244 # all shared libraries not just dll files. And with CYGWIN and sshd
       
   245 # service, you may need CYGWIN=ntsec for this to work.
       
   246 prep:
       
   247 	@$(MKDIR) -p $(ABS_TEST_OUTPUT_DIR)
       
   248 	@$(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`
       
   249 	@if [ ! -d $(TEST_ROOT)/../.hg ] ; then                          \
       
   250 	  $(FIND) $(TEST_ROOT) \( -name \*.dll -o -name \*.DLL -o -name \*.so \)  \
       
   251 	        -exec $(CHMOD) a+rx {} \; ;                             \
       
   252         fi
       
   253 
       
   254 # Cleanup
       
   255 clean:
       
   256 	@$(RM) -r $(ABS_TEST_OUTPUT_DIR)
       
   257 	@$(RM) $(ARCHIVE_BUNDLE)
       
   258 
       
   259 ################################################################
       
   260 
       
   261 # jtreg tests
       
   262 
       
   263 # Expect JT_HOME to be set for jtreg tests. (home for jtreg)
       
   264 ifndef JT_HOME
       
   265   JT_HOME = $(SLASH_JAVA)/re/jtreg/4.2/promoted/latest/binaries/jtreg
       
   266   ifdef JPRT_JTREG_HOME
       
   267     JT_HOME = $(JPRT_JTREG_HOME)
       
   268   endif
       
   269 endif
       
   270 
       
   271 # Problematic tests to be excluded
       
   272 PROBLEM_LISTS=$(call MixedDirs,$(wildcard ProblemList.txt closed/ProblemList.txt))
       
   273 
       
   274 # Create exclude list for this platform and arch
       
   275 ifdef NO_EXCLUDES
       
   276   JTREG_EXCLUSIONS =
       
   277 else
       
   278   JTREG_EXCLUSIONS = $(PROBLEM_LISTS:%=-exclude:%)
       
   279 endif
       
   280 
       
   281 # convert list of directories to dos paths
       
   282 define MixedDirs
       
   283 $(foreach i,$1,$(shell $(GETMIXEDPATH) "${i}"))
       
   284 endef
       
   285 
       
   286 define SummaryInfo
       
   287 $(ECHO) "########################################################"
       
   288 $(CAT) $(?:%=$(ABS_TEST_OUTPUT_DIR)/%/$(STATS_TXT_NAME))
       
   289 $(ECHO) "########################################################"
       
   290 endef
       
   291 
    39 
   292 # ------------------------------------------------------------------
    40 # ------------------------------------------------------------------
   293 
    41 
   294 jdk_% core_% svc_%:
    42 jdk_% core_% svc_%:
   295 	$(ECHO) "Running tests: $@"
    43 	$(ECHO) "Running tests: $@"
   296 	for each in $@; do \
    44 	for each in $@; do \
   297 	        $(MAKE) -j 1 TEST_SELECTION=":$$each" UNIQUE_DIR=$$each jtreg_tests; \
    45 	        $(MAKE) -j 1 TEST_SELECTION=":$$each" UNIQUE_DIR=$$each jtreg_tests; \
   298 	done
    46 	done
   299 
       
   300 # ------------------------------------------------------------------
       
   301 
       
   302 # When called from JPRT the TESTDIRS variable is set to the jtreg tests to run
       
   303 ifdef TESTDIRS
       
   304   TEST_SELECTION = $(TESTDIRS)
       
   305 endif
       
   306 
       
   307 ifdef CONCURRENCY
       
   308   JTREG_BASIC_OPTIONS += -concurrency:$(CONCURRENCY)
       
   309 endif
       
   310 ifdef EXTRA_JTREG_OPTIONS
       
   311   JTREG_BASIC_OPTIONS += $(EXTRA_JTREG_OPTIONS)
       
   312 endif
       
   313 
       
   314 # Default JTREG to run
       
   315 JTREG = $(JT_HOME)/bin/jtreg
       
   316 # run in agentvm mode
       
   317 JTREG_BASIC_OPTIONS += -agentvm
       
   318 # Only run automatic tests
       
   319 JTREG_BASIC_OPTIONS += -a
       
   320 # Always turn on assertions
       
   321 JTREG_ASSERT_OPTION = -ea -esa
       
   322 JTREG_BASIC_OPTIONS += $(JTREG_ASSERT_OPTION)
       
   323 # jtreg verbosity setting
       
   324 JTREG_VERBOSE ?= fail,error,time
       
   325 JTREG_BASIC_OPTIONS += $(if $(JTREG_VERBOSE),-v:$(JTREG_VERBOSE))
       
   326 # Retain all files for failing tests
       
   327 JTREG_BASIC_OPTIONS += -retain:fail,error
       
   328 # Ignore tests are not run and completely silent about it
       
   329 JTREG_IGNORE_OPTION = -ignore:quiet
       
   330 JTREG_BASIC_OPTIONS += $(JTREG_IGNORE_OPTION)
       
   331 # Multiple by 4 the timeout numbers
       
   332 JTREG_TIMEOUT_OPTION =  -timeoutFactor:4
       
   333 JTREG_BASIC_OPTIONS += $(JTREG_TIMEOUT_OPTION)
       
   334 # Set the max memory for jtreg control vm
       
   335 JTREG_MEMORY_OPTION = -J-Xmx512m
       
   336 JTREG_BASIC_OPTIONS += $(JTREG_MEMORY_OPTION)
       
   337 # Give tests access to JT_JAVA, see JDK-8141609
       
   338 JTREG_BASIC_OPTIONS += -e:JDK8_HOME=${JT_JAVA}
       
   339 # Set other vm and test options
       
   340 JTREG_TEST_OPTIONS = $(JAVA_ARGS:%=-javaoptions:%) $(JAVA_VM_ARGS:%=-vmoption:%)
       
   341 # Set the GC options for test vms
       
   342 #JTREG_GC_OPTION = -vmoption:-XX:+UseSerialGC
       
   343 #JTREG_TEST_OPTIONS += $(JTREG_GC_OPTION)
       
   344 # Set the max memory for jtreg target test vms
       
   345 JTREG_TESTVM_MEMORY_OPTION = -vmoption:-Xmx512m
       
   346 JTREG_TEST_OPTIONS += $(JTREG_TESTVM_MEMORY_OPTION)
       
   347 
       
   348 # Make sure jtreg exists
       
   349 $(JTREG): $(JT_HOME)
       
   350 
       
   351 # Run jtreg
       
   352 jtreg_tests: prep $(PRODUCT_HOME) $(JTREG)
       
   353 	(                                                                    \
       
   354 	  ( JT_HOME=$(shell $(GETMIXEDPATH) "$(JT_HOME)");                   \
       
   355             export JT_HOME;                                                  \
       
   356             $(shell $(GETMIXEDPATH) "$(JTREG)")                              \
       
   357               $(JTREG_BASIC_OPTIONS)                                         \
       
   358               -r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport")  \
       
   359               -w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork")    \
       
   360               -jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)")                \
       
   361               $(JTREG_NATIVE_PATH)                                           \
       
   362               $(JTREG_FAILURE_HANDLER_OPTIONS)                               \
       
   363               $(JTREG_EXCLUSIONS)                                            \
       
   364               $(JTREG_TEST_OPTIONS)                                          \
       
   365               $(TEST_SELECTION)                                                    \
       
   366 	  ) ;                                                                \
       
   367 	  $(BUNDLE_UP_AND_EXIT)                                              \
       
   368 	) 2>&1 | $(TEE) $(ABS_TEST_OUTPUT_DIR)/output.txt ; $(TESTEXIT)
       
   369 
       
   370 PHONY_LIST += jtreg_tests
       
   371 
       
   372 ################################################################
       
   373 
       
   374 # Phony targets (e.g. these are not filenames)
       
   375 .PHONY: all clean prep $(PHONY_LIST)
       
   376 
       
   377 ################################################################