klaviyo-ci-integration

Configure Klaviyo CI/CD integration with GitHub Actions and testing. Use when setting up automated testing, configuring CI pipelines, or integrating Klaviyo tests into your build process. Trigger with phrases like "klaviyo CI", "klaviyo GitHub Actions", "klaviyo automated tests", "CI klaviyo".

claude-code
4 Tools
klaviyo-pack Plugin
saas packs Category

Allowed Tools

ReadWriteEditBash(gh:*)

Provided by Plugin

klaviyo-pack

Claude Code skill pack for Klaviyo (24 skills)

saas packs v1.0.0
View Plugin

Installation

This skill is included in the klaviyo-pack plugin:

/plugin install klaviyo-pack@claude-code-plugins-plus

Click to copy

Instructions

Klaviyo CI Integration

Overview

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

Prerequisites

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

Instructions

Step 1: Create GitHub Actions Workflow

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


name: Klaviyo Integration Tests

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

env:
  KLAVIYO_API_KEY: ${{ secrets.KLAVIYO_API_KEY }}

jobs:
  test:
    runs-on: ubuntu-latest
    env:
      KLAVIYO_API_KEY: ${{ secrets.KLAVIYO_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


gh secret set KLAVIYO_API_KEY --body "sk_test_***"

Step 3: Add Integration Tests


describe('Klaviyo Integration', () => {
  it.skipIf(!process.env.KLAVIYO_API_KEY)('should connect', async () => {
    const client = getKlaviyoClient();
    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


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

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

Branch Protection


required_status_checks:
  - "test"
  - "klaviyo-integration"

Resources

Next Steps

For deployment patterns, see klaviyo-deploy-integration.

Ready to use klaviyo-pack?