Skip to content

ci: avoid husky on CI #89

ci: avoid husky on CI

ci: avoid husky on CI #89

Workflow file for this run

name: build
on:
push:
branches: [master, main]
pull_request:
branches: [master, main]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
node-version:
- 18
- 20
# okay... so it's super helpful to not need to re-acquire/re-build, which
# means putting *everything* into one job. We just need to be judicious
# with 'if' to skip some steps based on matrix stuff...
steps:
- uses: actions/checkout@v3
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}
- uses: actions/cache@v3
with:
path: ~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- run: npm ci
- run: npm run build --if-present
- run: npm run lint
- run: npm run test
- run: npm run coverage
- run: npm run codecov
env:
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
continue-on-error: true
release:
needs: build
if: ${{ needs.build.result == 'success' && github.event_name == 'push' }}
runs-on: ubuntu-latest
steps:
# sadly, we have to re-do the build... but we can skip lint/test
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 20
- uses: actions/cache@v3
with:
path: ~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-node-
- run: npm ci
- run: npm run build --if-present
- run: npm run release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
status:
needs: [build, release]
if: ${{ contains(needs.*.result, 'failure') }}
runs-on: ubuntu-latest
steps:
- uses: act10ns/slack@v1
with:
status: failure
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}