|
|
|
-include config.mk
|
|
|
|
|
|
|
|
BUILDTYPE ?= Release
|
|
|
|
PYTHON ?= python
|
|
|
|
DESTDIR ?=
|
|
|
|
SIGN ?=
|
|
|
|
PREFIX ?= /usr/local
|
|
|
|
FLAKY_TESTS ?= run
|
|
|
|
TEST_CI_ARGS ?=
|
|
|
|
STAGINGSERVER ?= node-www
|
|
|
|
LOGLEVEL ?= silent
|
|
|
|
OSTYPE := $(shell uname -s | tr '[A-Z]' '[a-z]')
|
|
|
|
COVTESTS ?= test
|
|
|
|
GTEST_FILTER ?= "*"
|
|
|
|
|
|
|
|
ifdef JOBS
|
|
|
|
PARALLEL_ARGS = -j $(JOBS)
|
|
|
|
endif
|
|
|
|
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
ifdef QUICKCHECK
|
|
|
|
QUICKCHECK_ARG := --quickcheck
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifdef ENABLE_V8_TAP
|
|
|
|
TAP_V8 := --junitout $(PWD)/v8-tap.xml
|
|
|
|
TAP_V8_INTL := --junitout $(PWD)/v8-intl-tap.xml
|
|
|
|
TAP_V8_BENCHMARKS := --junitout $(PWD)/v8-benchmarks-tap.xml
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
endif
|
|
|
|
|
|
|
|
V8_TEST_OPTIONS = $(V8_EXTRA_TEST_OPTIONS)
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
ifdef DISABLE_V8_I18N
|
|
|
|
V8_TEST_OPTIONS += --noi18n
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
V8_BUILD_OPTIONS += i18nsupport=off
|
|
|
|
endif
|
|
|
|
|
|
|
|
BUILDTYPE_LOWER := $(shell echo $(BUILDTYPE) | tr '[A-Z]' '[a-z]')
|
|
|
|
|
|
|
|
# Determine EXEEXT
|
|
|
|
EXEEXT := $(shell $(PYTHON) -c \
|
|
|
|
"import sys; print('.exe' if sys.platform == 'win32' else '')")
|
|
|
|
|
|
|
|
NODE_EXE = node$(EXEEXT)
|
|
|
|
NODE ?= ./$(NODE_EXE)
|
|
|
|
NODE_G_EXE = node_g$(EXEEXT)
|
|
|
|
NPM ?= ./deps/npm/bin/npm-cli.js
|
|
|
|
|
|
|
|
# Flags for packaging.
|
|
|
|
BUILD_DOWNLOAD_FLAGS ?= --download=all
|
|
|
|
BUILD_INTL_FLAGS ?= --with-intl=small-icu
|
|
|
|
BUILD_RELEASE_FLAGS ?= $(BUILD_DOWNLOAD_FLAGS) $(BUILD_INTL_FLAGS)
|
|
|
|
|
|
|
|
# Default to verbose builds.
|
|
|
|
# To do quiet/pretty builds, run `make V=` to set V to an empty string,
|
|
|
|
# or set the V environment variable to an empty string.
|
|
|
|
V ?= 1
|
|
|
|
|
|
|
|
# BUILDTYPE=Debug builds both release and debug builds. If you want to compile
|
|
|
|
# just the debug build, run `make -C out BUILDTYPE=Debug` instead.
|
|
|
|
ifeq ($(BUILDTYPE),Release)
|
|
|
|
all: out/Makefile $(NODE_EXE)
|
|
|
|
else
|
|
|
|
all: out/Makefile $(NODE_EXE) $(NODE_G_EXE)
|
|
|
|
endif
|
|
|
|
|
|
|
|
# The .PHONY is needed to ensure that we recursively use the out/Makefile
|
|
|
|
# to check for changes.
|
|
|
|
.PHONY: $(NODE_EXE) $(NODE_G_EXE)
|
|
|
|
|
|
|
|
# The -r/-L check stops it recreating the link if it is already in place,
|
|
|
|
# otherwise $(NODE_EXE) being a .PHONY target means it is always re-run.
|
|
|
|
# Without the check there is a race condition between the link being deleted
|
|
|
|
# and recreated which can break the addons build when running test-ci
|
|
|
|
# See comments on the build-addons target for some more info
|
|
|
|
$(NODE_EXE): config.gypi out/Makefile
|
|
|
|
$(MAKE) -C out BUILDTYPE=Release V=$(V)
|
|
|
|
if [ ! -r $@ -o ! -L $@ ]; then ln -fs out/Release/$(NODE_EXE) $@; fi
|
|
|
|
|
|
|
|
$(NODE_G_EXE): config.gypi out/Makefile
|
|
|
|
$(MAKE) -C out BUILDTYPE=Debug V=$(V)
|
|
|
|
if [ ! -r $@ -o ! -L $@ ]; then ln -fs out/Debug/$(NODE_EXE) $@; fi
|
|
|
|
|
|
|
|
out/Makefile: common.gypi deps/uv/uv.gyp deps/http_parser/http_parser.gyp \
|
|
|
|
deps/zlib/zlib.gyp deps/v8/gypfiles/toolchain.gypi \
|
|
|
|
deps/v8/gypfiles/features.gypi deps/v8/src/v8.gyp node.gyp \
|
|
|
|
config.gypi
|
|
|
|
$(PYTHON) tools/gyp_node.py -f make
|
|
|
|
|
|
|
|
config.gypi: configure
|
|
|
|
$(error Missing or stale $@, please run ./$<)
|
|
|
|
|
|
|
|
install: all
|
|
|
|
$(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
|
|
|
|
|
|
|
|
uninstall:
|
|
|
|
$(PYTHON) tools/install.py $@ '$(DESTDIR)' '$(PREFIX)'
|
|
|
|
|
|
|
|
clean:
|
|
|
|
-rm -rf out/Makefile $(NODE_EXE) $(NODE_G_EXE) out/$(BUILDTYPE)/$(NODE_EXE) \
|
|
|
|
out/$(BUILDTYPE)/node.exp
|
|
|
|
@if [ -d out ]; then find out/ -name '*.o' -o -name '*.a' -o -name '*.d' | xargs rm -rf; fi
|
|
|
|
-rm -rf node_modules
|
|
|
|
@if [ -d deps/icu ]; then echo deleting deps/icu; rm -rf deps/icu; fi
|
|
|
|
-rm -f test.tap
|
|
|
|
|
|
|
|
distclean:
|
|
|
|
-rm -rf out
|
|
|
|
-rm -f config.gypi icu_config.gypi config_fips.gypi
|
|
|
|
-rm -f config.mk
|
|
|
|
-rm -rf $(NODE_EXE) $(NODE_G_EXE)
|
|
|
|
-rm -rf node_modules
|
build: i18n: add icu config options
Make "--with-intl=none" the default and add "intl-none" option to
vcbuild.bat.
If icu data is missing print a warning unless either --download=all or
--download=icu is set. If set then automatically download, verify (MD5)
and unpack the ICU data if not already available.
There's a "list" of URLs being used, but right now only the first is
picked up. The logic works something like this:
* If there is no directory deps/icu,
* If no zip file (currently icu4c-54_1-src.zip),
* Download zip file (icu-project.org -> sf.net)
* Verify the MD5 sum of the zipfile
* If bad, print error and exit
* Unpack the zipfile into deps/icu
* If deps/icu now exists, use it, else fail with help text
Add the configuration option "--with-icu-source=..."
Usage:
* --with-icu-source=/path/to/my/other/icu
* --with-icu-source=/path/to/icu54.zip
* --with-icu-source=/path/to/icu54.tgz
* --with-icu-source=http://example.com/icu54.tar.bz2
Add the configuration option "--with-icu-locals=...". Allows choosing
which locales are used in the "small-icu" case.
Example:
configure --with-intl=small-icu --with-icu-locales=tlh,grc,nl
(Also note that as of this writing, neither Klingon nor Ancient Greek
are in upstream CLDR data. Serving suggestion only.)
Don't use hard coded ../../out paths on windows. This was suggested by
@misterdjules as it causes test failures. With this fix, "out" is no
longer created on windows and the following can run properly:
python tools/test.py simple
Reduce space by about 1MB with ICU 54 (over without this patch). Also
trims a few other source files, but only conditional on the exact ICU
version used. This is to future-proof - a file that is unneeded now may
be needed in future ICUs.
Also:
* Update distclean to remove icu related files
* Refactor some code into tools/configure.d/nodedownload.py
* Update docs
* Add test
PR-URL: https://github.com/joyent/node/pull/8719
Fixes: https://github.com/joyent/node/issues/7676#issuecomment-64704230
[trev.norris@gmail.com small change to test's whitespace and logic]
Signed-off-by: Trevor Norris <trev.norris@gmail.com>
10 years ago
|
|
|
-rm -rf deps/icu
|
|
|
|
-rm -rf deps/icu4c*.tgz deps/icu4c*.zip deps/icu-tmp
|
|
|
|
-rm -f $(BINARYTAR).* $(TARBALL).*
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
-rm -rf deps/v8/testing/gmock
|
|
|
|
|
|
|
|
check: test
|
|
|
|
|
|
|
|
# Remove files generated by running coverage, put the non-instrumented lib back
|
|
|
|
# in place
|
|
|
|
coverage-clean:
|
|
|
|
if [ -d lib_ ]; then rm -rf lib; mv lib_ lib; fi
|
|
|
|
-rm -rf node_modules
|
|
|
|
-rm -rf gcovr testing
|
|
|
|
-rm -rf out/$(BUILDTYPE)/.coverage
|
|
|
|
-rm -rf .cov_tmp coverage
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/*.gcda
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/tracing/*.gcda
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/*.gcno
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/tracing*.gcno
|
|
|
|
|
|
|
|
# Build and test with code coverage reporting. Leave the lib directory
|
|
|
|
# instrumented for any additional runs the user may want to make.
|
|
|
|
# For C++ coverage reporting, this needs to be run in conjunction with configure
|
|
|
|
# --coverage. html coverage reports will be created under coverage/
|
|
|
|
|
|
|
|
coverage: coverage-test
|
|
|
|
|
|
|
|
coverage-build: all
|
|
|
|
mkdir -p node_modules
|
|
|
|
if [ ! -d node_modules/istanbul-merge ]; then \
|
|
|
|
$(NODE) ./deps/npm install istanbul-merge; fi
|
|
|
|
if [ ! -d node_modules/nyc ]; then $(NODE) ./deps/npm install nyc; fi
|
|
|
|
if [ ! -d gcovr ]; then git clone --depth=1 \
|
|
|
|
--single-branch git://github.com/gcovr/gcovr.git; fi
|
|
|
|
if [ ! -d testing ]; then git clone --depth=1 \
|
|
|
|
--single-branch https://github.com/nodejs/testing.git; fi
|
|
|
|
if [ ! -f gcovr/scripts/gcovr.orig ]; then \
|
|
|
|
(cd gcovr && patch -N -p1 < \
|
|
|
|
"$(CURDIR)/testing/coverage/gcovr-patches.diff"); fi
|
|
|
|
if [ -d lib_ ]; then rm -rf lib; mv lib_ lib; fi
|
|
|
|
mv lib lib_
|
|
|
|
$(NODE) ./node_modules/.bin/nyc instrument lib_/ lib/
|
|
|
|
$(MAKE)
|
|
|
|
|
|
|
|
coverage-test: coverage-build
|
|
|
|
-rm -rf out/$(BUILDTYPE)/.coverage
|
|
|
|
-rm -rf .cov_tmp
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/*.gcda
|
|
|
|
-rm -f out/$(BUILDTYPE)/obj.target/node/src/tracing/*.gcda
|
|
|
|
-$(MAKE) $(COVTESTS)
|
|
|
|
mv lib lib__
|
|
|
|
mv lib_ lib
|
|
|
|
mkdir -p coverage .cov_tmp
|
|
|
|
$(NODE) ./node_modules/.bin/istanbul-merge --out \
|
|
|
|
.cov_tmp/libcov.json 'out/Release/.coverage/coverage-*.json'
|
|
|
|
(cd lib && .$(NODE) ../node_modules/.bin/nyc report \
|
|
|
|
--temp-directory "$(CURDIR)/.cov_tmp" -r html \
|
|
|
|
--report-dir "../coverage")
|
|
|
|
-(cd out && "../gcovr/scripts/gcovr" --gcov-exclude='.*deps' \
|
|
|
|
--gcov-exclude='.*usr' -v -r Release/obj.target/node \
|
|
|
|
--html --html-detail -o ../coverage/cxxcoverage.html)
|
|
|
|
mv lib lib_
|
|
|
|
mv lib__ lib
|
|
|
|
@echo -n "Javascript coverage %: "
|
|
|
|
@grep -B1 Lines coverage/index.html | head -n1 \
|
|
|
|
| sed 's/<[^>]*>//g'| sed 's/ //g'
|
|
|
|
@echo -n "C++ coverage %: "
|
|
|
|
@grep -A3 Lines coverage/cxxcoverage.html | grep style \
|
|
|
|
| sed 's/<[^>]*>//g'| sed 's/ //g'
|
|
|
|
|
|
|
|
cctest: all
|
|
|
|
@out/$(BUILDTYPE)/$@ --gtest_filter=$(GTEST_FILTER)
|
|
|
|
|
|
|
|
list-gtests:
|
|
|
|
ifeq (,$(wildcard out/$(BUILDTYPE)/cctest))
|
|
|
|
$(error Please run 'make cctest' first)
|
|
|
|
endif
|
|
|
|
@out/$(BUILDTYPE)/cctest --gtest_list_tests
|
|
|
|
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
v8:
|
|
|
|
tools/make-v8.sh
|
|
|
|
$(MAKE) -C deps/v8 $(V8_ARCH).$(BUILDTYPE_LOWER) $(V8_BUILD_OPTIONS)
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
|
|
|
|
test: all
|
|
|
|
$(MAKE) build-addons
|
|
|
|
$(MAKE) build-addons-napi
|
|
|
|
$(MAKE) cctest
|
|
|
|
$(PYTHON) tools/test.py --mode=release -J \
|
|
|
|
addons addons-napi doctool inspector known_issues message pseudo-tty parallel sequential
|
|
|
|
$(MAKE) lint
|
|
|
|
|
|
|
|
test-parallel: all
|
|
|
|
$(PYTHON) tools/test.py --mode=release parallel -J
|
|
|
|
|
|
|
|
test-valgrind: all
|
|
|
|
$(PYTHON) tools/test.py --mode=release --valgrind sequential parallel message
|
|
|
|
|
|
|
|
# Implicitly depends on $(NODE_EXE). We don't depend on it explicitly because
|
|
|
|
# it always triggers a rebuild due to it being a .PHONY rule. See the comment
|
|
|
|
# near the build-addons rule for more background.
|
|
|
|
test/gc/build/Release/binding.node: test/gc/binding.cc test/gc/binding.gyp
|
|
|
|
$(NODE) deps/npm/node_modules/node-gyp/bin/node-gyp rebuild \
|
|
|
|
--python="$(PYTHON)" \
|
|
|
|
--directory="$(shell pwd)/test/gc" \
|
|
|
|
--nodedir="$(shell pwd)"
|
|
|
|
|
|
|
|
# Implicitly depends on $(NODE_EXE), see the build-addons rule for rationale.
|
|
|
|
DOCBUILDSTAMP_PREREQS = tools/doc/addon-verify.js doc/api/addons.md
|
|
|
|
|
|
|
|
ifeq ($(OSTYPE),aix)
|
|
|
|
DOCBUILDSTAMP_PREREQS := $(DOCBUILDSTAMP_PREREQS) out/$(BUILDTYPE)/node.exp
|
|
|
|
endif
|
|
|
|
|
|
|
|
test/addons/.docbuildstamp: $(DOCBUILDSTAMP_PREREQS)
|
|
|
|
$(RM) -r test/addons/??_*/
|
|
|
|
$(NODE) $<
|
|
|
|
touch $@
|
|
|
|
|
|
|
|
ADDONS_BINDING_GYPS := \
|
|
|
|
$(filter-out test/addons/??_*/binding.gyp, \
|
|
|
|
$(wildcard test/addons/*/binding.gyp))
|
|
|
|
|
|
|
|
ADDONS_BINDING_SOURCES := \
|
|
|
|
$(filter-out test/addons/??_*/*.cc, $(wildcard test/addons/*/*.cc)) \
|
|
|
|
$(filter-out test/addons/??_*/*.h, $(wildcard test/addons/*/*.h))
|
|
|
|
|
|
|
|
# Implicitly depends on $(NODE_EXE), see the build-addons rule for rationale.
|
|
|
|
# Depends on node-gyp package.json so that build-addons is (re)executed when
|
|
|
|
# node-gyp is updated as part of an npm update.
|
|
|
|
test/addons/.buildstamp: config.gypi \
|
|
|
|
deps/npm/node_modules/node-gyp/package.json \
|
|
|
|
$(ADDONS_BINDING_GYPS) $(ADDONS_BINDING_SOURCES) \
|
|
|
|
deps/uv/include/*.h deps/v8/include/*.h \
|
|
|
|
src/node.h src/node_buffer.h src/node_object_wrap.h src/node_version.h \
|
|
|
|
test/addons/.docbuildstamp
|
|
|
|
# Cannot use $(wildcard test/addons/*/) here, it's evaluated before
|
|
|
|
# embedded addons have been generated from the documentation.
|
|
|
|
@for dirname in test/addons/*/; do \
|
|
|
|
printf "\nBuilding addon $$PWD/$$dirname\n" ; \
|
|
|
|
env MAKEFLAGS="-j1" $(NODE) deps/npm/node_modules/node-gyp/bin/node-gyp \
|
|
|
|
--loglevel=$(LOGLEVEL) rebuild \
|
|
|
|
--python="$(PYTHON)" \
|
|
|
|
--directory="$$PWD/$$dirname" \
|
|
|
|
--nodedir="$$PWD" || exit 1 ; \
|
|
|
|
done
|
|
|
|
touch $@
|
|
|
|
|
|
|
|
# .buildstamp and .docbuildstamp need $(NODE_EXE) but cannot depend on it
|
|
|
|
# directly because it calls make recursively. The parent make cannot know
|
|
|
|
# if the subprocess touched anything so it pessimistically assumes that
|
|
|
|
# .buildstamp and .docbuildstamp are out of date and need a rebuild.
|
|
|
|
# Just goes to show that recursive make really is harmful...
|
|
|
|
# TODO(bnoordhuis) Force rebuild after gyp update.
|
|
|
|
build-addons: $(NODE_EXE) test/addons/.buildstamp
|
|
|
|
|
|
|
|
ADDONS_NAPI_BINDING_GYPS := \
|
|
|
|
$(filter-out test/addons-napi/??_*/binding.gyp, \
|
|
|
|
$(wildcard test/addons-napi/*/binding.gyp))
|
|
|
|
|
|
|
|
ADDONS_NAPI_BINDING_SOURCES := \
|
|
|
|
$(filter-out test/addons-napi/??_*/*.cc, $(wildcard test/addons-napi/*/*.cc)) \
|
|
|
|
$(filter-out test/addons-napi/??_*/*.h, $(wildcard test/addons-napi/*/*.h))
|
|
|
|
|
|
|
|
# Implicitly depends on $(NODE_EXE), see the build-addons-napi rule for rationale.
|
|
|
|
test/addons-napi/.buildstamp: config.gypi \
|
|
|
|
deps/npm/node_modules/node-gyp/package.json \
|
|
|
|
$(ADDONS_NAPI_BINDING_GYPS) $(ADDONS_NAPI_BINDING_SOURCES) \
|
|
|
|
deps/uv/include/*.h deps/v8/include/*.h \
|
|
|
|
src/node.h src/node_buffer.h src/node_object_wrap.h src/node_version.h \
|
|
|
|
src/node_api.h src/node_api_types.h
|
|
|
|
# Cannot use $(wildcard test/addons-napi/*/) here, it's evaluated before
|
|
|
|
# embedded addons have been generated from the documentation.
|
|
|
|
@for dirname in test/addons-napi/*/; do \
|
|
|
|
printf "\nBuilding addon $$PWD/$$dirname\n" ; \
|
|
|
|
env MAKEFLAGS="-j1" $(NODE) deps/npm/node_modules/node-gyp/bin/node-gyp \
|
|
|
|
--loglevel=$(LOGLEVEL) rebuild \
|
|
|
|
--python="$(PYTHON)" \
|
|
|
|
--directory="$$PWD/$$dirname" \
|
|
|
|
--nodedir="$$PWD" || exit 1 ; \
|
|
|
|
done
|
|
|
|
touch $@
|
|
|
|
|
|
|
|
# .buildstamp and .docbuildstamp need $(NODE_EXE) but cannot depend on it
|
|
|
|
# directly because it calls make recursively. The parent make cannot know
|
|
|
|
# if the subprocess touched anything so it pessimistically assumes that
|
|
|
|
# .buildstamp and .docbuildstamp are out of date and need a rebuild.
|
|
|
|
# Just goes to show that recursive make really is harmful...
|
|
|
|
# TODO(bnoordhuis) Force rebuild after gyp or node-gyp update.
|
|
|
|
build-addons-napi: $(NODE_EXE) test/addons-napi/.buildstamp
|
|
|
|
|
|
|
|
ifeq ($(OSTYPE),$(filter $(OSTYPE),darwin aix))
|
|
|
|
XARGS = xargs
|
|
|
|
else
|
|
|
|
XARGS = xargs -r
|
|
|
|
endif
|
|
|
|
clear-stalled:
|
|
|
|
ps awwx | grep Release/node | grep -v grep | cat
|
|
|
|
ps awwx | grep Release/node | grep -v grep | awk '{print $$1}' | $(XARGS) kill
|
|
|
|
|
|
|
|
test-gc: all test/gc/build/Release/binding.node
|
|
|
|
$(PYTHON) tools/test.py --mode=release gc
|
|
|
|
|
|
|
|
test-build: | all build-addons build-addons-napi
|
|
|
|
|
|
|
|
test-build-addons-napi: all build-addons-napi
|
|
|
|
|
|
|
|
test-all: test-build test/gc/build/Release/binding.node
|
|
|
|
$(PYTHON) tools/test.py --mode=debug,release
|
|
|
|
|
|
|
|
test-all-valgrind: test-build
|
|
|
|
$(PYTHON) tools/test.py --mode=debug,release --valgrind
|
|
|
|
|
|
|
|
CI_NATIVE_SUITES := addons addons-napi
|
|
|
|
CI_JS_SUITES := doctool inspector known_issues message parallel pseudo-tty sequential
|
|
|
|
|
|
|
|
# Build and test addons without building anything else
|
|
|
|
test-ci-native: LOGLEVEL := info
|
|
|
|
test-ci-native: | test/addons/.buildstamp test/addons-napi/.buildstamp
|
|
|
|
$(PYTHON) tools/test.py $(PARALLEL_ARGS) -p tap --logfile test.tap \
|
|
|
|
--mode=release --flaky-tests=$(FLAKY_TESTS) \
|
|
|
|
$(TEST_CI_ARGS) $(CI_NATIVE_SUITES)
|
|
|
|
|
|
|
|
# This target should not use a native compiler at all
|
|
|
|
test-ci-js: | clear-stalled
|
|
|
|
$(PYTHON) tools/test.py $(PARALLEL_ARGS) -p tap --logfile test.tap \
|
|
|
|
--mode=release --flaky-tests=$(FLAKY_TESTS) \
|
|
|
|
$(TEST_CI_ARGS) $(CI_JS_SUITES)
|
|
|
|
# Clean up any leftover processes
|
|
|
|
PS_OUT=`ps awwx | grep Release/node | grep -v grep | awk '{print $$1}'`; \
|
|
|
|
if [ "$${PS_OUT}" ]; then \
|
|
|
|
echo $${PS_OUT} | $(XARGS) kill; exit 1; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
test-ci: LOGLEVEL := info
|
|
|
|
test-ci: | clear-stalled build-addons build-addons-napi
|
|
|
|
out/Release/cctest --gtest_output=tap:cctest.tap
|
|
|
|
$(PYTHON) tools/test.py $(PARALLEL_ARGS) -p tap --logfile test.tap \
|
|
|
|
--mode=release --flaky-tests=$(FLAKY_TESTS) \
|
|
|
|
$(TEST_CI_ARGS) $(CI_NATIVE_SUITES) addons-napi $(CI_JS_SUITES)
|
|
|
|
# Clean up any leftover processes
|
|
|
|
PS_OUT=`ps awwx | grep Release/node | grep -v grep | awk '{print $$1}'`; \
|
|
|
|
if [ "$${PS_OUT}" ]; then \
|
|
|
|
echo $${PS_OUT} | $(XARGS) kill; exit 1; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
test-release: test-build
|
|
|
|
$(PYTHON) tools/test.py --mode=release
|
|
|
|
|
|
|
|
test-debug: test-build
|
|
|
|
$(PYTHON) tools/test.py --mode=debug
|
|
|
|
|
|
|
|
test-message: test-build
|
|
|
|
$(PYTHON) tools/test.py message
|
|
|
|
|
|
|
|
test-simple: | cctest # Depends on 'all'.
|
|
|
|
$(PYTHON) tools/test.py parallel sequential
|
|
|
|
|
|
|
|
test-pummel: all
|
|
|
|
$(PYTHON) tools/test.py pummel
|
|
|
|
|
|
|
|
test-internet: all
|
|
|
|
$(PYTHON) tools/test.py internet
|
|
|
|
|
|
|
|
test-debugger: all
|
|
|
|
$(PYTHON) tools/test.py debugger
|
|
|
|
|
|
|
|
test-inspector: all
|
|
|
|
$(PYTHON) tools/test.py inspector
|
|
|
|
|
|
|
|
test-node-inspect: $(NODE_EXE)
|
|
|
|
USE_EMBEDDED_NODE_INSPECT=1 $(NODE) tools/test-npm-package \
|
|
|
|
--install deps/node-inspect test
|
|
|
|
|
|
|
|
test-tick-processor: all
|
|
|
|
$(PYTHON) tools/test.py tick-processor
|
|
|
|
|
|
|
|
test-known-issues: all
|
|
|
|
$(PYTHON) tools/test.py known_issues
|
|
|
|
|
|
|
|
test-npm: $(NODE_EXE)
|
|
|
|
NODE=$(NODE) tools/test-npm.sh
|
|
|
|
|
|
|
|
test-npm-publish: $(NODE_EXE)
|
|
|
|
npm_package_config_publishtest=true $(NODE) deps/npm/test/run.js
|
|
|
|
|
|
|
|
test-addons-napi: test-build-addons-napi
|
|
|
|
$(PYTHON) tools/test.py --mode=release addons-napi
|
|
|
|
|
|
|
|
test-addons: test-build test-addons-napi
|
|
|
|
$(PYTHON) tools/test.py --mode=release addons
|
|
|
|
|
|
|
|
test-addons-clean:
|
|
|
|
$(RM) -rf test/addons/??_*/
|
|
|
|
$(RM) -rf test/addons/*/build
|
|
|
|
$(RM) test/addons/.buildstamp test/addons/.docbuildstamp
|
|
|
|
|
|
|
|
test-timers:
|
|
|
|
$(MAKE) --directory=tools faketime
|
|
|
|
$(PYTHON) tools/test.py --mode=release timers
|
|
|
|
|
|
|
|
test-timers-clean:
|
|
|
|
$(MAKE) --directory=tools clean
|
|
|
|
|
|
|
|
|
|
|
|
ifneq ("","$(wildcard deps/v8/tools/run-tests.py)")
|
|
|
|
test-v8: v8
|
|
|
|
# note: performs full test unless QUICKCHECK is specified
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
deps/v8/tools/run-tests.py --arch=$(V8_ARCH) \
|
|
|
|
--mode=$(BUILDTYPE_LOWER) $(V8_TEST_OPTIONS) $(QUICKCHECK_ARG) \
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
--no-presubmit \
|
|
|
|
--shell-dir=$(PWD)/deps/v8/out/$(V8_ARCH).$(BUILDTYPE_LOWER) \
|
|
|
|
$(TAP_V8)
|
|
|
|
|
|
|
|
test-v8-intl: v8
|
|
|
|
# note: performs full test unless QUICKCHECK is specified
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
deps/v8/tools/run-tests.py --arch=$(V8_ARCH) \
|
|
|
|
--mode=$(BUILDTYPE_LOWER) --no-presubmit $(QUICKCHECK_ARG) \
|
|
|
|
--shell-dir=deps/v8/out/$(V8_ARCH).$(BUILDTYPE_LOWER) intl \
|
|
|
|
$(TAP_V8_INTL)
|
|
|
|
|
|
|
|
test-v8-benchmarks: v8
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
deps/v8/tools/run-tests.py --arch=$(V8_ARCH) --mode=$(BUILDTYPE_LOWER) \
|
|
|
|
--download-data $(QUICKCHECK_ARG) --no-presubmit \
|
|
|
|
--shell-dir=deps/v8/out/$(V8_ARCH).$(BUILDTYPE_LOWER) benchmarks \
|
|
|
|
$(TAP_V8_BENCHMARKS)
|
|
|
|
|
|
|
|
test-v8-all: test-v8 test-v8-intl test-v8-benchmarks
|
|
|
|
# runs all v8 tests
|
|
|
|
else
|
|
|
|
test-v8 test-v8-intl test-v8-benchmarks test-v8-all:
|
|
|
|
@echo "Testing v8 is not available through the source tarball."
|
|
|
|
@echo "Use the git repo instead:" \
|
|
|
|
"$ git clone https://github.com/nodejs/node.git"
|
|
|
|
endif
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
|
|
|
|
# Google Analytics ID used for tracking API docs page views, empty
|
|
|
|
# DOCS_ANALYTICS means no tracking scripts will be included in the
|
|
|
|
# generated .html files
|
|
|
|
DOCS_ANALYTICS ?=
|
|
|
|
|
|
|
|
apidoc_sources = $(wildcard doc/api/*.md)
|
|
|
|
apidocs_html = $(apidoc_dirs) $(apiassets) $(addprefix out/,$(apidoc_sources:.md=.html))
|
|
|
|
apidocs_json = $(apidoc_dirs) $(apiassets) $(addprefix out/,$(apidoc_sources:.md=.json))
|
|
|
|
|
|
|
|
apidoc_dirs = out/doc out/doc/api/ out/doc/api/assets
|
|
|
|
|
|
|
|
apiassets = $(subst api_assets,api/assets,$(addprefix out/,$(wildcard doc/api_assets/*)))
|
|
|
|
|
|
|
|
doc-only: $(apidocs_html) $(apidocs_json)
|
|
|
|
doc: $(NODE_EXE) doc-only
|
|
|
|
|
|
|
|
$(apidoc_dirs):
|
|
|
|
mkdir -p $@
|
|
|
|
|
|
|
|
out/doc/api/assets/%: doc/api_assets/% out/doc/api/assets/
|
|
|
|
cp $< $@
|
|
|
|
|
|
|
|
out/doc/%: doc/%
|
|
|
|
cp -r $< $@
|
|
|
|
|
|
|
|
# check if ./node is actually set, else use user pre-installed binary
|
|
|
|
gen-json = tools/doc/generate.js --format=json $< > $@
|
|
|
|
out/doc/api/%.json: doc/api/%.md
|
|
|
|
@[ -e tools/doc/node_modules/js-yaml/package.json ] || \
|
|
|
|
[ -e tools/eslint/node_modules/js-yaml/package.json ] || \
|
|
|
|
if [ -x $(NODE) ]; then \
|
|
|
|
cd tools/doc && ../../$(NODE) ../../$(NPM) install; \
|
|
|
|
else \
|
|
|
|
cd tools/doc && node ../../$(NPM) install; \
|
|
|
|
fi
|
|
|
|
[ -x $(NODE) ] && $(NODE) $(gen-json) || node $(gen-json)
|
|
|
|
|
|
|
|
# check if ./node is actually set, else use user pre-installed binary
|
|
|
|
gen-html = tools/doc/generate.js --node-version=$(FULLVERSION) --format=html \
|
|
|
|
--template=doc/template.html --analytics=$(DOCS_ANALYTICS) $< > $@
|
|
|
|
out/doc/api/%.html: doc/api/%.md
|
|
|
|
@[ -e tools/doc/node_modules/js-yaml/package.json ] || \
|
|
|
|
[ -e tools/eslint/node_modules/js-yaml/package.json ] || \
|
|
|
|
if [ -x $(NODE) ]; then \
|
|
|
|
cd tools/doc && ../../$(NODE) ../../$(NPM) install; \
|
|
|
|
else \
|
|
|
|
cd tools/doc && node ../../$(NPM) install; \
|
|
|
|
fi
|
|
|
|
[ -x $(NODE) ] && $(NODE) $(gen-html) || node $(gen-html)
|
|
|
|
|
|
|
|
docopen: $(apidocs_html)
|
|
|
|
@$(PYTHON) -mwebbrowser file://$(PWD)/out/doc/api/all.html
|
|
|
|
|
|
|
|
docclean:
|
|
|
|
-rm -rf out/doc
|
|
|
|
|
|
|
|
build-ci:
|
|
|
|
$(PYTHON) ./configure $(CONFIG_FLAGS)
|
|
|
|
$(MAKE)
|
|
|
|
|
|
|
|
run-ci: build-ci
|
|
|
|
$(MAKE) test-ci
|
|
|
|
|
|
|
|
RAWVER=$(shell $(PYTHON) tools/getnodeversion.py)
|
|
|
|
VERSION=v$(RAWVER)
|
|
|
|
|
|
|
|
# For nightly builds, you must set DISTTYPE to "nightly", "next-nightly" or
|
|
|
|
# "custom". For the nightly and next-nightly case, you need to set DATESTRING
|
|
|
|
# and COMMIT in order to properly name the build.
|
|
|
|
# For the rc case you need to set CUSTOMTAG to an appropriate CUSTOMTAG number
|
|
|
|
|
|
|
|
ifndef DISTTYPE
|
|
|
|
DISTTYPE=release
|
|
|
|
endif
|
|
|
|
ifeq ($(DISTTYPE),release)
|
|
|
|
FULLVERSION=$(VERSION)
|
|
|
|
else # ifeq ($(DISTTYPE),release)
|
|
|
|
ifeq ($(DISTTYPE),custom)
|
|
|
|
ifndef CUSTOMTAG
|
|
|
|
$(error CUSTOMTAG is not set for DISTTYPE=custom)
|
|
|
|
endif # ifndef CUSTOMTAG
|
|
|
|
TAG=$(CUSTOMTAG)
|
|
|
|
else # ifeq ($(DISTTYPE),custom)
|
|
|
|
ifndef DATESTRING
|
|
|
|
$(error DATESTRING is not set for nightly)
|
|
|
|
endif # ifndef DATESTRING
|
|
|
|
ifndef COMMIT
|
|
|
|
$(error COMMIT is not set for nightly)
|
|
|
|
endif # ifndef COMMIT
|
|
|
|
ifneq ($(DISTTYPE),nightly)
|
|
|
|
ifneq ($(DISTTYPE),next-nightly)
|
|
|
|
$(error DISTTYPE is not release, custom, nightly or next-nightly)
|
|
|
|
endif # ifneq ($(DISTTYPE),next-nightly)
|
|
|
|
endif # ifneq ($(DISTTYPE),nightly)
|
|
|
|
TAG=$(DISTTYPE)$(DATESTRING)$(COMMIT)
|
|
|
|
endif # ifeq ($(DISTTYPE),custom)
|
|
|
|
FULLVERSION=$(VERSION)-$(TAG)
|
|
|
|
endif # ifeq ($(DISTTYPE),release)
|
|
|
|
|
|
|
|
DISTTYPEDIR ?= $(DISTTYPE)
|
|
|
|
RELEASE=$(shell sed -ne 's/\#define NODE_VERSION_IS_RELEASE \([01]\)/\1/p' src/node_version.h)
|
|
|
|
PLATFORM=$(shell uname | tr '[:upper:]' '[:lower:]')
|
|
|
|
NPMVERSION=v$(shell cat deps/npm/package.json | grep '"version"' | sed 's/^[^:]*: "\([^"]*\)",.*/\1/')
|
|
|
|
|
|
|
|
UNAME_M=$(shell uname -m)
|
|
|
|
ifeq ($(findstring x86_64,$(UNAME_M)),x86_64)
|
|
|
|
DESTCPU ?= x64
|
|
|
|
else
|
|
|
|
ifeq ($(findstring ppc64,$(UNAME_M)),ppc64)
|
|
|
|
DESTCPU ?= ppc64
|
|
|
|
else
|
|
|
|
ifeq ($(findstring ppc,$(UNAME_M)),ppc)
|
|
|
|
DESTCPU ?= ppc
|
|
|
|
else
|
|
|
|
ifeq ($(findstring s390x,$(UNAME_M)),s390x)
|
|
|
|
DESTCPU ?= s390x
|
|
|
|
else
|
|
|
|
ifeq ($(findstring s390,$(UNAME_M)),s390)
|
|
|
|
DESTCPU ?= s390
|
|
|
|
else
|
|
|
|
ifeq ($(findstring arm,$(UNAME_M)),arm)
|
|
|
|
DESTCPU ?= arm
|
|
|
|
else
|
|
|
|
ifeq ($(findstring aarch64,$(UNAME_M)),aarch64)
|
|
|
|
DESTCPU ?= aarch64
|
|
|
|
else
|
|
|
|
ifeq ($(findstring powerpc,$(shell uname -p)),powerpc)
|
|
|
|
DESTCPU ?= ppc64
|
|
|
|
else
|
|
|
|
DESTCPU ?= x86
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
ifeq ($(DESTCPU),x64)
|
|
|
|
ARCH=x64
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),arm)
|
|
|
|
ARCH=arm
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),aarch64)
|
|
|
|
ARCH=arm64
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),ppc64)
|
|
|
|
ARCH=ppc64
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),ppc)
|
|
|
|
ARCH=ppc
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),s390)
|
|
|
|
ARCH=s390
|
|
|
|
else
|
|
|
|
ifeq ($(DESTCPU),s390x)
|
|
|
|
ARCH=s390x
|
|
|
|
else
|
|
|
|
ARCH=x86
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
test: run v8 tests from node tree
Ported by exinfinitum from a PR by jasnell:
see https://github.com/nodejs/node-v0.x-archive/pull/14185
Allows the running of v8 tests on node's packaged v8 source code.
Note that the limited win32 support added by jasnell has NOT been ported,
and so these tests are currently UNIX ONLY.
Note that gclient depot tools
(see https://commondatastorage.googleapis.com/
chrome-infra-docs/flat/depot_tools/docs/html/
depot_tools_tutorial.html#_setting_up) and subversion are required
to run tests.
To perform tests, run the following commands:
make v8 DESTCPU=(ARCH)
make test-v8 DESTCPU=(ARCH)
where (ARCH) is your CPU architecture, e.g. x64, ia32.
DESTCPU MUST be specified for this to work properly.
Can also do tests on debug build by using "make test-v8 DESTCPU=(ARCH)
BUILDTYPE=Debug", or perform intl or benchmark tests via make
test-v8-intl or test-v8-benchmarks respectively.
Note that by default, quickcheck and TAP output are disabled, and i18n
is enabled. To activate these options, use options"QUICKCHECK=True" and
"ENABLE_V8_TAP=True" respectively.
Use "DISABLE_V8_I18N" to disable i18n.
Use V8_BUILD_OPTIONS to allow custom user-defined flags to be
appended onto "make v8".
Any tests performed after changes to the packaged v8 file will require
recompiling of v8, which can be done using "make v8 DESTCPU=(ARCH)".
Finally, two additional files necessary for one of the v8 tests have
been added to the v8 folder.
PR-URL: https://github.com/nodejs/node/pull/4704
Reviewed-By: James M Snell <jasnell@gmail.com>
Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl>
Reviewed-By: targos - Michaël Zasso <mic.besace@gmail.com>
10 years ago
|
|
|
# node and v8 use different arch names (e.g. node 'x86' vs v8 'ia32').
|
|
|
|
# pass the proper v8 arch name to $V8_ARCH based on user-specified $DESTCPU.
|
|
|
|
ifeq ($(DESTCPU),x86)
|
|
|
|
V8_ARCH=ia32
|
|
|
|
else
|
|
|
|
V8_ARCH ?= $(DESTCPU)
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
|
|
|
# enforce "x86" over "ia32" as the generally accepted way of referring to 32-bit intel
|
|
|
|
ifeq ($(ARCH),ia32)
|
|
|
|
override ARCH=x86
|
|
|
|
endif
|
|
|
|
ifeq ($(DESTCPU),ia32)
|
|
|
|
override DESTCPU=x86
|
|
|
|
endif
|
|
|
|
|
|
|
|
TARNAME=node-$(FULLVERSION)
|
|
|
|
TARBALL=$(TARNAME).tar
|
|
|
|
# Custom user-specified variation, use it directly
|
|
|
|
ifdef VARIATION
|
|
|
|
BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)-$(VARIATION)
|
|
|
|
else
|
|
|
|
BINARYNAME=$(TARNAME)-$(PLATFORM)-$(ARCH)
|
|
|
|
endif
|
|
|
|
BINARYTAR=$(BINARYNAME).tar
|
|
|
|
# OSX doesn't have xz installed by default, http://macpkg.sourceforge.net/
|
|
|
|
XZ=$(shell which xz > /dev/null 2>&1; echo $$?)
|
|
|
|
XZ_COMPRESSION ?= 9
|
|
|
|
PKG=$(TARNAME).pkg
|
|
|
|
PACKAGEMAKER ?= /Developer/Applications/Utilities/PackageMaker.app/Contents/MacOS/PackageMaker
|
|
|
|
PKGDIR=out/dist-osx
|
|
|
|
|
|
|
|
release-only:
|
|
|
|
@if [ "$(DISTTYPE)" != "nightly" ] && [ "$(DISTTYPE)" != "next-nightly" ] && \
|
|
|
|
`grep -q REPLACEME doc/api/*.md`; then \
|
|
|
|
echo 'Please update REPLACEME in Added: tags in doc/api/*.md (See doc/releases.md)' ; \
|
|
|
|
exit 1 ; \
|
|
|
|
fi
|
|
|
|
@if [ "$(shell git status --porcelain | egrep -v '^\?\? ')" = "" ]; then \
|
|
|
|
exit 0 ; \
|
|
|
|
else \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
echo "The git repository is not clean." >&2 ; \
|
|
|
|
echo "Please commit changes before building release tarball." >&2 ; \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
git status --porcelain | egrep -v '^\?\?' >&2 ; \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
exit 1 ; \
|
|
|
|
fi
|
|
|
|
@if [ "$(DISTTYPE)" != "release" -o "$(RELEASE)" = "1" ]; then \
|
|
|
|
exit 0; \
|
|
|
|
else \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
echo "#NODE_VERSION_IS_RELEASE is set to $(RELEASE)." >&2 ; \
|
|
|
|
echo "Did you remember to update src/node_version.h?" >&2 ; \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
exit 1 ; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
$(PKG): release-only
|
|
|
|
rm -rf $(PKGDIR)
|
|
|
|
rm -rf out/deps out/Release
|
|
|
|
$(PYTHON) ./configure \
|
|
|
|
--dest-cpu=x64 \
|
|
|
|
--tag=$(TAG) \
|
|
|
|
--release-urlbase=$(RELEASE_URLBASE) \
|
|
|
|
$(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS)
|
|
|
|
$(MAKE) install V=$(V) DESTDIR=$(PKGDIR)
|
|
|
|
SIGN="$(CODESIGN_CERT)" PKGDIR="$(PKGDIR)" bash tools/osx-codesign.sh
|
|
|
|
cat tools/osx-pkg.pmdoc/index.xml.tmpl \
|
|
|
|
| sed -E "s/\\{nodeversion\\}/$(FULLVERSION)/g" \
|
|
|
|
| sed -E "s/\\{npmversion\\}/$(NPMVERSION)/g" \
|
|
|
|
> tools/osx-pkg.pmdoc/index.xml
|
|
|
|
$(PACKAGEMAKER) \
|
|
|
|
--id "org.nodejs.pkg" \
|
|
|
|
--doc tools/osx-pkg.pmdoc \
|
|
|
|
--out $(PKG)
|
|
|
|
SIGN="$(PRODUCTSIGN_CERT)" PKG="$(PKG)" bash tools/osx-productsign.sh
|
|
|
|
|
|
|
|
pkg: $(PKG)
|
|
|
|
|
|
|
|
pkg-upload: pkg
|
|
|
|
ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)"
|
|
|
|
chmod 664 node-$(FULLVERSION).pkg
|
|
|
|
scp -p node-$(FULLVERSION).pkg $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).pkg
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).pkg.done"
|
|
|
|
|
|
|
|
$(TARBALL): release-only $(NODE_EXE) doc
|
|
|
|
git checkout-index -a -f --prefix=$(TARNAME)/
|
|
|
|
mkdir -p $(TARNAME)/doc/api
|
|
|
|
cp doc/node.1 $(TARNAME)/doc/node.1
|
|
|
|
cp -r out/doc/api/* $(TARNAME)/doc/api/
|
|
|
|
rm -rf $(TARNAME)/deps/v8/{test,samples,tools/profviz,tools/run-tests.py}
|
|
|
|
rm -rf $(TARNAME)/doc/images # too big
|
|
|
|
rm -rf $(TARNAME)/deps/uv/{docs,samples,test}
|
|
|
|
rm -rf $(TARNAME)/deps/openssl/openssl/{doc,demos,test}
|
|
|
|
rm -rf $(TARNAME)/deps/zlib/contrib # too big, unused
|
|
|
|
rm -rf $(TARNAME)/.{editorconfig,git*,mailmap}
|
|
|
|
rm -rf $(TARNAME)/tools/{eslint,eslint-rules,osx-pkg.pmdoc,pkgsrc}
|
|
|
|
rm -rf $(TARNAME)/tools/{osx-*,license-builder.sh,cpplint.py}
|
|
|
|
rm -rf $(TARNAME)/test*.tap
|
|
|
|
find $(TARNAME)/ -name ".eslint*" -maxdepth 2 | xargs rm
|
|
|
|
find $(TARNAME)/ -type l | xargs rm # annoying on windows
|
|
|
|
tar -cf $(TARNAME).tar $(TARNAME)
|
|
|
|
rm -rf $(TARNAME)
|
|
|
|
gzip -c -f -9 $(TARNAME).tar > $(TARNAME).tar.gz
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
xz -c -f -$(XZ_COMPRESSION) $(TARNAME).tar > $(TARNAME).tar.xz
|
|
|
|
endif
|
|
|
|
rm $(TARNAME).tar
|
|
|
|
|
|
|
|
tar: $(TARBALL)
|
|
|
|
|
|
|
|
tar-upload: tar
|
|
|
|
ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)"
|
|
|
|
chmod 664 node-$(FULLVERSION).tar.gz
|
|
|
|
scp -p node-$(FULLVERSION).tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.gz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.gz.done"
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
chmod 664 node-$(FULLVERSION).tar.xz
|
|
|
|
scp -p node-$(FULLVERSION).tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.xz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION).tar.xz.done"
|
|
|
|
endif
|
|
|
|
|
|
|
|
doc-upload: doc
|
|
|
|
ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)"
|
|
|
|
chmod -R ug=rw-x+X,o=r+X out/doc/
|
|
|
|
scp -pr out/doc/ $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/docs/
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/docs.done"
|
|
|
|
|
|
|
|
$(TARBALL)-headers: release-only
|
|
|
|
$(PYTHON) ./configure \
|
|
|
|
--prefix=/ \
|
|
|
|
--dest-cpu=$(DESTCPU) \
|
|
|
|
--tag=$(TAG) \
|
|
|
|
--release-urlbase=$(RELEASE_URLBASE) \
|
|
|
|
$(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS)
|
|
|
|
HEADERS_ONLY=1 $(PYTHON) tools/install.py install '$(TARNAME)' '/'
|
|
|
|
find $(TARNAME)/ -type l | xargs rm -f
|
|
|
|
tar -cf $(TARNAME)-headers.tar $(TARNAME)
|
|
|
|
rm -rf $(TARNAME)
|
|
|
|
gzip -c -f -9 $(TARNAME)-headers.tar > $(TARNAME)-headers.tar.gz
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
xz -c -f -$(XZ_COMPRESSION) $(TARNAME)-headers.tar > $(TARNAME)-headers.tar.xz
|
|
|
|
endif
|
|
|
|
rm $(TARNAME)-headers.tar
|
|
|
|
|
|
|
|
tar-headers: $(TARBALL)-headers
|
|
|
|
|
|
|
|
tar-headers-upload: tar-headers
|
|
|
|
ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)"
|
|
|
|
chmod 664 $(TARNAME)-headers.tar.gz
|
|
|
|
scp -p $(TARNAME)-headers.tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.gz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.gz.done"
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
chmod 664 $(TARNAME)-headers.tar.xz
|
|
|
|
scp -p $(TARNAME)-headers.tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.xz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/$(TARNAME)-headers.tar.xz.done"
|
|
|
|
endif
|
|
|
|
|
|
|
|
$(BINARYTAR): release-only
|
|
|
|
rm -rf $(BINARYNAME)
|
|
|
|
rm -rf out/deps out/Release
|
|
|
|
$(PYTHON) ./configure \
|
|
|
|
--prefix=/ \
|
|
|
|
--dest-cpu=$(DESTCPU) \
|
|
|
|
--tag=$(TAG) \
|
|
|
|
--release-urlbase=$(RELEASE_URLBASE) \
|
|
|
|
$(CONFIG_FLAGS) $(BUILD_RELEASE_FLAGS)
|
|
|
|
$(MAKE) install DESTDIR=$(BINARYNAME) V=$(V) PORTABLE=1
|
|
|
|
cp README.md $(BINARYNAME)
|
|
|
|
cp LICENSE $(BINARYNAME)
|
|
|
|
cp CHANGELOG.md $(BINARYNAME)
|
|
|
|
tar -cf $(BINARYNAME).tar $(BINARYNAME)
|
|
|
|
rm -rf $(BINARYNAME)
|
|
|
|
gzip -c -f -9 $(BINARYNAME).tar > $(BINARYNAME).tar.gz
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
xz -c -f -$(XZ_COMPRESSION) $(BINARYNAME).tar > $(BINARYNAME).tar.xz
|
|
|
|
endif
|
|
|
|
rm $(BINARYNAME).tar
|
|
|
|
|
|
|
|
binary: $(BINARYTAR)
|
|
|
|
|
|
|
|
binary-upload: binary
|
|
|
|
ssh $(STAGINGSERVER) "mkdir -p nodejs/$(DISTTYPEDIR)/$(FULLVERSION)"
|
|
|
|
chmod 664 node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz
|
|
|
|
scp -p node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.gz.done"
|
|
|
|
ifeq ($(XZ), 0)
|
|
|
|
chmod 664 node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz
|
|
|
|
scp -p node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz $(STAGINGSERVER):nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz
|
|
|
|
ssh $(STAGINGSERVER) "touch nodejs/$(DISTTYPEDIR)/$(FULLVERSION)/node-$(FULLVERSION)-$(OSTYPE)-$(ARCH).tar.xz.done"
|
|
|
|
endif
|
|
|
|
|
|
|
|
bench-net: all
|
|
|
|
@$(NODE) benchmark/run.js net
|
|
|
|
|
|
|
|
bench-crypto: all
|
|
|
|
@$(NODE) benchmark/run.js crypto
|
|
|
|
|
|
|
|
bench-tls: all
|
|
|
|
@$(NODE) benchmark/run.js tls
|
|
|
|
|
|
|
|
bench-http: all
|
|
|
|
@$(NODE) benchmark/run.js http
|
|
|
|
|
|
|
|
bench-fs: all
|
|
|
|
@$(NODE) benchmark/run.js fs
|
|
|
|
|
|
|
|
bench-misc: all
|
|
|
|
@$(MAKE) -C benchmark/misc/function_call/
|
|
|
|
@$(NODE) benchmark/run.js misc
|
|
|
|
|
|
|
|
bench-array: all
|
|
|
|
@$(NODE) benchmark/run.js arrays
|
|
|
|
|
|
|
|
bench-buffer: all
|
|
|
|
@$(NODE) benchmark/run.js buffers
|
|
|
|
|
|
|
|
bench-url: all
|
|
|
|
@$(NODE) benchmark/run.js url
|
|
|
|
|
|
|
|
bench-events: all
|
|
|
|
@$(NODE) benchmark/run.js events
|
|
|
|
|
|
|
|
bench-util: all
|
|
|
|
@$(NODE) benchmark/run.js util
|
|
|
|
|
|
|
|
bench-dgram: all
|
|
|
|
@$(NODE) benchmark/run.js dgram
|
|
|
|
|
|
|
|
bench-all: bench bench-misc bench-array bench-buffer bench-url bench-events bench-dgram bench-util
|
|
|
|
|
|
|
|
bench: bench-net bench-http bench-fs bench-tls
|
|
|
|
|
|
|
|
bench-ci: bench
|
|
|
|
|
|
|
|
jslint:
|
|
|
|
$(NODE) tools/eslint/bin/eslint.js --cache --rulesdir=tools/eslint-rules \
|
|
|
|
benchmark lib test tools
|
|
|
|
|
|
|
|
jslint-ci:
|
|
|
|
$(NODE) tools/jslint.js $(PARALLEL_ARGS) -f tap -o test-eslint.tap \
|
|
|
|
benchmark lib test tools
|
|
|
|
|
|
|
|
CPPLINT_EXCLUDE ?=
|
|
|
|
CPPLINT_EXCLUDE += src/node_root_certs.h
|
|
|
|
CPPLINT_EXCLUDE += src/queue.h
|
|
|
|
CPPLINT_EXCLUDE += src/tree.h
|
|
|
|
CPPLINT_EXCLUDE += $(wildcard test/addons/??_*/*.cc test/addons/??_*/*.h)
|
|
|
|
CPPLINT_EXCLUDE += $(wildcard test/addons-napi/??_*/*.cc test/addons-napi/??_*/*.h)
|
|
|
|
|
|
|
|
CPPLINT_FILES = $(filter-out $(CPPLINT_EXCLUDE), $(wildcard \
|
|
|
|
src/*.c \
|
|
|
|
src/*.cc \
|
|
|
|
src/*.h \
|
|
|
|
test/addons/*/*.cc \
|
|
|
|
test/addons/*/*.h \
|
|
|
|
test/cctest/*.cc \
|
|
|
|
test/cctest/*.h \
|
|
|
|
test/addons-napi/*/*.cc \
|
|
|
|
test/addons-napi/*/*.h \
|
|
|
|
test/gc/binding.cc \
|
|
|
|
tools/icu/*.cc \
|
|
|
|
tools/icu/*.h \
|
|
|
|
))
|
|
|
|
|
|
|
|
cpplint:
|
|
|
|
@$(PYTHON) tools/cpplint.py $(CPPLINT_FILES)
|
|
|
|
@$(PYTHON) tools/check-imports.py
|
|
|
|
|
|
|
|
ifneq ("","$(wildcard tools/eslint/lib/eslint.js)")
|
|
|
|
lint: jslint cpplint
|
|
|
|
CONFLICT_RE=^>>>>>>> [0-9A-Fa-f]+|^<<<<<<< [A-Za-z]+
|
|
|
|
lint-ci: jslint-ci cpplint
|
|
|
|
@if ! ( grep -IEqrs "$(CONFLICT_RE)" benchmark deps doc lib src test tools ) \
|
|
|
|
&& ! ( find . -maxdepth 1 -type f | xargs grep -IEqs "$(CONFLICT_RE)" ); then \
|
|
|
|
exit 0 ; \
|
|
|
|
else \
|
|
|
|
echo "" >&2 ; \
|
|
|
|
echo "Conflict marker detected in one or more files. Please fix them first." >&2 ; \
|
|
|
|
exit 1 ; \
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
lint:
|
|
|
|
@echo "Linting is not available through the source tarball."
|
|
|
|
@echo "Use the git repo instead:" \
|
|
|
|
"$ git clone https://github.com/nodejs/node.git"
|
|
|
|
|
|
|
|
lint-ci: lint
|
|
|
|
endif
|
|
|
|
|
|
|
|
.PHONY: lint cpplint jslint bench clean docopen docclean doc dist distclean \
|
|
|
|
check uninstall install install-includes install-bin all staticlib \
|
|
|
|
dynamiclib test test-all test-addons test-addons-clean build-addons \
|
|
|
|
website-upload pkg blog blogclean tar binary release-only \
|
|
|
|
bench-http-simple bench-idle bench-all bench bench-misc bench-array \
|
|
|
|
bench-buffer bench-net bench-http bench-fs bench-tls cctest run-ci test-v8 \
|
|
|
|
test-v8-intl test-v8-benchmarks test-v8-all v8 lint-ci bench-ci jslint-ci \
|
|
|
|
doc-only $(TARBALL)-headers test-ci test-ci-native test-ci-js build-ci \
|
|
|
|
clear-stalled coverage-clean coverage-build coverage-test coverage \
|
|
|
|
list-gtests test-addons-napi build-addons-napi
|