Claude-code-plugins-plus-skills finta-ci-integration
install
source · Clone the upstream repo
git clone https://github.com/jeremylongshore/claude-code-plugins-plus-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/jeremylongshore/claude-code-plugins-plus-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/saas-packs/finta-pack/skills/finta-ci-integration" ~/.claude/skills/jeremylongshore-claude-code-plugins-plus-skills-finta-ci-integration && rm -rf "$T"
manifest:
plugins/saas-packs/finta-pack/skills/finta-ci-integration/SKILL.mdsource content
Finta CI Integration
Overview
Set up CI/CD for Finta fundraising integrations: run unit tests with mocked investor pipeline data on every PR, validate live API connectivity for round and investor queries on merge to main. Finta centralizes fundraising CRM data including rounds, investor contacts, and pipeline stages, so CI focuses on verifying data sync logic, pipeline stage transitions, and automated investor reporting workflows.
GitHub Actions Workflow
# .github/workflows/finta-ci.yml name: Finta CI on: pull_request: paths: ['src/finta/**', 'tests/**'] push: branches: [main] jobs: unit-tests: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: { node-version: '20' } - run: npm ci - run: npm test -- --reporter=verbose integration-tests: if: github.ref == 'refs/heads/main' needs: unit-tests runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - uses: actions/setup-node@v4 with: { node-version: '20' } - run: npm ci - run: npm run test:integration env: FINTA_API_KEY: ${{ secrets.FINTA_API_KEY }}
Mock-Based Unit Tests
// tests/finta-service.test.ts import { describe, it, expect, vi } from 'vitest'; import { summarizeRound } from '../src/finta-service'; const mockRound = { id: 'round_seed_01', name: 'Seed Round', target_amount: 2_000_000, raised_amount: 1_250_000, investors: [ { name: 'Acme Ventures', committed: 500_000, stage: 'committed' }, { name: 'Beta Capital', committed: 750_000, stage: 'committed' }, ], }; vi.mock('../src/finta-client', () => ({ FintaClient: vi.fn().mockImplementation(() => ({ getRound: vi.fn().mockResolvedValue(mockRound), listInvestors: vi.fn().mockResolvedValue({ investors: mockRound.investors, total: 2 }), getPipelineSummary: vi.fn().mockResolvedValue({ stages: { committed: 2, in_progress: 3 } }), })), })); describe('Finta Service', () => { it('summarizes fundraising round progress', async () => { const summary = await summarizeRound('round_seed_01'); expect(summary.percentRaised).toBeCloseTo(62.5); expect(summary.investorCount).toBe(2); }); });
Integration Tests
// tests/integration/finta.integration.test.ts import { describe, it, expect } from 'vitest'; const hasKey = !!process.env.FINTA_API_KEY; describe.skipIf(!hasKey)('Finta Live API', () => { it('lists fundraising rounds', async () => { const res = await fetch('https://api.finta.io/v1/rounds', { headers: { Authorization: `Bearer ${process.env.FINTA_API_KEY}` }, }); expect(res.status).toBe(200); const body = await res.json(); expect(body).toHaveProperty('rounds'); }); });
Error Handling
| CI Issue | Cause | Fix |
|---|---|---|
| Invalid API key | Regenerate at finta.io dashboard |
| Empty rounds list | No active fundraising rounds | Create a test round in sandbox |
| Pipeline stage mismatch | Custom stage names in workspace | Fetch stages dynamically with |
| Rate limit (429) | Burst of API calls in parallel tests | Serialize integration tests or add throttling |
| Investor data stale | Webhook sync delay | Add polling retry for recently updated investors |
Resources
Next Steps
For deployment, see
finta-deploy-integration.