test: integration tests now against bazel built packages (#22810)

PR Close #22810
This commit is contained in:
Alex Eagle 2018-03-15 15:36:11 -07:00 committed by Igor Minar
parent d1177c75f8
commit 328b48b697
7 changed files with 54 additions and 36 deletions

View File

@ -82,6 +82,10 @@ jobs:
# NOTE: Angular developers should typically just bazel build //packages/... or bazel test //packages/... # NOTE: Angular developers should typically just bazel build //packages/... or bazel test //packages/...
- run: bazel query --output=label //... | xargs bazel test - run: bazel query --output=label //... | xargs bazel test
# We run the integration tests outside of Bazel for now.
# See comments inside this script.
- run: xvfb-run --auto-servernum ./integration/run_tests.sh
# CircleCI will allow us to go back and view/download these artifacts from past builds. # CircleCI will allow us to go back and view/download these artifacts from past builds.
# Also we can use a service like https://buildsize.org/ to automatically track binary size of these artifacts. # Also we can use a service like https://buildsize.org/ to automatically track binary size of these artifacts.
- store_artifacts: - store_artifacts:

View File

@ -51,18 +51,9 @@ you can install the package directly from `file:../../node_modules`.
## Running integration tests ## Running integration tests
First you must run `build.sh` to create the current distribution.
You can iterate on the tests by keeping the dist folder up-to-date.
See the `package.json` of the test(s) you're debugging, to see which dist/ folders they install from.
Then run the right `tsc --watch` command to keep those dist folders up-to-date, for example:
```
$ ./node_modules/.bin/tsc -p packages/core/tsconfig-build.json --watch
```
Now you can run the integration test, it will re-install from the dist/ folder on each run.
``` ```
$ ./integration/run_tests.sh $ ./integration/run_tests.sh
``` ```
The test runner will first re-build any stale npm packages, then `cd` into each
subdirectory to execute the test.

View File

@ -17,6 +17,6 @@
"node_modules/@angular/bazel/**", "node_modules/@angular/bazel/**",
"node_modules/@angular/compiler-cli/**", "node_modules/@angular/compiler-cli/**",
"node_modules/@angular/common/locales/**", "node_modules/@angular/common/locales/**",
"node_modules/@angular/tsc-wrapped/**" "node_modules/@angular/*/testing/**"
] ]
} }

View File

@ -2,19 +2,47 @@
set -e -o pipefail set -e -o pipefail
currentDir=$(cd $(dirname $0); pwd) # see https://circleci.com/docs/2.0/env-vars/#circleci-built-in-environment-variables
cd ${currentDir} CI=${CI:-false}
cd "$(dirname "$0")"
readonly thisDir=$(cd $(dirname $0); pwd) # basedir is the workspace root
readonly basedir=$(pwd)/..
readonly bin=$(bazel info bazel-bin)
echo "#################################"
echo "Building @angular/* npm packages "
echo "#################################"
# Ideally these integration tests should run under bazel, and just list the npm
# packages in their deps[].
# Until then, we have to manually run bazel first to create the npm packages we
# want to test.
bazel query --output=label 'kind(.*_package, //packages/...)' \
| xargs bazel build
# Allow this test to run even if dist/ doesn't exist yet.
# Under Bazel we don't need to create the dist folder to run the integration tests
[ -d "${basedir}/dist/packages-dist" ] || mkdir -p $basedir/dist/packages-dist
# Each package is a subdirectory of bazel-bin/packages/
for pkg in $(ls ${bin}/packages); do
# Skip any that don't have an "npm_package" target
if [ -d "${bin}/packages/${pkg}/npm_package" ]; then
echo "# Copy artifacts to dist/packages-dist/${pkg}"
rm -rf ${basedir}/dist/packages-dist/${pkg}
cp -R ${bin}/packages/${pkg}/npm_package ${basedir}/dist/packages-dist/${pkg}
fi
done
# Track payload size functions # Track payload size functions
# TODO(alexeagle): finish migrating these to buildsize.org # TODO(alexeagle): finish migrating these to buildsize.org
if [[ -v TRAVIS ]]; then if $CI; then
# We don't install this by default because it contains some broken Bazel setup # We don't install this by default because it contains some broken Bazel setup
# and also it's a very big dependency that we never use except on Travis. # and also it's a very big dependency that we never use except when publishing
# payload sizes on CI.
yarn add -D firebase-tools@3.12.0 yarn add -D firebase-tools@3.12.0
source ../scripts/ci/payload-size.sh source ${basedir}/scripts/ci/payload-size.sh
fi fi
# Workaround https://github.com/yarnpkg/yarn/issues/2165 # Workaround https://github.com/yarnpkg/yarn/issues/2165
@ -35,6 +63,7 @@ for testDir in $(ls | grep -v node_modules) ; do
( (
cd $testDir cd $testDir
rm -rf dist rm -rf dist
pwd
yarn install --cache-folder ../$cache yarn install --cache-folder ../$cache
yarn test || exit 1 yarn test || exit 1
# Track payload size for cli-hello-world and hello_world__closure and the render3 tests # Track payload size for cli-hello-world and hello_world__closure and the render3 tests
@ -42,17 +71,15 @@ for testDir in $(ls | grep -v node_modules) ; do
if [[ $testDir == cli-hello-world ]] || [[ $testDir == hello_world__render3__cli ]]; then if [[ $testDir == cli-hello-world ]] || [[ $testDir == hello_world__render3__cli ]]; then
yarn build yarn build
fi fi
if [[ -v TRAVIS ]]; then #if $CI; then
trackPayloadSize "$testDir" "dist/*.js" true false "${thisDir}/_payload-limits.json" # trackPayloadSize "$testDir" "dist/*.js" true false "${basedir}/integration/_payload-limits.json"
#fi
fi fi
fi # remove the temporary node modules directory to keep the source folder clean.
if [[ -v TRAVIS ]]; then
# remove the temporary node modules directory to save space.
rm -rf node_modules rm -rf node_modules
fi
) )
done done
if [[ -v TRAVIS ]]; then #if $CI; then
trackPayloadSize "umd" "../dist/packages-dist/*/bundles/*.umd.min.js" false false # trackPayloadSize "umd" "../dist/packages-dist/*/bundles/*.umd.min.js" false false
fi #fi

View File

@ -1,3 +1,4 @@
{ {
"name": "example" "name": "example",
"version": "0.0.0-PLACEHOLDER"
} }

View File

@ -13,12 +13,6 @@ travisFoldStart "test.e2e.buildPackages"
./build.sh ./build.sh
travisFoldEnd "test.e2e.buildPackages" travisFoldEnd "test.e2e.buildPackages"
travisFoldStart "test.e2e.integration"
./integration/run_tests.sh
travisFoldEnd "test.e2e.integration"
# TODO(i): temporarily disable this test because we don't have rxjs backwards compatibility package # TODO(i): temporarily disable this test because we don't have rxjs backwards compatibility package
# and cdk+material are not yet compatible with rxjs v6 # and cdk+material are not yet compatible with rxjs v6
# uncomment when we have cdk and material releases compatible with rxjs v6 # uncomment when we have cdk and material releases compatible with rxjs v6

View File

@ -28,6 +28,7 @@ build --watchfs
# Release support # # Release support #
############################### ###############################
# Releases should always be stamped with version control info
build --workspace_status_command=./tools/bazel_stamp_vars.sh build --workspace_status_command=./tools/bazel_stamp_vars.sh
############################### ###############################