fix: operator_ui/package.json to reduce vulnerabilities #57
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Continuous Integration Workflow | |
on: [push] | |
env: | |
CACHE_VERSION: 9c3bfa173ea0aca1f9939f8896feb4a4 | |
jobs: | |
core: | |
strategy: | |
fail-fast: false | |
matrix: | |
cmd: ['go_core_tests'] | |
name: Core Tests | |
runs-on: [self-hosted, sdlc-ghr-prod] | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
env: | |
DATABASE_URL: postgres://chainlink@postgres:5432/chainlink_test?sslmode=disable | |
services: | |
postgres: | |
image: postgres | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
env: | |
POSTGRES_USER: postgres | |
POSTGRES_HOST_AUTH_METHOD: trust | |
# Set health checks to wait until postgres has started | |
options: >- | |
--health-cmd pg_isready | |
--health-interval 10s | |
--health-timeout 5s | |
--health-retries 5 | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Set up Postgres user | |
uses: docker://postgres | |
with: | |
args: psql -v ON_ERROR_STOP=1 --username postgres -h postgres -c "CREATE USER chainlink NOSUPERUSER CREATEDB;" | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Cache Go vendor packages | |
uses: actions/cache@v2 | |
with: | |
path: /go/pkg/mod | |
key: go-mod-${{ env.CACHE_VERSION }}-${{ hashFiles('go.sum') }} | |
restore-keys: | | |
go-mod-${{ env.CACHE_VERSION }} | |
- name: Download Go vendor packages | |
run: go mod download | |
- name: Set up Yarn for Contracts | |
run: yarn setup:contracts | |
- name: Setup DB | |
run: go run ./core local db preparetest | |
- name: Run tests | |
run: ./tools/bin/${{ matrix.cmd }} | |
- name: Store logs artifacts on failure | |
if: failure() | |
uses: actions/upload-artifact@v1 | |
with: | |
name: ${{ matrix.cmd }}_logs | |
path: ./output.txt | |
- name: Print postgres logs | |
if: always() | |
uses: docker://docker:latest | |
with: | |
args: logs ${{ job.services.postgres.id }} | |
integration: | |
name: Integration tests | |
runs-on: [self-hosted, sdlc-ghr-prod] | |
strategy: | |
matrix: | |
test: ['test', 'test:ts'] | |
geth: [true, false] | |
explorer: ['latest', 'develop'] | |
env: | |
GETH_MODE: ${{ matrix.geth }} | |
CI: true | |
CHAINLINK_DB_NAME: postgres | |
EXPLORER_DOCKER_TAG: ${{ matrix.explorer }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Login to DockerHub | |
uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
- name: Run tests | |
run: cd ./tools/docker && timeout --foreground 1200s ./compose ${{ matrix.test }} | |
- name: Capture logs on failure | |
if: failure() | |
run: cd ./tools/docker && CI_SKIP_PRE_HOOK=1 ./compose logs:test:save | |
- name: Store logs artifacts on failure | |
if: failure() | |
uses: actions/upload-artifact@v1 | |
with: | |
name: logs | |
path: ./tools/docker/logs | |
solidity: | |
name: Solidity | |
runs-on: [self-hosted, sdlc-ghr-prod] | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Run tests | |
run: ./tools/ci/solidity_test | |
operator-ui: | |
name: Operator UI | |
runs-on: ubuntu-latest | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Run Operator UI tests | |
run: ./tools/ci/operator_ui_test | |
lint: | |
name: Yarn lint | |
runs-on: ubuntu-latest | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Run Yarn lint | |
run: yarn lint | |
prettier: | |
name: Prettier formatting check | |
runs-on: ubuntu-latest | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Run Yarn lint | |
run: yarn prettier:check | |
prepublish_npm: | |
name: Prepublish NPM | |
runs-on: [self-hosted, sdlc-ghr-prod] | |
container: | |
image: smartcontract/builder:1.0.37 | |
credentials: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Cache Yarn dependencies | |
uses: actions/cache@v2 | |
with: | |
path: /usr/local/share/.cache/yarn | |
key: yarn-${{ env.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} | |
restore-keys: | | |
yarn-${{ env.CACHE_VERSION }} | |
- name: Install Yarn dependencies | |
run: make yarndep | |
- name: Run prepublish NPM test | |
run: ./tools/ci/prepublish_npm_test | |
build-chainlink: | |
name: Build chainlink image | |
runs-on: [self-hosted, sdlc-ghr-prod] | |
strategy: | |
matrix: | |
dockerfile: [core/chainlink.Dockerfile] | |
steps: | |
- name: Checkout the repo | |
uses: actions/checkout@v2 | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: '${{ secrets.GHA_AWS_ACCESS_KEY_ID }}' | |
aws-secret-access-key: '${{ secrets.GHA_AWS_SECRET_ACCESS_KEY }}' | |
aws-region: '${{ secrets.AWS_DEFAULT_REGION }}' | |
role-to-assume: '${{ secrets.GHA_AWS_ROLE_TO_ASSUME }}' | |
role-duration-seconds: 1200 | |
role-session-name: 'temp-session' | |
role-skip-session-tagging: true | |
- name: Docker login to ECR | |
uses: aws-actions/amazon-ecr-login@v1 | |
id: login-ecr | |
# https://github.com/docker/build-push-action/issues/20 | |
- name: Get ecr password | |
id: get-ecr-password | |
run: | | |
aws ecr get-login-password \ | |
| { | |
read PASSWORD | |
echo "::add-mask::$PASSWORD" | |
echo "::set-output name=password::$PASSWORD" | |
} | |
- name: Login to DockerHub | |
uses: docker/login-action@v1 | |
with: | |
username: ${{ secrets.DOCKER_READONLY_USERNAME }} | |
password: ${{ secrets.DOCKER_READONLY_PASSWORD }} | |
- name: Build image | |
uses: docker/build-push-action@v1 | |
with: | |
registry: ${{ steps.login-ecr.outputs.registry }} | |
repository: ${{ secrets.ECR_REPO }} | |
username: AWS # temporary | |
password: ${{ steps.get-ecr-password.outputs.password }} # temporary | |
dockerfile: ${{ matrix.dockerfile }} | |
build_args: COMMIT_SHA=${{ github.sha }},ENVIRONMENT=release | |
tags: githubactions | |
add_git_labels: true | |
tag_with_ref: true | |
tag_with_sha: true | |
push: false |