Makefile revision 1814:1e7049278c4c
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
35CO=
36GET=
37
38# Utilities used
39AWK       = awk
40CAT       = cat
41CD        = cd
42CHMOD     = chmod
43CP        = cp
44CUT       = cut
45DIRNAME   = dirname
46ECHO      = echo
47EGREP     = egrep
48EXPAND    = expand
49FIND      = find
50MKDIR     = mkdir
51PWD       = pwd
52SED       = sed
53SORT      = sort
54TEE       = tee
55UNAME     = uname
56UNIQ      = uniq
57WC        = wc
58ZIP       = zip
59
60# Get OS name from uname (Cygwin inexplicably adds _NT-5.1)
61UNAME_S := $(shell $(UNAME) -s | $(CUT) -f1 -d_)
62
63# Commands to run on paths to make mixed paths for java on windows
64ifeq ($(UNAME_S), CYGWIN)
65  # Location of developer shared files
66  SLASH_JAVA = J:
67  GETMIXEDPATH = cygpath -m
68else
69  # Location of developer shared files
70  SLASH_JAVA = /java
71
72  GETMIXEDPATH=$(ECHO)
73endif
74
75# Root of this test area (important to use full paths in some places)
76TEST_ROOT := $(shell $(PWD))
77
78# Root of all test results
79ifdef TEST_OUTPUT_DIR
80  $(shell $(MKDIR) -p $(TEST_OUTPUT_DIR)/jtreg)
81  ABS_TEST_OUTPUT_DIR := \
82    $(shell $(CD) $(TEST_OUTPUT_DIR)/jtreg && $(PWD))
83else
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)
92endif
93
94# Expect JPRT to set PRODUCT_HOME (the product or jdk in this case to test)
95ifndef 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)
106endif
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
111ifdef JPRT_PRODUCT_ARGS
112  JAVA_ARGS = $(JPRT_PRODUCT_ARGS)
113endif
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, ...).
117ifdef JPRT_PRODUCT_VM_ARGS
118  JAVA_VM_ARGS = $(JPRT_PRODUCT_VM_ARGS)
119endif
120
121# jtreg failure handler config
122ifeq ($(FAILURE_HANDLER_DIR), )
123  ifneq ($(TESTNATIVE_DIR), )
124    FAILURE_HANDLER_DIR := $(TESTNATIVE_DIR)/failure_handler
125  endif
126endif
127ifneq ($(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
138endif
139
140# Expect JPRT to set JPRT_ARCHIVE_BUNDLE (path to zip bundle for results)
141ifdef JPRT_ARCHIVE_BUNDLE
142  ARCHIVE_BUNDLE = $(JPRT_ARCHIVE_BUNDLE)
143else
144  ARCHIVE_BUNDLE = $(ABS_TEST_OUTPUT_DIR)/ARCHIVE_BUNDLE.zip
145endif
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.
149ZIP_UP_RESULTS = ( $(MKDIR) -p `$(DIRNAME) $(ARCHIVE_BUNDLE)`     \
150	           && $(CD) $(ABS_TEST_OUTPUT_DIR)             \
151	           && $(CHMOD) -R a+r . \
152	           && $(ZIP) -q -r $(ARCHIVE_BUNDLE) . )
153
154# important results files
155SUMMARY_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/JTreport/text/summary.txt")
156STATS_TXT_NAME = Stats.txt
157STATS_TXT = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/$(STATS_TXT_NAME)")
158RUNLIST   = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/runlist.txt")
159PASSLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/passlist.txt")
160FAILLIST  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/faillist.txt")
161EXITCODE  = $(shell $(GETMIXEDPATH) "$(ABS_TEST_OUTPUT_DIR)/exitcode.txt")
162
163TESTEXIT = \
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
172BUNDLE_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)
215all: 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.
230prep:
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
239clean:
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)
248ifndef 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
253endif
254
255# Problematic tests to be excluded
256PROBLEM_LISTS=$(call MixedDirs,$(wildcard ProblemList.txt closed/ProblemList.txt))
257
258# Create exclude list for this platform and arch
259ifdef NO_EXCLUDES
260  JTREG_EXCLUSIONS =
261else
262  JTREG_EXCLUSIONS = $(PROBLEM_LISTS:%=-exclude:%)
263endif
264
265# convert list of directories to dos paths
266define MixedDirs
267$(foreach i,$1,$(shell $(GETMIXEDPATH) "${i}"))
268endef
269
270define SummaryInfo
271$(ECHO) "########################################################"
272$(CAT) $(?:%=$(ABS_TEST_OUTPUT_DIR)/%/$(STATS_TXT_NAME))
273$(ECHO) "########################################################"
274endef
275
276# ------------------------------------------------------------------
277
278nashorn_%:
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
287ifdef TESTDIRS
288  TEST_SELECTION = $(TESTDIRS)
289endif
290
291ifdef CONCURRENCY
292  JTREG_BASIC_OPTIONS += -concurrency:$(CONCURRENCY)
293endif
294ifdef EXTRA_JTREG_OPTIONS
295  JTREG_BASIC_OPTIONS += $(EXTRA_JTREG_OPTIONS)
296endif
297
298# Default JTREG to run
299JTREG = $(JT_HOME)/bin/jtreg
300# run in agentvm mode
301JTREG_BASIC_OPTIONS += -agentvm
302# Only run automatic tests
303JTREG_BASIC_OPTIONS += -a
304# Always turn on assertions
305JTREG_ASSERT_OPTION = -ea -esa
306JTREG_BASIC_OPTIONS += $(JTREG_ASSERT_OPTION)
307# Report details on all failed or error tests, times too
308JTREG_BASIC_OPTIONS += -v:fail,error,time
309# Retain all files for failing tests
310JTREG_BASIC_OPTIONS += -retain:fail,error
311# Ignore tests are not run and completely silent about it
312JTREG_IGNORE_OPTION = -ignore:quiet
313JTREG_BASIC_OPTIONS += $(JTREG_IGNORE_OPTION)
314# Multiple by 4 the timeout numbers
315JTREG_TIMEOUT_OPTION =  -timeoutFactor:4
316JTREG_BASIC_OPTIONS += $(JTREG_TIMEOUT_OPTION)
317# Set the max memory for jtreg control vm
318JTREG_MEMORY_OPTION = -J-Xmx512m
319JTREG_BASIC_OPTIONS += $(JTREG_MEMORY_OPTION)
320# Give tests access to JT_JAVA, see JDK-8141609
321JTREG_BASIC_OPTIONS += -e:JDK8_HOME=${JT_JAVA}
322# Set other vm and test options
323JTREG_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
328JTREG_TESTVM_MEMORY_OPTION = -vmoption:-Xmx512m
329JTREG_TEST_OPTIONS += $(JTREG_TESTVM_MEMORY_OPTION)
330
331# Make sure jtreg exists
332$(JTREG): $(JT_HOME)
333
334# Run jtreg
335jtreg_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
353PHONY_LIST += jtreg_tests
354
355################################################################
356
357# Phony targets (e.g. these are not filenames)
358.PHONY: all clean prep $(PHONY_LIST)
359
360################################################################
361