Skip to content

chore: eslint -> biome + enhance types + codeql #13

chore: eslint -> biome + enhance types + codeql

chore: eslint -> biome + enhance types + codeql #13

Workflow file for this run

name: ci
permissions: {}
on:
pull_request:
branches:
- master
paths-ignore:
- "**.md"
push:
branches:
- master
paths-ignore:
- "**.md"
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
cancel-in-progress: true
jobs:
test:
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- name: Checkout repository
uses: actions/checkout@v5
with:
persist-credentials: false
- name: Set up pnpm
uses: pnpm/action-setup@v4
with:
version: latest
run_install: false
- name: Set up Node
uses: actions/setup-node@v6
with:
node-version-file: ".nvmrc"
cache: "pnpm"
- name: Install dependencies
run: pnpm install --frozen-lockfile
- name: Check formatting
run: pnpm run fmt:check
- name: Lint code
run: pnpm run lint:check
- name: Build project
run: pnpm run build
- name: Upload build artifacts
uses: actions/upload-artifact@v5
with:
name: dist
path: dist
codeql:
name: analyze (${{ matrix.language }})
runs-on: ubuntu-latest
permissions:
security-events: write
actions: read
contents: read
strategy:
fail-fast: false
matrix:
include:
- language: actions
build-mode: none
- language: typescript
build-mode: none
steps:
- name: Checkout repository
uses: actions/checkout@v5
with:
persist-credentials: false
- name: Initialize CodeQL
uses: github/codeql-action/init@v4
with:
languages: ${{ matrix.language }}
build-mode: ${{ matrix.build-mode }}
- name: Set up pnpm
if: matrix.language == 'typescript'
uses: pnpm/action-setup@v4
with:
version: latest
run_install: false
- name: Set up Node
if: matrix.language == 'typescript'
uses: actions/setup-node@v6
with:
node-version-file: ".nvmrc"
cache: "pnpm"
- name: Install dependencies
if: matrix.language == 'typescript'
run: pnpm install --frozen-lockfile
- name: Build project
if: matrix.language == 'typescript'
run: pnpm run build
- name: Perform CodeQL Analysis
uses: github/codeql-action/analyze@v4
with:
category: "/language:${{matrix.language}}"
ci-success:
runs-on: ubuntu-latest
if: always()
needs:
- test
- codeql
timeout-minutes: 30
steps:
- name: Decide whether the needed jobs succeeded or failed
uses: re-actors/alls-green@05ac9388f0aebcb5727afa17fcccfecd6f8ec5fe # release/v1
with:
jobs: ${{ toJSON(needs) }}