Makefile

Mon, 28 Feb 2011 10:56:10 +0100

author
ohrstrom
date
Mon, 28 Feb 2011 10:56:10 +0100
changeset 313
a1c8b847b753
parent 291
24900a58ab9f
child 317
c6f380693342
permissions
-rw-r--r--

7021753: Add a build times report
Summary: Report the build times at end of a jdkroot build.
Reviewed-by: ohair

duke@2 1 #
ohair@191 2 # Copyright (c) 1995, 2010, Oracle and/or its affiliates. All rights reserved.
duke@2 3 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@2 4 #
duke@2 5 # This code is free software; you can redistribute it and/or modify it
duke@2 6 # under the terms of the GNU General Public License version 2 only, as
ohair@182 7 # published by the Free Software Foundation. Oracle designates this
duke@2 8 # particular file as subject to the "Classpath" exception as provided
ohair@182 9 # by Oracle in the LICENSE file that accompanied this code.
duke@2 10 #
duke@2 11 # This code is distributed in the hope that it will be useful, but WITHOUT
duke@2 12 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@2 13 # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@2 14 # version 2 for more details (a copy is included in the LICENSE file that
duke@2 15 # accompanied this code).
duke@2 16 #
duke@2 17 # You should have received a copy of the GNU General Public License version
duke@2 18 # 2 along with this work; if not, write to the Free Software Foundation,
duke@2 19 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@2 20 #
ohair@182 21 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
ohair@182 22 # or visit www.oracle.com if you need additional information or have any
ohair@182 23 # questions.
duke@2 24 #
duke@2 25
ohair@7 26 BUILD_PARENT_DIRECTORY=.
ohair@7 27
duke@2 28 ifndef TOPDIR
ohair@10 29 TOPDIR:=.
duke@2 30 endif
duke@2 31
duke@2 32 ifndef JDK_TOPDIR
duke@2 33 JDK_TOPDIR=$(TOPDIR)/jdk
duke@2 34 endif
duke@2 35 ifndef JDK_MAKE_SHARED_DIR
duke@2 36 JDK_MAKE_SHARED_DIR=$(JDK_TOPDIR)/make/common/shared
duke@2 37 endif
duke@2 38
ohair@29 39 default: all
ohair@29 40
duke@2 41 include $(JDK_MAKE_SHARED_DIR)/Defs-control.gmk
duke@2 42 include ./make/Defs-internal.gmk
duke@2 43 include ./make/sanity-rules.gmk
duke@2 44 include ./make/hotspot-rules.gmk
duke@2 45 include ./make/langtools-rules.gmk
duke@2 46 include ./make/corba-rules.gmk
duke@2 47 include ./make/jaxp-rules.gmk
duke@2 48 include ./make/jaxws-rules.gmk
duke@2 49 include ./make/jdk-rules.gmk
duke@2 50 include ./make/install-rules.gmk
duke@2 51 include ./make/sponsors-rules.gmk
duke@2 52 include ./make/deploy-rules.gmk
duke@2 53
ohair@288 54 all:: sanity
ohair@29 55
ohair@29 56 ifeq ($(SKIP_FASTDEBUG_BUILD), false)
ohair@29 57 all:: fastdebug_build
ohair@29 58 endif
ohair@29 59
ohair@29 60 ifeq ($(SKIP_DEBUG_BUILD), false)
ohair@29 61 all:: debug_build
ohair@29 62 endif
ohair@29 63
ohair@34 64 all:: all_product_build
ohair@34 65
ohrstrom@313 66 # Everything for a full product build
ohrstrom@313 67 ifeq ($(SKIP_PRODUCT_BUILD), false)
ohair@29 68
ohair@29 69 all_product_build:: product_build
ohair@29 70
ohair@29 71 ifeq ($(BUILD_INSTALL), true)
ohair@29 72 all_product_build:: $(INSTALL)
ohair@29 73 clobber:: install-clobber
ohair@29 74 endif
ohrstrom@313 75
ohair@29 76 ifeq ($(BUILD_SPONSORS), true)
ohair@29 77 all_product_build:: $(SPONSORS)
ohair@29 78 clobber:: sponsors-clobber
ohair@29 79 endif
ohrstrom@313 80
ohair@29 81 ifneq ($(SKIP_COMPARE_IMAGES), true)
ohair@29 82 all_product_build:: compare-image
ohair@29 83 endif
ohair@29 84
ohair@29 85 endif
ohair@29 86
ohrstrom@313 87 define StartTimer
ohrstrom@313 88 $(MKDIR) -p $(BUILDTIMESDIR)
ohrstrom@313 89 $(RM) $(BUILDTIMESDIR)/build_time_*
ohrstrom@313 90 $(call RecordStartTime,TOTAL)
ohrstrom@313 91 endef
ohrstrom@313 92
ohrstrom@313 93 define StopTimer
ohrstrom@313 94 $(if $(REPORT_BUILD_TIMES),$(call RecordEndTime,TOTAL) && $(call ReportBuildTimes,$1),)
ohrstrom@313 95 endef
ohair@29 96
ohair@191 97 # Generic build of basic repo series
ohair@29 98 generic_build_repo_series::
ohair@29 99 $(MKDIR) -p $(OUTPUTDIR)
duke@2 100 $(MKDIR) -p $(OUTPUTDIR)/j2sdk-image
ohrstrom@313 101 @$(call StartTimer)
duke@2 102
ohair@29 103 ifeq ($(BUILD_LANGTOOLS), true)
ohair@29 104 generic_build_repo_series:: langtools
ohair@29 105 clobber:: langtools-clobber
ohair@29 106 endif
ohair@29 107
ohair@29 108 ifeq ($(BUILD_CORBA), true)
ohair@29 109 generic_build_repo_series:: corba
ohair@29 110 clobber:: corba-clobber
ohair@29 111 endif
ohair@29 112
ohair@29 113 ifeq ($(BUILD_JAXP), true)
ohair@29 114 generic_build_repo_series:: jaxp
ohair@29 115 clobber:: jaxp-clobber
ohair@29 116 endif
ohair@29 117
ohair@29 118 ifeq ($(BUILD_JAXWS), true)
ohair@29 119 generic_build_repo_series:: jaxws
ohair@29 120 clobber:: jaxws-clobber
ohair@29 121 endif
ohair@29 122
ohair@29 123 ifeq ($(BUILD_HOTSPOT), true)
ohair@29 124 generic_build_repo_series:: $(HOTSPOT)
ohair@29 125 clobber:: hotspot-clobber
ohair@29 126 endif
ohair@29 127
ohair@29 128 ifeq ($(BUILD_JDK), true)
ohair@29 129 generic_build_repo_series:: $(JDK_JAVA_EXE)
ohair@29 130 clobber:: jdk-clobber
ohair@29 131 endif
ohair@29 132
ohair@29 133 ifeq ($(BUILD_DEPLOY), true)
ohair@29 134 generic_build_repo_series:: $(DEPLOY)
ohair@29 135 clobber:: deploy-clobber
ohair@29 136 endif
ohair@29 137
ohrstrom@313 138 generic_build_repo_series::
ohrstrom@313 139 @$(call StopTimer,$(if $(DEBUG_NAME),$(DEBUG_NAME)_build,all_product_build))
ohrstrom@313 140
ohair@29 141 # The debug build, fastdebug or debug. Needs special handling.
ohair@29 142 # Note that debug builds do NOT do INSTALL steps, but must be done
ohair@29 143 # after the product build and before the INSTALL step of the product build.
ohair@29 144 #
ohair@29 145 # DEBUG_NAME is fastdebug or debug
ohair@29 146 # ALT_OUTPUTDIR is changed to have -debug or -fastdebug suffix
ohair@29 147 # The resulting j2sdk-image is used by the install makefiles to create a
ohair@29 148 # debug install bundle jdk-*-debug-** bundle (tar or zip)
ohair@29 149 # which will install in the debug or fastdebug subdirectory of the
ohair@29 150 # normal product install area.
ohair@29 151 # The install process needs to know what the DEBUG_NAME is, so
ohair@29 152 # look for INSTALL_DEBUG_NAME in the install rules.
ohair@29 153 #
ohair@191 154 # NOTE: On windows, do not use $(ABS_BOOTDIR_OUTPUTDIR)-$(DEBUG_NAME).
ohair@191 155 # Due to the use of short paths in $(ABS_OUTPUTDIR), this may
ohair@191 156 # not be the same location.
ohair@191 157 #
ohair@29 158
ohair@29 159 # Location of fresh bootdir output
ohair@29 160 ABS_BOOTDIR_OUTPUTDIR=$(ABS_OUTPUTDIR)/bootjdk
ohair@29 161 FRESH_BOOTDIR=$(ABS_BOOTDIR_OUTPUTDIR)/j2sdk-image
ohair@191 162 FRESH_DEBUG_BOOTDIR=$(ABS_BOOTDIR_OUTPUTDIR)/../$(PLATFORM)-$(ARCH)-$(DEBUG_NAME)/j2sdk-image
ohair@29 163
ohair@29 164 create_fresh_product_bootdir: FRC
ohair@29 165 $(MAKE) ALT_OUTPUTDIR=$(ABS_BOOTDIR_OUTPUTDIR) \
ohair@144 166 GENERATE_DOCS=false \
ohair@29 167 BOOT_CYCLE_SETTINGS= \
ohair@29 168 build_product_image
ohair@29 169
ohair@29 170 create_fresh_debug_bootdir: FRC
ohair@29 171 $(MAKE) ALT_OUTPUTDIR=$(ABS_BOOTDIR_OUTPUTDIR) \
ohair@144 172 GENERATE_DOCS=false \
ohair@29 173 BOOT_CYCLE_DEBUG_SETTINGS= \
ohair@29 174 build_debug_image
ohair@29 175
ohair@29 176 create_fresh_fastdebug_bootdir: FRC
ohair@29 177 $(MAKE) ALT_OUTPUTDIR=$(ABS_BOOTDIR_OUTPUTDIR) \
ohair@144 178 GENERATE_DOCS=false \
ohair@29 179 BOOT_CYCLE_DEBUG_SETTINGS= \
ohair@29 180 build_fastdebug_image
ohair@29 181
ohair@29 182 # Create boot image?
ohair@29 183 ifeq ($(SKIP_BOOT_CYCLE),false)
ohair@29 184 ifneq ($(PLATFORM)$(ARCH_DATA_MODEL),solaris64)
ohair@29 185 DO_BOOT_CYCLE=true
ohair@29 186 endif
ohair@29 187 endif
ohair@29 188
ohrstrom@313 189
ohrstrom@313 190
ohair@29 191 ifeq ($(DO_BOOT_CYCLE),true)
ohair@29 192
ohair@29 193 # Create the bootdir to use in the build
ohair@29 194 product_build:: create_fresh_product_bootdir
ohair@29 195 debug_build:: create_fresh_debug_bootdir
ohair@29 196 fastdebug_build:: create_fresh_fastdebug_bootdir
ohair@29 197
ohair@29 198 # Define variables to be used now for the boot jdk
ohair@29 199 BOOT_CYCLE_SETTINGS= \
ohair@29 200 ALT_BOOTDIR=$(FRESH_BOOTDIR) \
ohair@29 201 ALT_JDK_IMPORT_PATH=$(FRESH_BOOTDIR)
ohair@29 202 BOOT_CYCLE_DEBUG_SETTINGS= \
ohair@29 203 ALT_BOOTDIR=$(FRESH_DEBUG_BOOTDIR) \
ohair@29 204 ALT_JDK_IMPORT_PATH=$(FRESH_DEBUG_BOOTDIR)
ohair@29 205
ohair@29 206 else
ohair@29 207
ohair@29 208 # Use the supplied ALT_BOOTDIR as the boot
ohair@29 209 BOOT_CYCLE_SETTINGS=
ohair@29 210 BOOT_CYCLE_DEBUG_SETTINGS=
ohair@29 211
ohair@29 212 endif
ohair@29 213
ohair@29 214 build_product_image:
ohair@29 215 $(MAKE) \
ohair@29 216 SKIP_FASTDEBUG_BUILD=true \
ohair@29 217 SKIP_DEBUG_BUILD=true \
ohair@29 218 $(BOOT_CYCLE_SETTINGS) \
ohair@29 219 generic_build_repo_series
ohair@29 220
ohair@191 221 # NOTE: On windows, do not use $(ABS_OUTPUTDIR)-$(DEBUG_NAME).
ohair@191 222 # Due to the use of short paths in $(ABS_OUTPUTDIR), this may
ohair@191 223 # not be the same location.
ohair@191 224
ohair@29 225 generic_debug_build:
ohair@29 226 $(MAKE) \
ohair@191 227 ALT_OUTPUTDIR=$(ABS_OUTPUTDIR)/../$(PLATFORM)-$(ARCH)-$(DEBUG_NAME) \
ohair@29 228 DEBUG_NAME=$(DEBUG_NAME) \
ohair@144 229 GENERATE_DOCS=false \
ohair@29 230 $(BOOT_CYCLE_DEBUG_SETTINGS) \
ohair@29 231 generic_build_repo_series
ohair@29 232
ohair@29 233 build_debug_image:
ohair@29 234 $(MAKE) DEBUG_NAME=debug generic_debug_build
ohair@29 235
ohair@29 236 build_fastdebug_image:
ohair@29 237 $(MAKE) DEBUG_NAME=fastdebug generic_debug_build
ohair@29 238
ohair@29 239 # Build final image
ohair@29 240 product_build:: build_product_image
ohair@29 241 debug_build:: build_debug_image
ohair@29 242 fastdebug_build:: build_fastdebug_image
ohair@29 243
ohrstrom@313 244 clobber:: REPORT_BUILD_TIMES=
ohrstrom@313 245 clobber::
duke@2 246 $(RM) -r $(OUTPUTDIR)/*
ohair@191 247 $(RM) -r $(OUTPUTDIR)/../$(PLATFORM)-$(ARCH)-debug/*
ohair@191 248 $(RM) -r $(OUTPUTDIR)/../$(PLATFORM)-$(ARCH)-fastdebug/*
duke@2 249 -($(RMDIR) -p $(OUTPUTDIR) > $(DEV_NULL) 2>&1; $(TRUE))
duke@2 250
duke@2 251 clean: clobber
duke@2 252
ohair@29 253 #
ohair@29 254 # Dev builds
ohair@29 255 #
ohair@29 256
ohair@29 257 dev : dev-build
ohair@29 258
ohair@29 259 dev-build:
ohair@29 260 $(MAKE) DEV_ONLY=true all
ohair@29 261 dev-sanity:
ohair@29 262 $(MAKE) DEV_ONLY=true sanity
ohair@29 263 dev-clobber:
ohair@29 264 $(MAKE) DEV_ONLY=true clobber
duke@2 265
duke@2 266 #
duke@2 267 # Quick jdk verification build
duke@2 268 #
duke@2 269 jdk_only:
duke@2 270 $(MAKE) SKIP_FASTDEBUG_BUILD=true BUILD_HOTSPOT=false all
duke@2 271
duke@2 272
duke@2 273 #
duke@2 274 # Quick jdk verification fastdebug build
duke@2 275 #
duke@2 276 jdk_fastdebug_only:
duke@2 277 $(MAKE) DEBUG_NAME=fastdebug BUILD_HOTSPOT=false BUILD_DEPLOY=false \
duke@2 278 BUILD_INSTALL=false BUILD_SPONSORS=false generic_debug_build
duke@2 279
duke@2 280 #
duke@2 281 # Quick deploy verification fastdebug build
duke@2 282 #
duke@2 283 deploy_fastdebug_only:
duke@2 284 $(MAKE) \
duke@2 285 DEBUG_NAME=fastdebug \
duke@2 286 BUILD_HOTSPOT=false \
duke@2 287 BUILD_JDK=false \
duke@2 288 BUILD_LANGTOOLS=false \
duke@2 289 BUILD_CORBA=false \
duke@2 290 BUILD_JAXP=false \
duke@2 291 BUILD_JAXWS=false \
duke@2 292 BUILD_INSTALL=false \
duke@2 293 BUILD_SPONSORS=false \
duke@2 294 generic_debug_build
duke@2 295
duke@2 296 #
duke@2 297 # Product build (skip debug builds)
duke@2 298 #
duke@2 299 product_only:
duke@2 300 $(MAKE) SKIP_FASTDEBUG_BUILD=true all
duke@2 301
duke@2 302 #
duke@2 303 # Check target
duke@2 304 #
duke@2 305
duke@2 306 check: variable_check
duke@2 307
duke@2 308 #
duke@2 309 # Help target
duke@2 310 #
duke@2 311 help: intro_help target_help variable_help notes_help examples_help
duke@2 312
duke@2 313 # Intro help message
duke@2 314 intro_help:
duke@2 315 @$(ECHO) "\
duke@2 316 Makefile for the JDK builds (all the JDK). \n\
duke@2 317 "
duke@2 318
duke@2 319 # Target help
duke@2 320 target_help:
duke@2 321 @$(ECHO) "\
duke@2 322 --- Common Targets --- \n\
duke@2 323 all -- build the core JDK (default target) \n\
duke@2 324 help -- Print out help information \n\
duke@2 325 check -- Check make variable values for correctness \n\
duke@2 326 sanity -- Perform detailed sanity checks on system and settings \n\
duke@2 327 fastdebug_build -- build the core JDK in 'fastdebug' mode (-g -O) \n\
duke@2 328 debug_build -- build the core JDK in 'debug' mode (-g) \n\
duke@2 329 clean -- remove all built and imported files \n\
duke@2 330 clobber -- same as clean \n\
duke@2 331 "
duke@2 332
duke@2 333 # Variable help (only common ones used by this Makefile)
duke@2 334 variable_help: variable_help_intro variable_list variable_help_end
duke@2 335 variable_help_intro:
duke@2 336 @$(ECHO) "--- Common Variables ---"
duke@2 337 variable_help_end:
duke@2 338 @$(ECHO) " "
duke@2 339
duke@2 340 # One line descriptions for the variables
duke@2 341 OUTPUTDIR.desc = Output directory
duke@2 342 PARALLEL_COMPILE_JOBS.desc = Solaris/Linux parallel compile run count
duke@2 343 SLASH_JAVA.desc = Root of all build tools, e.g. /java or J:
duke@2 344 BOOTDIR.desc = JDK used to boot the build
duke@2 345 JDK_IMPORT_PATH.desc = JDK used to import components of the build
duke@2 346 COMPILER_PATH.desc = Compiler install directory
duke@2 347 CACERTS_FILE.desc = Location of certificates file
duke@2 348 DEVTOOLS_PATH.desc = Directory containing zip and gnumake
duke@2 349 CUPS_HEADERS_PATH.desc = Include directory location for CUPS header files
duke@2 350 DXSDK_PATH.desc = Root directory of DirectX SDK
duke@2 351
duke@2 352 # Make variables to print out (description and value)
duke@2 353 VARIABLE_PRINTVAL_LIST += \
duke@2 354 OUTPUTDIR \
duke@2 355 PARALLEL_COMPILE_JOBS \
duke@2 356 SLASH_JAVA \
duke@2 357 BOOTDIR \
duke@2 358 JDK_IMPORT_PATH \
duke@2 359 COMPILER_PATH \
duke@2 360 CACERTS_FILE \
duke@2 361 DEVTOOLS_PATH
duke@2 362
duke@2 363 # Make variables that should refer to directories that exist
duke@2 364 VARIABLE_CHECKDIR_LIST += \
duke@2 365 SLASH_JAVA \
duke@2 366 BOOTDIR \
duke@2 367 JDK_IMPORT_PATH \
duke@2 368 COMPILER_PATH \
duke@2 369 DEVTOOLS_PATH
duke@2 370
duke@2 371 # Make variables that should refer to files that exist
duke@2 372 VARIABLE_CHECKFIL_LIST += \
duke@2 373 CACERTS_FILE
duke@2 374
duke@2 375 # Some are windows specific
duke@2 376 ifeq ($(PLATFORM), windows)
duke@2 377
duke@2 378 VARIABLE_PRINTVAL_LIST += \
ohair@291 379 DXSDK_PATH
duke@2 380
duke@2 381 VARIABLE_CHECKDIR_LIST += \
ohair@291 382 DXSDK_PATH
duke@2 383
duke@2 384 endif
duke@2 385
duke@2 386 # For pattern rules below, so all are treated the same
duke@2 387 DO_PRINTVAL_LIST=$(VARIABLE_PRINTVAL_LIST:%=%.printval)
duke@2 388 DO_CHECKDIR_LIST=$(VARIABLE_CHECKDIR_LIST:%=%.checkdir)
duke@2 389 DO_CHECKFIL_LIST=$(VARIABLE_CHECKFIL_LIST:%=%.checkfil)
duke@2 390
duke@2 391 # Complete variable check
duke@2 392 variable_check: $(DO_CHECKDIR_LIST) $(DO_CHECKFIL_LIST)
duke@2 393 variable_list: $(DO_PRINTVAL_LIST) variable_check
duke@2 394
duke@2 395 # Pattern rule for printing out a variable
duke@2 396 %.printval:
duke@2 397 @$(ECHO) " ALT_$* - $($*.desc)"
duke@2 398 @$(ECHO) " \t $*=$($*)"
duke@2 399
duke@2 400 # Pattern rule for checking to see if a variable with a directory exists
duke@2 401 %.checkdir:
duke@2 402 @if [ ! -d $($*) ] ; then \
duke@2 403 $(ECHO) "WARNING: $* does not exist, try $(MAKE) sanity"; \
duke@2 404 fi
duke@2 405
duke@2 406 # Pattern rule for checking to see if a variable with a file exists
duke@2 407 %.checkfil:
duke@2 408 @if [ ! -f $($*) ] ; then \
duke@2 409 $(ECHO) "WARNING: $* does not exist, try $(MAKE) sanity"; \
duke@2 410 fi
duke@2 411
duke@2 412 # Misc notes on help
duke@2 413 notes_help:
duke@2 414 @$(ECHO) "\
duke@2 415 --- Notes --- \n\
duke@2 416 - All builds use same output directory unless overridden with \n\
duke@2 417 \t ALT_OUTPUTDIR=<dir>, changing from product to fastdebug you may want \n\
duke@2 418 \t to use the clean target first. \n\
duke@2 419 - JDK_IMPORT_PATH must refer to a compatible build, not all past promoted \n\
duke@2 420 \t builds or previous release JDK builds will work. \n\
duke@2 421 - The fastest builds have been when the sources and the BOOTDIR are on \n\
duke@2 422 \t local disk. \n\
duke@2 423 "
duke@2 424
duke@2 425 examples_help:
duke@2 426 @$(ECHO) "\
duke@2 427 --- Examples --- \n\
duke@2 428 $(MAKE) fastdebug_build \n\
duke@2 429 $(MAKE) ALT_OUTPUTDIR=/tmp/foobar all \n\
duke@2 430 $(MAKE) ALT_OUTPUTDIR=/tmp/foobar fastdebug_build \n\
duke@2 431 $(MAKE) ALT_OUTPUTDIR=/tmp/foobar all \n\
duke@2 432 $(MAKE) ALT_BOOTDIR=/opt/java/jdk1.5.0 \n\
duke@2 433 $(MAKE) ALT_JDK_IMPORT_PATH=/opt/java/jdk1.6.0 \n\
duke@2 434 "
duke@2 435
duke@2 436 ################################################################
ohair@278 437 # Source bundling
duke@2 438 ################################################################
duke@2 439 ifeq ($(BUNDLE_RULES_AVAILABLE), true)
duke@2 440 include $(BUNDLE_RULES)
duke@2 441 endif
duke@2 442
duke@2 443 ################################################################
ohair@191 444 # rule to test
ohair@191 445 ################################################################
ohair@191 446
ohair@224 447 .NOTPARALLEL: test_run
ohair@191 448
ohair@224 449 test:
ohair@224 450 $(MAKE) test_run
ohair@224 451
ohair@224 452 test_run: test_clean test_start test_summary
ohair@191 453
ohair@191 454 test_start:
ohair@191 455 @$(ECHO) "Tests started at `$(DATE)`"
ohair@191 456
ohair@191 457 test_clean:
ohair@191 458 $(RM) $(OUTPUTDIR)/test_failures.txt $(OUTPUTDIR)/test_log.txt
ohair@191 459
ohair@191 460 test_summary: $(OUTPUTDIR)/test_failures.txt
ohair@191 461 @$(ECHO) "#################################################"
ohair@191 462 @$(ECHO) "Tests completed at `$(DATE)`"
ohair@191 463 @( $(EGREP) '^TEST STATS:' $(OUTPUTDIR)/test_log.txt \
ohair@191 464 || $(ECHO) "No TEST STATS seen in log" )
ohair@191 465 @$(ECHO) "For complete details see: $(OUTPUTDIR)/test_log.txt"
ohair@191 466 @$(ECHO) "#################################################"
ohair@191 467 @if [ -s $< ] ; then \
ohair@191 468 $(ECHO) "ERROR: Test failure count: `$(CAT) $< | $(WC) -l`"; \
ohair@191 469 $(CAT) $<; \
ohair@191 470 exit 1; \
ohair@191 471 else \
ohair@191 472 $(ECHO) "Success! No failures detected"; \
ohair@191 473 fi
ohair@191 474
ohair@191 475 # Get failure list from log
ohair@191 476 $(OUTPUTDIR)/test_failures.txt: $(OUTPUTDIR)/test_log.txt
ohair@191 477 @$(RM) $@
ohair@224 478 @( $(EGREP) '^FAILED:' $< || $(ECHO) "" ) | $(NAWK) 'length>0' > $@
ohair@191 479
ohair@191 480 # Get log file of all tests run
ohair@191 481 JDK_TO_TEST := $(shell \
ohair@191 482 if [ -d "$(ABS_OUTPUTDIR)/j2sdk-image" ] ; then \
ohair@191 483 $(ECHO) "$(ABS_OUTPUTDIR)/j2sdk-image"; \
ohair@191 484 elif [ -d "$(ABS_OUTPUTDIR)/bin" ] ; then \
ohair@191 485 $(ECHO) "$(ABS_OUTPUTDIR)"; \
ohair@191 486 elif [ "$(PRODUCT_HOME)" != "" -a -d "$(PRODUCT_HOME)/bin" ] ; then \
ohair@191 487 $(ECHO) "$(PRODUCT_HOME)"; \
ohair@191 488 fi \
ohair@191 489 )
ohair@224 490 TEST_TARGETS=all
ohair@191 491 $(OUTPUTDIR)/test_log.txt:
ohair@191 492 $(RM) $@
ohair@224 493 ( $(CD) test && \
ohair@224 494 $(MAKE) NO_STOPPING=- PRODUCT_HOME=$(JDK_TO_TEST) $(TEST_TARGETS) \
ohair@191 495 ) | tee $@
ohair@191 496
ohair@191 497 ################################################################
duke@2 498 # JPRT rule to build
duke@2 499 ################################################################
duke@2 500
duke@2 501 include ./make/jprt.gmk
duke@2 502
duke@2 503 ################################################################
duke@2 504 # PHONY
duke@2 505 ################################################################
duke@2 506
ohair@224 507 .PHONY: all test test_run test_start test_summary test_clean \
ohair@29 508 generic_build_repo_series \
ohair@29 509 what clobber insane \
ohair@29 510 dev dev-build dev-sanity dev-clobber \
ohair@29 511 product_build \
ohair@29 512 fastdebug_build \
ohair@29 513 debug_build \
ohair@29 514 build_product_image \
ohair@29 515 build_debug_image \
ohair@29 516 build_fastdebug_image \
ohair@29 517 create_fresh_product_bootdir \
ohair@29 518 create_fresh_debug_bootdir \
ohair@29 519 create_fresh_fastdebug_bootdir \
ohair@29 520 generic_debug_build
duke@2 521
ohair@7 522 # Force target
ohair@7 523 FRC:
ohair@7 524

mercurial