Skip to content

test: improve coverage to 80.53% with sitemap edge cases #232

test: improve coverage to 80.53% with sitemap edge cases

test: improve coverage to 80.53% with sitemap edge cases #232

Workflow file for this run

name: CI
on:
push:
branches: [main, develop]
pull_request:
branches: [main]
jobs:
test:
name: Test Suite
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [20.x, 22.x]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
cache: "npm"
- name: Install dependencies
run: npm ci
- name: Clean up any existing memory files
run: rm -rf .documcp
- name: Type check
run: npm run typecheck
- name: Lint code
run: npm run lint
- name: Run tests
run: npm test -- --forceExit
- name: Clean up memory files before coverage run
run: rm -rf .documcp
- name: Run tests with coverage
run: npm test -- --coverage --forceExit
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
file: ./coverage/lcov.info
flags: unittests
name: codecov-umbrella
- name: Performance benchmarks
run: npm run test:performance
build:
name: Build Verification
runs-on: ubuntu-latest
needs: test
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: "20.x"
cache: "npm"
- name: Install dependencies
run: npm ci
- name: Clean up any existing memory files
run: rm -rf .documcp
- name: Build project
run: npm run build
- name: Verify build output
run: |
test -f dist/index.js
test -f dist/index.d.ts
- name: Package verification
run: npm pack --dry-run
security:
name: Security Audit
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: "20.x"
cache: "npm"
- name: Install dependencies
run: npm ci
- name: Run security audit (dev dependencies)
run: npm audit --audit-level=moderate || echo "⚠️ Some dev dependency vulnerabilities found - see Security tab for details"
continue-on-error: true
- name: Check for high severity vulnerabilities (production)
run: npm audit --audit-level=high --production
commitlint:
name: Commit Message Validation
runs-on: ubuntu-latest
if: github.event_name == 'pull_request'
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: "20.x"
cache: "npm"
- name: Install dependencies
run: npm ci
- name: Validate commit messages
run: npx commitlint --from ${{ github.event.pull_request.base.sha }} --to ${{ github.event.pull_request.head.sha }} --verbose