Skip to content

ci: upgrade actions (#700) #1804

ci: upgrade actions (#700)

ci: upgrade actions (#700) #1804

Workflow file for this run

name: Build, Test and Deploy
on:
pull_request:
push:
branches: ["main", "beta"]
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
lint:
name: Lint
runs-on: ubuntu-latest
timeout-minutes: 10
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: actions/setup-node@v4
with:
node-version: 18.14.0
cache: 'yarn'
- name: Cache node_modules
uses: actions/cache@v4
id: cache-primes
with:
path: "**/node_modules"
key: ${{ runner.os }}-node_modules-${{ hashFiles('**/yarn.lock') }}
- name: Install dependencies
if: steps.cache-primes.outputs.cache-hit != 'true'
run: yarn install --frozen-lockfile --non-interactive --production=false
- name: Lint commit message
uses: wagoid/commitlint-github-action@456526eec71276a59e74aafdfe06a9632ac2eee1
- name: Lint javascript and typescript
run: yarn lint
build:
name: Build
runs-on: ubuntu-latest
needs: [lint]
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 18.14.0
cache: 'yarn'
- name: Cache node_modules
uses: actions/cache@v4
with:
path: "**/node_modules"
key: ${{ runner.os }}-node_modules-${{ hashFiles('**/yarn.lock') }}
- name: Build
run: yarn build
test:
name: Test
runs-on: ubuntu-latest
timeout-minutes: 10
needs: [lint]
strategy:
matrix:
node: [18, 20]
include:
- node: 18
withCoverage: ${{ true }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
cache: 'yarn'
- name: Cache node_modules
uses: actions/cache@v4
with:
path: "**/node_modules"
key: ${{ runner.os }}-node_modules-${{ hashFiles('**/yarn.lock') }}
- name: Login on dockerhub
run: echo ${{ secrets.DOCKER_PASSWORD }} | docker login -u ${{ secrets.DOCKER_USERNAME }} --password-stdin
- name: Start docker container
run: docker compose up -d; sleep 15
- name: Test with Node ${{ matrix.node }}
if: ${{ !matrix.withCoverage }}
run: yarn test
- name: Test with Node ${{ matrix.node }} & Send coverage
uses: paambaati/codeclimate-action@5f637ccd517bc8960de0fe59379dd922bcba9486
if: matrix.withCoverage && matrix.node == 18
env:
CC_TEST_REPORTER_ID: ${{ secrets.CC_TEST_REPORTER_ID }}
with:
coverageCommand: yarn test:coverage
- name: Test prepack
run: yarn prepack
- name: Test postpack
run: yarn postpack
deploy:
name: Release package
runs-on: ubuntu-latest
timeout-minutes: 10
needs: [build, test]
if: github.event_name == 'push' && (github.ref == 'refs/heads/main' || github.ref == 'refs/heads/beta')
steps:
- uses: actions/checkout@v4
with:
ref: ${{ github.ref }}
persist-credentials: false # GITHUB_TOKEN must not be set for the semantic release
- uses: actions/setup-node@v4
with:
node-version: 18.14.0
cache: 'yarn'
- uses: actions/cache@v4
with:
path: "**/node_modules"
key: ${{ runner.os }}-node_modules-${{ hashFiles('**/yarn.lock') }}
- name: Build
run: yarn build
- name: Get Semantic Release current version
id: semantic_version
run: |
VERSION=`node -p "require('./package.json').devDependencies['semantic-release']"`
echo "version=$VERSION" >> "$GITHUB_OUTPUT"
- name: Semantic Release
uses: cycjimmy/semantic-release-action@61680d0e9b02ff86f5648ade99e01be17f0260a4
id: semantic
with:
semantic_version: ${{ steps.semantic_version.outputs.version }}
env:
GITHUB_TOKEN: ${{ secrets.GH_TOKEN }}
GIT_AUTHOR_EMAIL: ${{ secrets.GIT_AUTHOR_EMAIL }}
GIT_AUTHOR_NAME: ${{ secrets.GIT_AUTHOR_NAME }}
GIT_COMMITTER_EMAIL: ${{ secrets.GIT_COMMITTER_EMAIL }}
GIT_COMMITTER_NAME: ${{ secrets.GIT_COMMITTER_NAME }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }}