Never merge untested code again.

PR comments, status checks, and line annotations on every pull request. Works with any CI — your source never leaves it.

No credit card · 5-min setup · Free for public repos

How it works

Three steps. Five minutes. No code access.

Add one line to your CI pipeline. OtterWise handles the rest.

Step 01 — CI

Drop one line in CI.

Add a single curl step after your tests run. Works with every major CI provider and every coverage format.

$ bash <(curl -s otterwise.app/bash)
→ uploaded 1.2 MB · signed · queued
✓ report processed in 1.8s

Step 02 — Ingest

We parse the report. That’s it.

We read the coverage artifact your tests already produce, like lcov, cobertura, jacoco, and more. Your source never leaves your runner.

lcov cobertura jacoco clover istanbul opencover go cover simplecov phpunit junit-xml + 2 more
Just point us at the report file. No code access required.

Step 03 — Read

Share a dashboard. Or a PR comment.

Coverage trends, cycle time, and churn risk, all in one place. Post results back to GitHub, or pull them anywhere via the API.

main · weekly +2.4%
Apr 4Apr 18

Treemap coverage

Coverage clarity for the whole repo

Treemap tiles sit side by side so you can spot hot spots instantly. Size reflects lines of code; color reflects coverage. The bigger and warmer the block, the higher the risk.

Uncovered lines by path
Jobs 47.8%
app/Jobs
Uncovered1,842
Coverage47.8%
Gain if covered+6.2%
Transformers 4.0%
app/Transformers
Uncovered889
Coverage4.0%
Gain if covered+9.46%
User.tsx 1.2%
ui/User.tsx
Uncovered326
Coverage1.2%
Gain if covered+4.1%
Http 44.7%
app/Http
Uncovered1,214
Coverage44.7%
Gain if covered+5.8%
API 78.6%
app/Api
Uncovered188
Coverage78.6%
Gain if covered+1.2%
Console 42.4%
app/Console
Uncovered522
Coverage42.4%
Gain if covered+3.8%
Traits 58.1%
app/Traits
Uncovered274
Coverage58.1%
Gain if covered+2.0%
Coverage scale · low to high

Coverage trends

Track trends, spot wins, find gaps

See how coverage moves across every branch: who's pushing it up, where code is slipping through untested, and which trends to act on before they become problems.

Status checks

Block bad code before it ships

Status checks automatically fail PRs when coverage drops or complexity spikes. Set your own quality thresholds and let automation enforce them. No more “looks good to me” merges that introduce untested code.

Everything else

Built for the whole team, not just the build

Privacy by default

We never access your source. We only store coverage metrics and the minimal service data needed to run OtterWise. Read about our code privacy efforts.

Invite your entire team

All plans (including free) offer unlimited collaborators at no extra charge. You can invite your entire engineering department, designers, PMs, and stakeholders.

Track progress anywhere

Watch coverage move over time in the dashboard, or pull the same numbers into your own with the API.

Onboarding assistance

All paid plans include priority chat support, and we can help you get running even if you have no CI pipeline yet.

Tailored to your workflow

Configure which files to ignore, when to fail CI, how coverage is calculated, and more. It bends to your setup, not the other way around.

Surface the riskiest code

Per-line coverage, type coverage, and CRAP scores point you at the code most likely to break, so you test what matters first.

Runs anywhere

Works with your favorite tools

Any CI that can run tests and upload a coverage report. Official guides for GitHub Actions and ChipperCI; everything else via the bash uploader. Use it with JavaScript, Go, Ruby, .NET, PHP, and any other language.

… plus any CI that can run the uploader

Why OtterWise

Coverage insight, without the trade-offs

what leaves your runner secure
your CI runner stays local
src/ tests/ diffs .env git history
uploads only the coverage report
coverage.lcov · 1.2 MB ✓ received
source never leaves CI 0 bytes of code stored
OW OtterWise bot commented just now

Coverage report · +2.4%

src/api/auth.handler.ts 91%
src/webhooks/stripe.ts 68%
src/reports/export.ts 41%
coverage/project — 82.6% (+2.4%)
coverage/patch — 96% of new lines
3 new lines need tests
files ranked by risk top 4
src/legacy/migrator.ts 22%
src/reports/export.ts 41%
src/webhooks/stripe.ts 68%
src/parsers/csv.ts 72%
coverage trend · 30 days +2.4%
covering migrator.ts → +9.4% overall 82.6%

See exactly what your tests miss.

Free for public repos. Set up in 5 minutes. No credit card required.

FAQ

Frequently asked questions

Something not covered here? Email [email protected] and we'll help you out.

No. By default, our servers can't reach your repository code at all.

We rely on GitHub annotations and the coverage files your tests already produce, so you get everything a coverage service offers without us ever reading your source.

Your organization can opt in to temporary code access if you want coverage rendered per line inside OtterWise. You can read about our code privacy efforts here.

Any of them. OtterWise is language- and framework-agnostic; the only requirement is that your code is on GitHub.com and your test framework can output a Clover XML or LCOV file.

Most can: PHPUnit has it built in (via PCOV or Xdebug), and in JavaScript you get it through Istanbul/nyc. Our setup guides walk you through it.

None. There's no minimum commitment, cancel anytime from your account and billing stops immediately. You keep access until the end of the cycle.

After that we move you to the free plan and adjust automatically, for example disabling private repos over the free limit. Your data stays put.

Free forever, with unlimited collaborators and unlimited builds. We only charge for private repos.

Two ways to try it:

  • Public repos are free forever.
  • Private repos get a 7-day trial; billing starts when it ends.

Yes. On your organization's billing page, switch between yearly and monthly and hit Update plan, it applies instantly and prorates the difference. Or email [email protected] and we'll sort it.

Yes, no questions asked. Email [email protected] and we'll sort it out.

Login runs entirely through GitHub, so your existing GitHub access controls apply. Remove someone from your GitHub organization and they lose OtterWise access automatically.

Yes, coverage across the whole repository, not just the diff, on every plan.

Yes, coverage of just the lines your pull request or commit changed, on every plan. It shows exactly which new lines aren't tested before you merge.

GitHub today, plus any CI that can run the uploader.

OtterWise tracks line coverage, branch coverage, patch coverage, type coverage, complexity, and CRAP.

Free plans keep 6 months of history; Pro plans keep it indefinitely. Either way you can view past reports and track trends over time.

Yes. Pull your coverage, metrics, and history out through the API anytime, or ask support for an export.

Authentication runs through GitHub, traffic is encrypted in transit, and code access is off by default and opt-in only, so your source stays private unless you choose otherwise.

Weekly and monthly digests, leaderboards, coverage trends, and per-file breakdowns. Pro plans add deeper history and analytics.

Yes, unlimited collaborators on every plan, including free. Manage access through your GitHub organization, and work from shared PR comments and line annotations.

Any framework that can output a Clover XML or LCOV report, including PHPUnit, Jest, Cypress, RSpec, and PyTest.

No, coverage reports only.

Ready when you are

Ship better code faster, with confidence.

PR comments, status checks, line annotations, and trends, all without code access. Free for public repos; per-repo pricing for private repos.