AgentSkillsCN

windsurf-ci-integration

配置Windsurf CI/CD与GitHub Actions及测试的集成。 在设置自动化测试、配置CI流水线或将Windsurf测试集成到构建流程时使用。 可通过“windsurf CI”、“windsurf GitHub Actions”、“windsurf automated tests”、“CI windsurf”等短语触发。

SKILL.md
--- frontmatter
name: windsurf-ci-integration
description: |
  Configure Windsurf CI/CD integration with GitHub Actions and testing.
  Use when setting up automated testing, configuring CI pipelines,
  or integrating Windsurf tests into your build process.
  Trigger with phrases like "windsurf CI", "windsurf GitHub Actions",
  "windsurf automated tests", "CI windsurf".
allowed-tools: Read, Write, Edit, Bash(gh:*)
version: 1.0.0
license: MIT
author: Jeremy Longshore <jeremy@intentsolutions.io>

Windsurf CI Integration

Overview

Set up CI/CD pipelines for Windsurf integrations with automated testing.

Prerequisites

  • GitHub repository with Actions enabled
  • Windsurf test API key
  • npm/pnpm project configured

Instructions

Step 1: Create GitHub Actions Workflow

Create .github/workflows/windsurf-integration.yml:

yaml
name: Windsurf Integration Tests

on:
  push:
    branches: [main]
  pull_request:
    branches: [main]

env:
  WINDSURF_API_KEY: ${{ secrets.WINDSURF_API_KEY }}

jobs:
  test:
    runs-on: ubuntu-latest
    env:
      WINDSURF_API_KEY: ${{ secrets.WINDSURF_API_KEY }}
    steps:
      - uses: actions/checkout@v4
      - uses: actions/setup-node@v4
        with:
          node-version: '20'
          cache: 'npm'
      - run: npm ci
      - run: npm test -- --coverage
      - run: npm run test:integration

Step 2: Configure Secrets

bash
gh secret set WINDSURF_API_KEY --body "sk_test_***"

Step 3: Add Integration Tests

typescript
describe('Windsurf Integration', () => {
  it.skipIf(!process.env.WINDSURF_API_KEY)('should connect', async () => {
    const client = getWindsurfClient();
    const result = await client.healthCheck();
    expect(result.status).toBe('ok');
  });
});

Output

  • Automated test pipeline
  • PR checks configured
  • Coverage reports uploaded
  • Release workflow ready

Error Handling

IssueCauseSolution
Secret not foundMissing configurationAdd secret via gh secret set
Tests timeoutNetwork issuesIncrease timeout or mock
Auth failuresInvalid keyCheck secret value

Examples

Release Workflow

yaml
on:
  push:
    tags: ['v*']

jobs:
  release:
    runs-on: ubuntu-latest
    env:
      WINDSURF_API_KEY: ${{ secrets.WINDSURF_API_KEY_PROD }}
    steps:
      - uses: actions/checkout@v4
      - uses: actions/setup-node@v4
        with:
          node-version: '20'
      - run: npm ci
      - name: Verify Windsurf production readiness
        run: npm run test:integration
      - run: npm run build
      - run: npm publish

Branch Protection

yaml
required_status_checks:
  - "test"
  - "windsurf-integration"

Resources

Next Steps

For deployment patterns, see windsurf-deploy-integration.