< prev index next >

nashorn/test/Makefile

Print this page


   1 #
   2 # Copyright (c) 1995, 2015, Oracle and/or its affiliates. All rights reserved.
   3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4 #
   5 # This code is free software; you can redistribute it and/or modify it
   6 # under the terms of the GNU General Public License version 2 only, as
   7 # published by the Free Software Foundation.  Oracle designates this
   8 # particular file as subject to the "Classpath" exception as provided
   9 # by Oracle in the LICENSE file that accompanied this code.
  10 #
  11 # This code is distributed in the hope that it will be useful, but WITHOUT
  12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14 # version 2 for more details (a copy is included in the LICENSE file that
  15 # accompanied this code).
  16 #
  17 # You should have received a copy of the GNU General Public License version
  18 # 2 along with this work; if not, write to the Free Software Foundation,
  19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20 #
  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
  23 # questions.
  24 #
  25 
  26 #
  27 # Makefile to run various nashorn tests
  28 #
  29 
  30 .DEFAULT : all
  31 
  32 # Empty these to get rid of some default rules
  33 .SUFFIXES:
  34 .SUFFIXES: .java
  35 CO=
  36 GET=
  37 
  38 # Utilities used
  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 
  60 # Get OS name from uname (Cygwin inexplicably adds _NT-5.1)
  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 failure handler config
 122 ifeq ($(FAILURE_HANDLER_DIR), )
 123   ifneq ($(TESTNATIVE_DIR), )
 124     FAILURE_HANDLER_DIR := $(TESTNATIVE_DIR)/failure_handler
 125   endif
 126 endif
 127 ifneq ($(FAILURE_HANDLER_DIR), )
 128   FAILURE_HANDLER_DIR_MIXED := $(shell $(GETMIXEDPATH) "$(FAILURE_HANDLER_DIR)")
 129   JTREG_FAILURE_HANDLER_OPTIONS := \
 130       -timeoutHandlerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \
 131       -observerDir:$(FAILURE_HANDLER_DIR_MIXED)/jtregFailureHandler.jar \
 132       -timeoutHandler:jdk.test.failurehandler.jtreg.GatherProcessInfoTimeoutHandler \
 133       -observer:jdk.test.failurehandler.jtreg.GatherDiagnosticInfoObserver \
 134       -timeoutHandlerTimeout:0
 135   ifeq ($(UNAME_S), CYGWIN)
 136     JTREG_FAILURE_HANDLER_OPTIONS += -J-Djava.library.path="$(FAILURE_HANDLER_DIR_MIXED)"
 137   endif
 138 endif
 139 
 140 # Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results)
 141 ifdef JPRT_ARCHIVE_BUNDLE
 142   ARCHIVE_BUNDLE = $(JPRT_ARCHIVE_BUNDLE)
 143 else
 144   ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip
 145 endif
 146 
 147 # How to create the test bundle (pass or fail, we want to create this)
 148 #   Follow command with ";$(BUNDLE_UP_AND_EXIT)", so it always gets executed.
 149 ZIP_UP_RESULTS = ( $(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`     \
 150                    && $(CD) $(ABS_TEST_OUTPUT_DIR)             \
 151                    && $(CHMOD) -R a+r . \
 152                    && $(ZIPEXE) -q -r $(ARCHIVE_BUNDLE) . )
 153 
 154 # important results files
 155 SUMMARY_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport/text/summary.txt")
 156 STATS_TXT_NAME = Stats.txt
 157 STATS_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/$(STATS_TXT_NAME)")
 158 RUNLIST   = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/runlist.txt")
 159 PASSLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/passlist.txt")
 160 FAILLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/faillist.txt")
 161 EXITCODE  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/exitcode.txt")
 162 
 163 TESTEXIT = \
 164   if [ ! -s $(EXITCODE) ] ; then \
 165     $(ECHO) "ERROR: EXITCODE file not filled in."; \
 166     $(ECHO) "1" > $(EXITCODE); \
 167   fi ; \
 168   testExitCode=`$(CAT) $(EXITCODE)`; \
 169   $(ECHO) "EXIT CODE: $${testExitCode}"; \
 170   exit $${testExitCode}
 171 
 172 BUNDLE_UP_AND_EXIT = \
 173 ( \
 174   jtregExitCode=$$? && \
 175   _summary="$(SUMMARY_TXT)"; \
 176   $(RM) -f $(STATS_TXT) $(RUNLIST) $(PASSLIST) $(FAILLIST) $(EXITCODE); \
 177   $(ECHO) "$${jtregExitCode}" > $(EXITCODE); \
 178   if [ -r "$${_summary}" ] ; then \
 179     $(ECHO) "Summary: $(UNIQUE_DIR)" > $(STATS_TXT); \
 180     $(EXPAND) $${_summary} | $(EGREP) -v ' Not run\.' > $(RUNLIST); \
 181     $(EGREP) ' Passed\.' $(RUNLIST) \
 182       | $(EGREP) -v ' Error\.' \
 183       | $(EGREP) -v ' Failed\.' > $(PASSLIST); \
 184     ( $(EGREP) ' Failed\.' $(RUNLIST); \
 185       $(EGREP) ' Error\.' $(RUNLIST); \
 186       $(EGREP) -v ' Passed\.' $(RUNLIST) ) \
 187       | $(SORT) | $(UNIQ) > $(FAILLIST); \
 188     if [ $${jtregExitCode} != 0 -o -s $(FAILLIST) ] ; then \
 189       $(EXPAND) $(FAILLIST) \
 190         | $(CUT) -d' ' -f1 \
 191         | $(SED) -e 's@^@FAILED: @' >> $(STATS_TXT); \
 192       if [ $${jtregExitCode} = 0 ] ; then \
 193         jtregExitCode=1; \
 194       fi; \
 195     fi; \
 196     runc="`$(CAT) $(RUNLIST)      | $(WC) -l | $(AWK) '{print $$1;}'`"; \
 197     passc="`$(CAT) $(PASSLIST)    | $(WC) -l | $(AWK) '{print $$1;}'`"; \
 198     failc="`$(CAT) $(FAILLIST)    | $(WC) -l | $(AWK) '{print $$1;}'`"; \
 199     exclc="FIXME CODETOOLS-7900176"; \
 200     $(ECHO) "TEST STATS: name=$(UNIQUE_DIR)  run=$${runc}  pass=$${passc}  fail=$${failc}" \
 201       >> $(STATS_TXT); \
 202   else \
 203     $(ECHO) "Missing file: $${_summary}" >> $(STATS_TXT); \
 204   fi; \
 205   if [ -f $(STATS_TXT) ] ; then \
 206     $(CAT) $(STATS_TXT); \
 207   fi; \
 208   $(ZIP_UP_RESULTS) ; \
 209   $(TESTEXIT) \
 210 )
 211 
 212 ################################################################
 213 
 214 # Default make rule (runs default nashorn tests)
 215 all: nashorn_default
 216         @$(ECHO) "Testing completed successfully"
 217 
 218 # Prep for output
 219 # Change execute permissions on shared library files.
 220 # Files in repositories should never have execute permissions, but
 221 # there are some tests that have pre-built shared libraries, and these
 222 # windows dll files must have execute permission. Adding execute
 223 # permission may happen automatically on windows when using certain
 224 # versions of mercurial but it cannot be guaranteed. And blindly
 225 # adding execute permission might be seen as a mercurial 'change', so
 226 # we avoid adding execute permission to repository files. But testing
 227 # from a plain source tree needs the chmod a+rx. Applying the chmod to
 228 # all shared libraries not just dll files. And with CYGWIN and sshd
 229 # service, you may need CYGWIN=ntsec for this to work.
 230 prep:
 231         @$(MKDIR) -p $(ABS_TEST_OUTPUT_DIR)
 232         @$(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`
 233         @if [ ! -d $(TEST_ROOT)/../.hg ] ; then                          \
 234           $(FIND) $(TEST_ROOT) \( -name \*.dll -o -name \*.DLL -o -name \*.so \)  \
 235                 -exec $(CHMOD) a+rx {} \; ;                             \
 236         fi
 237 
 238 # Cleanup
 239 clean:
 240         @$(RM) -r $(ABS_TEST_OUTPUT_DIR)
 241         @$(RM) $(ARCHIVE_BUNDLE)
 242 
 243 ################################################################
 244 
 245 # jtreg tests
 246 
 247 # Expect JT_HOME to be set for jtreg tests. (home for jtreg)
 248 ifndef JT_HOME
 249   JT_HOME = $(SLASH_JAVA)/re/jtreg/4.2/promoted/latest/binaries/jtreg
 250   ifdef JPRT_JTREG_HOME
 251     JT_HOME = $(JPRT_JTREG_HOME)
 252   endif
 253 endif
 254 
 255 # Problematic tests to be excluded
 256 PROBLEM_LISTS=$(call MixedDirs,$(wildcard ProblemList.txt closed/ProblemList.txt))
 257 
 258 # Create exclude list for this platform and arch
 259 ifdef NO_EXCLUDES
 260   JTREG_EXCLUSIONS =
 261 else
 262   JTREG_EXCLUSIONS = $(PROBLEM_LISTS:%=-exclude:%)
 263 endif
 264 
 265 # convert list of directories to dos paths
 266 define MixedDirs
 267 $(foreach i,$1,$(shell $(GETMIXEDPATH) "${i}"))
 268 endef
 269 
 270 define SummaryInfo
 271 $(ECHO) "########################################################"
 272 $(CAT) $(?:%=$(ABS_TEST_OUTPUT_DIR)/%/$(STATS_TXT_NAME))
 273 $(ECHO) "########################################################"
 274 endef
 275 
 276 # ------------------------------------------------------------------
 277 
 278 nashorn_%:
 279         $(ECHO) "Running tests: $@"
 280         for each in $@; do \
 281                 $(MAKE) -j 1 TEST_SELECTION=":$$each" UNIQUE_DIR=$$each jtreg_tests; \
 282         done
 283 
 284 # ------------------------------------------------------------------
 285 
 286 # When called from JPRT the TESTDIRS variable is set to the jtreg tests to run
 287 ifdef TESTDIRS
 288   TEST_SELECTION = $(TESTDIRS)
 289 endif
 290 
 291 ifdef CONCURRENCY
 292   JTREG_BASIC_OPTIONS += -concurrency:$(CONCURRENCY)
 293 endif
 294 ifdef EXTRA_JTREG_OPTIONS
 295   JTREG_BASIC_OPTIONS += $(EXTRA_JTREG_OPTIONS)
 296 endif
 297 
 298 # Default JTREG to run
 299 JTREG = $(JT_HOME)/bin/jtreg
 300 # run in agentvm mode
 301 JTREG_BASIC_OPTIONS += -agentvm
 302 # Only run automatic tests
 303 JTREG_BASIC_OPTIONS += -a
 304 # Always turn on assertions
 305 JTREG_ASSERT_OPTION = -ea -esa
 306 JTREG_BASIC_OPTIONS += $(JTREG_ASSERT_OPTION)
 307 # Report details on all failed or error tests, times too
 308 JTREG_BASIC_OPTIONS += -v:fail,error,time
 309 # Retain all files for failing tests
 310 JTREG_BASIC_OPTIONS += -retain:fail,error
 311 # Ignore tests are not run and completely silent about it
 312 JTREG_IGNORE_OPTION = -ignore:quiet
 313 JTREG_BASIC_OPTIONS += $(JTREG_IGNORE_OPTION)
 314 # Multiple by 4 the timeout numbers
 315 JTREG_TIMEOUT_OPTION =  -timeoutFactor:4
 316 JTREG_BASIC_OPTIONS += $(JTREG_TIMEOUT_OPTION)
 317 # Set the max memory for jtreg control vm
 318 JTREG_MEMORY_OPTION = -J-Xmx512m
 319 JTREG_BASIC_OPTIONS += $(JTREG_MEMORY_OPTION)
 320 # Give tests access to JT_JAVA, see JDK-8141609
 321 JTREG_BASIC_OPTIONS += -e:JDK8_HOME=${JT_JAVA}
 322 # Set other vm and test options
 323 JTREG_TEST_OPTIONS = $(JAVA_ARGS:%=-javaoptions:%) $(JAVA_VM_ARGS:%=-vmoption:%)
 324 # Set the GC options for test vms
 325 #JTREG_GC_OPTION = -vmoption:-XX:+UseSerialGC
 326 #JTREG_TEST_OPTIONS += $(JTREG_GC_OPTION)
 327 # Set the max memory for jtreg target test vms
 328 JTREG_TESTVM_MEMORY_OPTION = -vmoption:-Xmx512m
 329 JTREG_TEST_OPTIONS += $(JTREG_TESTVM_MEMORY_OPTION)
 330 
 331 # Make sure jtreg exists
 332 $(JTREG): $(JT_HOME)
 333 
 334 # Run jtreg
 335 jtreg_tests: prep $(PRODUCT_HOME) $(JTREG)
 336         (                                                                    \
 337           ( JT_HOME=$(shell $(GETMIXEDPATH) "$(JT_HOME)");                   \
 338             export JT_HOME;                                                  \
 339             $(shell $(GETMIXEDPATH) "$(JTREG)")                              \
 340               $(JTREG_BASIC_OPTIONS)                                         \
 341               -r:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport")  \
 342               -w:$(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTwork")    \
 343               -jdk:$(shell $(GETMIXEDPATH) "$(PRODUCT_HOME)")                \
 344               $(JTREG_NATIVE_PATH)                                           \
 345               $(JTREG_FAILURE_HANDLER_OPTIONS)                               \
 346               $(JTREG_EXCLUSIONS)                                            \
 347               $(JTREG_TEST_OPTIONS)                                          \
 348               $(TEST_SELECTION)                                                    \
 349           ) ;                                                                \
 350           $(BUNDLE_UP_AND_EXIT)                                              \
 351         ) 2>&1 | $(TEE) $(ABS_TEST_OUTPUT_DIR)/output.txt ; $(TESTEXIT)
 352 
 353 PHONY_LIST += jtreg_tests
 354 
 355 ################################################################
 356 
 357 # Phony targets (e.g. these are not filenames)
 358 .PHONY: all clean prep $(PHONY_LIST)
 359 
 360 ################################################################
   1 #
   2 # Copyright (c) 1995, 2016, Oracle and/or its affiliates. All rights reserved.
   3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4 #
   5 # This code is free software; you can redistribute it and/or modify it
   6 # under the terms of the GNU General Public License version 2 only, as
   7 # published by the Free Software Foundation.  Oracle designates this
   8 # particular file as subject to the "Classpath" exception as provided
   9 # by Oracle in the LICENSE file that accompanied this code.
  10 #
  11 # This code is distributed in the hope that it will be useful, but WITHOUT
  12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14 # version 2 for more details (a copy is included in the LICENSE file that
  15 # accompanied this code).
  16 #
  17 # You should have received a copy of the GNU General Public License version
  18 # 2 along with this work; if not, write to the Free Software Foundation,
  19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20 #
  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
  23 # questions.
  24 #
  25 
  26 default: all
















































































































































  27 
  28 USE_FAILURE_HANDLER := true






































  29 
  30 include ../../test/TestCommon.gmk
  31 
  32 # Default make rule (runs default nashorn tests)
  33 all: nashorn_default
  34         @$(ECHO) "Testing completed successfully"
  35 


























































  36 # ------------------------------------------------------------------
  37 
  38 nashorn_%:
  39         $(ECHO) "Running tests: $@"
  40         for each in $@; do \
  41                 $(MAKE) -j 1 TEST_SELECTION=":$$each" UNIQUE_DIR=$$each jtreg_tests; \
  42         done
  43 













































































< prev index next >