Configure Clay CI/CD integration with GitHub Actions and testing. Use when setting up automated testing, configuring CI pipelines, or integrating Clay tests into your build process. Trigger with phrases like "clay CI", "clay GitHub Actions", "clay automated tests", "CI clay".
View on GitHubjeremylongshore/claude-code-plugins-plus-skills
clay-pack
plugins/saas-packs/clay-pack/skills/clay-ci-integration/SKILL.md
February 1, 2026
Select agents to install to:
npx add-skill https://github.com/jeremylongshore/claude-code-plugins-plus-skills/blob/main/plugins/saas-packs/clay-pack/skills/clay-ci-integration/SKILL.md -a claude-code --skill clay-ci-integrationInstallation paths:
.claude/skills/clay-ci-integration/# Clay CI Integration
## Overview
Set up CI/CD pipelines for Clay integrations with automated testing.
## Prerequisites
- GitHub repository with Actions enabled
- Clay test API key
- npm/pnpm project configured
## Instructions
### Step 1: Create GitHub Actions Workflow
Create `.github/workflows/clay-integration.yml`:
```yaml
name: Clay Integration Tests
on:
push:
branches: [main]
pull_request:
branches: [main]
env:
CLAY_API_KEY: ${{ secrets.CLAY_API_KEY }}
jobs:
test:
runs-on: ubuntu-latest
env:
CLAY_API_KEY: ${{ secrets.CLAY_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 CLAY_API_KEY --body "sk_test_***"
```
### Step 3: Add Integration Tests
```typescript
describe('Clay Integration', () => {
it.skipIf(!process.env.CLAY_API_KEY)('should connect', async () => {
const client = getClayClient();
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
| Issue | Cause | Solution |
|-------|-------|----------|
| Secret not found | Missing configuration | Add secret via `gh secret set` |
| Tests timeout | Network issues | Increase timeout or mock |
| Auth failures | Invalid key | Check secret value |
## Examples
### Release Workflow
```yaml
on:
push:
tags: ['v*']
jobs:
release:
runs-on: ubuntu-latest
env:
CLAY_API_KEY: ${{ secrets.CLAY_API_KEY_PROD }}
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
- run: npm ci
- name: Verify Clay production readiness
run: npm run test:integration