Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
221 changes: 221 additions & 0 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,221 @@
name: CI/CD Pipeline

on:
push:
branches: [ main, master, develop, 'feature/**' ]
pull_request:
branches: [ main, master, develop ]

env:
NODE_VERSION: '20'

jobs:
# =====================================================
# Job 1: 代码质量检查 (Lint & Type Check)
# =====================================================
lint-and-typecheck:
name: Code Quality Check
runs-on: ubuntu-latest
timeout-minutes: 10

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}

- name: Setup pnpm
uses: pnpm/action-setup@v4
with:
run_install: false

- name: Get pnpm store directory
shell: bash
run: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV

- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-

- name: Install dependencies
run: pnpm install --frozen-lockfile

- name: Run ESLint
run: pnpm run lint

- name: Type check
run: npx tsc --noEmit

# =====================================================
# Job 2: 单元测试 (Unit Tests)
# =====================================================
unit-tests:
name: Unit Tests
runs-on: windows-latest # Windows runner for Electron app
timeout-minutes: 15
needs: lint-and-typecheck

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}

- name: Setup pnpm
uses: pnpm/action-setup@v4
with:
run_install: false

- name: Get pnpm store directory
shell: bash
run: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV

- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-

- name: Install dependencies
run: pnpm install --frozen-lockfile

- name: Run unit tests
run: pnpm run test:unit

- name: Generate coverage report
run: pnpm run test:coverage

- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
files: ./coverage/lcov.info
flags: unittests
name: codecov-umbrella
fail_ci_if_error: false

# =====================================================
# Job 3: 构建测试 (Build Test)
# =====================================================
build-test:
name: Build Test
runs-on: windows-latest
timeout-minutes: 20
needs: unit-tests

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}

- name: Setup pnpm
uses: pnpm/action-setup@v4
with:
run_install: false

- name: Get pnpm store directory
shell: bash
run: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV

- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-

- name: Install dependencies
run: pnpm install --frozen-lockfile

- name: Package application (dry run)
run: pnpm run package

# =====================================================
# Job 4: 发布检查 (Release Check)
# =====================================================
release-check:
name: Release Check
runs-on: windows-latest
timeout-minutes: 30
needs: [unit-tests, build-test]
if: github.ref == 'refs/heads/main' || startsWith(github.ref, 'refs/tags/v')

steps:
- name: Checkout code
uses: actions/checkout@v4

- name: Setup Node.js ${{ env.NODE_VERSION }}
uses: actions/setup-node@v4
with:
node-version: ${{ env.NODE_VERSION }}

- name: Setup pnpm
uses: pnpm/action-setup@v4
with:
run_install: false

- name: Get pnpm store directory
shell: bash
run: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV

- name: Setup pnpm cache
uses: actions/cache@v4
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-

- name: Install dependencies
run: pnpm install --frozen-lockfile

- name: Build and package
run: |
pnpm run package
pnpm run make

# =====================================================
# Job 5: 测试结果通知 (Notifications)
# =====================================================
test-notify:
name: Test Results Summary
runs-on: ubuntu-latest
needs: [lint-and-typecheck, unit-tests, build-test]
if: always()

steps:
- name: Test Summary
run: |
echo "========================================="
echo " Test Results Summary"
echo "========================================="
echo "Lint & Type Check: ${{ needs.lint-and-typecheck.result }}"
echo "Unit Tests: ${{ needs.unit-tests.result }}"
echo "Build Test: ${{ needs.build-test.result }}"
echo "========================================="

- name: Job Status
if: needs.lint-and-typecheck.result == 'success' && needs.unit-tests.result == 'success' && needs.build-test.result == 'success'
run: echo "✅ All jobs passed!"

- name: Job Status (Failed)
if: needs.lint-and-typecheck.result != 'success' || needs.unit-tests.result != 'success' || needs.build-test.result != 'success'
run: |
echo "❌ Some jobs failed!"
exit 1
Loading
Loading