2019-11-14 17:47:32 +01:00
|
|
|
version: 2.1
|
2018-03-09 21:47:01 +01:00
|
|
|
|
|
|
|
workflows:
|
2019-07-18 07:51:47 +02:00
|
|
|
test_and_release:
|
2018-03-09 21:47:01 +01:00
|
|
|
jobs:
|
2019-07-18 07:51:47 +02:00
|
|
|
- create_release_pull_request:
|
2020-10-06 19:57:59 +02:00
|
|
|
requires:
|
|
|
|
- prep-deps
|
2019-07-18 07:51:47 +02:00
|
|
|
filters:
|
|
|
|
branches:
|
|
|
|
only:
|
|
|
|
- /^Version-v(\d+)[.](\d+)[.](\d+)/
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2019-07-25 19:07:54 +02:00
|
|
|
- test-deps
|
2018-03-27 23:16:58 +02:00
|
|
|
- prep-build:
|
2018-03-27 23:08:20 +02:00
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2020-01-20 18:03:21 +01:00
|
|
|
- prep-build-test:
|
|
|
|
requires:
|
|
|
|
- prep-deps
|
2020-02-08 20:56:33 +01:00
|
|
|
- prep-build-storybook:
|
|
|
|
requires:
|
|
|
|
- prep-deps
|
2018-03-09 22:15:36 +01:00
|
|
|
- test-lint:
|
2018-03-09 21:47:01 +01:00
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2019-11-19 16:46:10 +01:00
|
|
|
- test-lint-shellcheck
|
2020-01-06 19:58:43 +01:00
|
|
|
- test-lint-lockfile:
|
|
|
|
requires:
|
|
|
|
- prep-deps
|
2019-02-20 14:57:49 +01:00
|
|
|
- test-e2e-chrome:
|
2018-05-28 18:22:48 +02:00
|
|
|
requires:
|
2020-01-20 18:03:21 +01:00
|
|
|
- prep-build-test
|
2019-02-20 14:57:49 +01:00
|
|
|
- test-e2e-firefox:
|
2018-05-28 18:22:48 +02:00
|
|
|
requires:
|
2020-01-20 18:03:21 +01:00
|
|
|
- prep-build-test
|
2018-03-09 22:37:13 +01:00
|
|
|
- test-unit:
|
2018-03-09 22:15:36 +01:00
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2019-10-24 15:54:32 +02:00
|
|
|
- test-unit-global:
|
|
|
|
requires:
|
|
|
|
- prep-deps
|
2020-08-04 19:21:46 +02:00
|
|
|
- validate-source-maps:
|
|
|
|
requires:
|
|
|
|
- prep-build
|
2018-09-26 02:44:57 +02:00
|
|
|
- test-mozilla-lint:
|
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2018-09-26 02:44:57 +02:00
|
|
|
- prep-build
|
2018-03-28 01:09:11 +02:00
|
|
|
- all-tests-pass:
|
2018-03-27 23:40:04 +02:00
|
|
|
requires:
|
|
|
|
- test-lint
|
2019-11-19 16:46:10 +01:00
|
|
|
- test-lint-shellcheck
|
2020-01-06 19:58:43 +01:00
|
|
|
- test-lint-lockfile
|
2018-03-27 23:40:04 +02:00
|
|
|
- test-unit
|
2019-10-24 15:54:32 +02:00
|
|
|
- test-unit-global
|
2020-08-04 19:21:46 +02:00
|
|
|
- validate-source-maps
|
2018-09-26 02:44:57 +02:00
|
|
|
- test-mozilla-lint
|
2019-02-20 14:57:49 +01:00
|
|
|
- test-e2e-chrome
|
|
|
|
- test-e2e-firefox
|
2020-01-23 21:55:17 +01:00
|
|
|
- benchmark:
|
|
|
|
requires:
|
|
|
|
- prep-build-test
|
2018-05-18 20:10:42 +02:00
|
|
|
- job-publish-prerelease:
|
2018-04-09 22:55:19 +02:00
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2018-04-09 22:55:19 +02:00
|
|
|
- prep-build
|
2020-01-23 21:55:17 +01:00
|
|
|
- benchmark
|
2018-04-09 22:55:19 +02:00
|
|
|
- all-tests-pass
|
2018-05-18 20:29:10 +02:00
|
|
|
- job-publish-release:
|
|
|
|
filters:
|
|
|
|
branches:
|
|
|
|
only: master
|
|
|
|
requires:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
- prep-deps
|
2018-05-18 20:29:10 +02:00
|
|
|
- prep-build
|
|
|
|
- all-tests-pass
|
2020-02-08 20:56:33 +01:00
|
|
|
- job-publish-storybook:
|
|
|
|
filters:
|
|
|
|
branches:
|
|
|
|
only: develop
|
|
|
|
requires:
|
|
|
|
- prep-build-storybook
|
2019-08-13 17:59:10 +02:00
|
|
|
- coveralls-upload:
|
|
|
|
requires:
|
|
|
|
- test-unit
|
2018-03-09 21:47:01 +01:00
|
|
|
|
2018-03-09 21:38:28 +01:00
|
|
|
jobs:
|
2019-07-18 07:51:47 +02:00
|
|
|
create_release_pull_request:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2019-07-18 07:51:47 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
2020-10-06 21:09:53 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2019-07-18 07:51:47 +02:00
|
|
|
- run:
|
|
|
|
name: Create GitHub Pull Request for version
|
|
|
|
command: |
|
|
|
|
.circleci/scripts/release-bump-changelog-version
|
|
|
|
.circleci/scripts/release-bump-manifest-version
|
|
|
|
.circleci/scripts/release-create-release-pr
|
|
|
|
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
prep-deps:
|
2018-03-09 21:38:28 +01:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-03-09 21:38:28 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
2019-07-25 00:54:16 +02:00
|
|
|
- run:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
name: Install deps
|
2018-07-06 06:32:12 +02:00
|
|
|
command: |
|
2019-09-25 14:01:10 +02:00
|
|
|
.circleci/scripts/deps-install.sh
|
2019-09-11 18:03:47 +02:00
|
|
|
- run:
|
|
|
|
name: Collect yarn install HAR logs
|
|
|
|
command: |
|
|
|
|
.circleci/scripts/collect-har-artifact.sh
|
2018-08-17 23:31:39 +02:00
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
|
|
|
paths:
|
|
|
|
- node_modules
|
2019-09-11 18:03:47 +02:00
|
|
|
- build-artifacts
|
2018-03-09 23:58:02 +01:00
|
|
|
|
2018-03-27 23:16:58 +02:00
|
|
|
prep-build:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2020-10-27 16:14:24 +01:00
|
|
|
environment:
|
|
|
|
NODE_OPTIONS: --max_old_space_size=1024
|
2018-03-27 23:16:58 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2018-03-27 23:16:58 +02:00
|
|
|
- run:
|
|
|
|
name: build:dist
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
command: yarn dist
|
2018-03-27 23:16:58 +02:00
|
|
|
- run:
|
|
|
|
name: build:debug
|
|
|
|
command: find dist/ -type f -exec md5sum {} \; | sort -k 2
|
2018-08-17 23:31:39 +02:00
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
2018-03-27 23:16:58 +02:00
|
|
|
paths:
|
|
|
|
- dist
|
2018-03-31 02:59:15 +02:00
|
|
|
- builds
|
2018-03-09 23:27:27 +01:00
|
|
|
|
2020-01-20 18:03:21 +01:00
|
|
|
prep-build-test:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2020-10-27 16:14:24 +01:00
|
|
|
environment:
|
|
|
|
NODE_OPTIONS: --max_old_space_size=1024
|
2020-01-20 18:03:21 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: Build extension for testing
|
|
|
|
command: yarn build:test
|
|
|
|
- run:
|
|
|
|
name: Move test build to 'dist-test' to avoid conflict with production build
|
|
|
|
command: mv ./dist ./dist-test
|
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
|
|
|
paths:
|
|
|
|
- dist-test
|
|
|
|
|
2020-02-08 20:56:33 +01:00
|
|
|
prep-build-storybook:
|
|
|
|
docker:
|
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: Build Storybook
|
|
|
|
command: yarn storybook:build
|
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
|
|
|
paths:
|
|
|
|
- .out
|
|
|
|
|
2018-03-09 22:15:36 +01:00
|
|
|
test-lint:
|
2018-03-09 21:38:28 +01:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-03-09 21:38:28 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2018-03-09 21:38:28 +01:00
|
|
|
- run:
|
2019-09-21 18:31:33 +02:00
|
|
|
name: Lint
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
command: yarn lint
|
2019-09-21 18:31:33 +02:00
|
|
|
- run:
|
|
|
|
name: Verify locales
|
|
|
|
command: yarn verify-locales --quiet
|
2018-03-09 22:37:13 +01:00
|
|
|
|
2019-11-19 16:46:10 +01:00
|
|
|
test-lint-shellcheck:
|
|
|
|
docker:
|
2020-09-21 22:08:15 +02:00
|
|
|
- image: koalaman/shellcheck-alpine@sha256:35882cba254810c7de458528011e935ba2c4f3ebcb224275dfa7ebfa930ef294
|
2019-11-19 16:46:10 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
2020-01-30 14:59:16 +01:00
|
|
|
- run: apk add --no-cache bash jq yarn
|
2019-11-19 16:46:10 +01:00
|
|
|
- run:
|
2020-09-21 22:08:15 +02:00
|
|
|
name: ShellCheck Lint
|
|
|
|
command: ./development/shellcheck.sh
|
2019-11-19 16:46:10 +01:00
|
|
|
|
2020-01-06 19:58:43 +01:00
|
|
|
test-lint-lockfile:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2020-01-06 19:58:43 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: lockfile-lint
|
|
|
|
command: yarn lint:lockfile
|
|
|
|
|
2019-06-06 17:56:27 +02:00
|
|
|
test-deps:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2019-06-06 17:56:27 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2019-07-25 00:54:16 +02:00
|
|
|
- run:
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
name: yarn audit
|
|
|
|
command: .circleci/scripts/yarn-audit
|
2018-05-02 20:05:39 +02:00
|
|
|
|
2019-02-20 14:57:49 +01:00
|
|
|
test-e2e-chrome:
|
2018-05-28 18:22:48 +02:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-05-28 18:22:48 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2020-01-20 18:03:21 +01:00
|
|
|
- run:
|
|
|
|
name: Move test build to dist
|
|
|
|
command: mv ./dist-test ./dist
|
2018-05-28 18:22:48 +02:00
|
|
|
- run:
|
2019-02-20 14:57:49 +01:00
|
|
|
name: test:e2e:chrome
|
2020-10-07 19:42:52 +02:00
|
|
|
command: |
|
|
|
|
if .circleci/scripts/test-run-e2e
|
|
|
|
then
|
|
|
|
yarn test:e2e:chrome
|
|
|
|
fi
|
2019-03-28 17:43:11 +01:00
|
|
|
no_output_timeout: 20m
|
2018-05-28 18:22:48 +02:00
|
|
|
- store_artifacts:
|
|
|
|
path: test-artifacts
|
|
|
|
destination: test-artifacts
|
|
|
|
|
2019-02-20 14:57:49 +01:00
|
|
|
test-e2e-firefox:
|
2018-05-28 18:22:48 +02:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-05-28 18:22:48 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- run:
|
2018-08-17 15:43:47 +02:00
|
|
|
name: Install Firefox
|
|
|
|
command: ./.circleci/scripts/firefox-install
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2020-01-20 18:03:21 +01:00
|
|
|
- run:
|
|
|
|
name: Move test build to dist
|
|
|
|
command: mv ./dist-test ./dist
|
2018-05-28 18:22:48 +02:00
|
|
|
- run:
|
2019-02-20 14:57:49 +01:00
|
|
|
name: test:e2e:firefox
|
2020-10-07 19:42:52 +02:00
|
|
|
command: |
|
|
|
|
if .circleci/scripts/test-run-e2e
|
|
|
|
then
|
|
|
|
yarn test:e2e:firefox
|
|
|
|
fi
|
2019-03-28 17:43:11 +01:00
|
|
|
no_output_timeout: 20m
|
2018-05-28 18:22:48 +02:00
|
|
|
- store_artifacts:
|
|
|
|
path: test-artifacts
|
|
|
|
destination: test-artifacts
|
|
|
|
|
2020-01-23 21:55:17 +01:00
|
|
|
benchmark:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2020-01-23 21:55:17 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: Move test build to dist
|
|
|
|
command: mv ./dist-test ./dist
|
|
|
|
- run:
|
|
|
|
name: Run page load benchmark
|
|
|
|
command: yarn benchmark:chrome --out test-artifacts/chrome/benchmark/pageload.json
|
|
|
|
- store_artifacts:
|
|
|
|
path: test-artifacts
|
|
|
|
destination: test-artifacts
|
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
|
|
|
paths:
|
|
|
|
- test-artifacts
|
|
|
|
|
2018-05-18 20:10:42 +02:00
|
|
|
job-publish-prerelease:
|
2018-03-31 02:59:15 +02:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-03-31 02:59:15 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2019-09-11 17:35:30 +02:00
|
|
|
- run:
|
|
|
|
name: build:source-map-explorer
|
|
|
|
command: ./development/source-map-explorer.sh
|
2018-04-03 20:11:00 +02:00
|
|
|
- store_artifacts:
|
|
|
|
path: dist/sourcemaps
|
|
|
|
destination: builds/sourcemaps
|
2018-03-31 02:59:15 +02:00
|
|
|
- store_artifacts:
|
|
|
|
path: builds
|
|
|
|
destination: builds
|
2018-03-30 10:01:16 +02:00
|
|
|
- store_artifacts:
|
|
|
|
path: test-artifacts
|
|
|
|
destination: test-artifacts
|
2019-09-11 16:47:21 +02:00
|
|
|
# important: generate sesify viz AFTER uploading builds as artifacts
|
|
|
|
- run:
|
|
|
|
name: build:sesify-viz
|
|
|
|
command: ./.circleci/scripts/create-sesify-viz
|
|
|
|
- store_artifacts:
|
|
|
|
path: build-artifacts
|
|
|
|
destination: build-artifacts
|
2018-03-31 02:59:15 +02:00
|
|
|
- run:
|
|
|
|
name: build:announce
|
|
|
|
command: ./development/metamaskbot-build-announce.js
|
2018-05-18 20:29:10 +02:00
|
|
|
|
|
|
|
job-publish-release:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-05-18 20:29:10 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2018-04-03 21:36:46 +02:00
|
|
|
- run:
|
|
|
|
name: sentry sourcemaps upload
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
command: yarn sentry:publish
|
2019-09-11 16:44:36 +02:00
|
|
|
- run:
|
|
|
|
name: Create GitHub release
|
|
|
|
command: |
|
|
|
|
.circleci/scripts/release-create-gh-release
|
|
|
|
- run:
|
|
|
|
name: Create GitHub Pull Request to sync master with develop
|
|
|
|
command: .circleci/scripts/release-create-master-pr
|
2020-02-08 20:56:33 +01:00
|
|
|
|
|
|
|
job-publish-storybook:
|
|
|
|
docker:
|
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
|
|
|
steps:
|
|
|
|
- add_ssh_keys:
|
|
|
|
fingerprints:
|
|
|
|
- "5e:a3:2d:35:b6:25:b5:87:b1:41:11:0d:77:50:96:73"
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: storybook:deploy
|
|
|
|
command: |
|
|
|
|
git remote add storybook git@github.com:MetaMask/metamask-storybook.git
|
|
|
|
yarn storybook:deploy
|
2018-03-30 10:01:16 +02:00
|
|
|
|
2018-03-09 22:37:13 +01:00
|
|
|
test-unit:
|
2018-03-09 22:15:36 +01:00
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-03-09 22:15:36 +01:00
|
|
|
steps:
|
|
|
|
- checkout
|
2018-08-17 23:31:39 +02:00
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
2018-03-09 22:15:36 +01:00
|
|
|
- run:
|
|
|
|
name: test:coverage
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
command: yarn test:coverage
|
2019-08-14 15:11:01 +02:00
|
|
|
- persist_to_workspace:
|
|
|
|
root: .
|
|
|
|
paths:
|
|
|
|
- .nyc_output
|
|
|
|
- coverage
|
2019-10-24 15:54:32 +02:00
|
|
|
test-unit-global:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2019-10-24 15:54:32 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: test:unit:global
|
|
|
|
command: yarn test:unit:global
|
2020-08-04 19:21:46 +02:00
|
|
|
|
|
|
|
validate-source-maps:
|
|
|
|
docker:
|
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: Validate source maps
|
|
|
|
command: yarn validate-source-maps
|
|
|
|
|
2018-09-26 02:44:57 +02:00
|
|
|
test-mozilla-lint:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-09-26 02:44:57 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: test:mozilla-lint
|
Switch from `npm` to `yarn` (#6843)
As a solution to the constant lockfile churn issues we've had with
`npm`, the project now uses `yarn` to manage dependencies.
The `package-lock.json` file has been replaced with `yarn.lock`, which
was created using `yarn import`. It should approximate the contents of
`package-lock.json` fairly well, though there may be some changes due to
deduplication. The codeowners file has been updated to reference this
new lockfile.
All documentation and npm scripts have been updated to reference `yarn`
rather than `npm`. Note that running scripts using `npm run` still works
fine, but it seemed better to switch those to `yarn` as well to avoid
confusion.
The `npm-audit` Bash script has been replaced with `yarn-audit`. The
output of `yarn audit` is a bit different than `npm audit` in that it
returns a bitmask to describe which severity issues were found. This
made it simpler to check the results directly from the Bash script, so
the associated `npm-audit-check.js` script was no longer required. The
output should be exactly the same, and the information is still sourced
from the same place (the npm registry).
The new `yarn-audit` script does have an external dependency: `jq`.
However, `jq` is already assumed to be present by another CI script, and
is present on all CI images we use. `jq` was not added to `package.json`
as a dependency because there is no official package on the npm
registry, just wrapper scripts. We don't need it anywhere exept on CI
anyway.
The section in `CONTRIBUTING` about how to develop inside the
`node_modules` folder was removed, as the advice was a bit dated, and
wasn't specific to this project anyway.
2019-07-30 20:36:23 +02:00
|
|
|
command: NODE_OPTIONS=--max_old_space_size=3072 yarn mozilla-lint
|
2018-03-09 22:37:13 +01:00
|
|
|
|
2018-03-28 01:09:11 +02:00
|
|
|
all-tests-pass:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2018-03-28 01:09:11 +02:00
|
|
|
steps:
|
|
|
|
- run:
|
2018-03-28 01:10:27 +02:00
|
|
|
name: All Tests Passed
|
2018-08-17 15:43:47 +02:00
|
|
|
command: echo 'weew - everything passed!'
|
2019-07-18 07:51:47 +02:00
|
|
|
|
2019-08-13 17:59:10 +02:00
|
|
|
coveralls-upload:
|
|
|
|
docker:
|
2020-02-06 00:50:06 +01:00
|
|
|
- image: circleci/node@sha256:e16740707de2ebed45c05d507f33ef204902349c7356d720610b5ec6a35d3d88
|
2019-08-13 17:59:10 +02:00
|
|
|
steps:
|
|
|
|
- checkout
|
|
|
|
- attach_workspace:
|
|
|
|
at: .
|
|
|
|
- run:
|
|
|
|
name: Coveralls upload
|
|
|
|
command: yarn test:coveralls-upload
|