From finta-pack
Automate Finta data export and reporting in CI pipelines. Trigger with phrases like "finta CI", "finta automated reporting".
How this skill is triggered — by the user, by Claude, or both
Slash command
/finta-pack:finta-ci-integrationThis skill is limited to the following tools:
The summary Claude sees in its skill listing — used to decide when to auto-load this skill
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 wor...
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/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 }}
// 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);
});
});
// 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');
});
});
| CI Issue | Cause | Fix |
|---|---|---|
401 Unauthorized | 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 listStages() |
| 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 |
For deployment, see finta-deploy-integration.
Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.
npx claudepluginhub flight505/skill-forge --plugin finta-pack