2d9cd0ad1a
test.yml: Use dorny/paths-filter to detect changed paths. Backend tests only run when backend/**, biome.json, or the workflow itself changes. Frontend build only runs when frontend/**, biome.json, or the workflow changes. Jobs skipped via job-level 'if:' are treated as passed by GitHub required checks. codeql.yml: Only run on push/PR when JS/TS source files, package files, or CodeQL config changes. Weekly schedule and manual dispatch remain unfiltered.
65 lines
1.5 KiB
YAML
65 lines
1.5 KiB
YAML
name: "CodeQL"
|
|
|
|
on:
|
|
push:
|
|
branches: [main]
|
|
paths:
|
|
- '**.js'
|
|
- '**.ts'
|
|
- '**.tsx'
|
|
- '**.jsx'
|
|
- 'backend/package.json'
|
|
- 'backend/package-lock.json'
|
|
- 'frontend/package.json'
|
|
- 'frontend/package-lock.json'
|
|
- '.github/codeql/**'
|
|
- '.github/workflows/codeql.yml'
|
|
pull_request:
|
|
branches: [main]
|
|
paths:
|
|
- '**.js'
|
|
- '**.ts'
|
|
- '**.tsx'
|
|
- '**.jsx'
|
|
- 'backend/package.json'
|
|
- 'backend/package-lock.json'
|
|
- 'frontend/package.json'
|
|
- 'frontend/package-lock.json'
|
|
- '.github/codeql/**'
|
|
- '.github/workflows/codeql.yml'
|
|
schedule:
|
|
- cron: "0 6 * * 1" # Weekly on Monday at 6am UTC
|
|
workflow_dispatch: # Allow manual trigger
|
|
|
|
jobs:
|
|
analyze:
|
|
name: Analyze
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
actions: read
|
|
contents: read
|
|
security-events: write
|
|
|
|
strategy:
|
|
fail-fast: false
|
|
matrix:
|
|
language: [javascript-typescript]
|
|
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@v4
|
|
|
|
- name: Initialize CodeQL
|
|
uses: github/codeql-action/init@v3
|
|
with:
|
|
languages: ${{ matrix.language }}
|
|
config-file: ./.github/codeql/codeql-config.yml
|
|
|
|
- name: Autobuild
|
|
uses: github/codeql-action/autobuild@v3
|
|
|
|
- name: Perform CodeQL Analysis
|
|
uses: github/codeql-action/analyze@v3
|
|
with:
|
|
category: "/language:${{ matrix.language }}"
|