aboutsummaryrefslogtreecommitdiff
path: root/docs/guides/test/coverage-threshold.md
diff options
context:
space:
mode:
Diffstat (limited to 'docs/guides/test/coverage-threshold.md')
-rw-r--r--docs/guides/test/coverage-threshold.md58
1 files changed, 58 insertions, 0 deletions
diff --git a/docs/guides/test/coverage-threshold.md b/docs/guides/test/coverage-threshold.md
new file mode 100644
index 000000000..4180c6f1a
--- /dev/null
+++ b/docs/guides/test/coverage-threshold.md
@@ -0,0 +1,58 @@
+---
+name: Set a code coverage threshold with the Bun test runner
+---
+
+Bun's test runner supports built-in code coverage reporting via the `--coverage` flag.
+
+```sh
+$ bun test --coverage
+
+test.test.ts:
+✓ math > add [0.71ms]
+✓ math > multiply [0.03ms]
+✓ random [0.13ms]
+-------------|---------|---------|-------------------
+File | % Funcs | % Lines | Uncovered Line #s
+-------------|---------|---------|-------------------
+All files | 66.67 | 77.78 |
+ math.ts | 50.00 | 66.67 |
+ random.ts | 50.00 | 66.67 |
+-------------|---------|---------|-------------------
+
+ 3 pass
+ 0 fail
+ 3 expect() calls
+```
+
+---
+
+To set a minimum coverage threshold, add the following line to your `bunfig.toml`. This requires that 90% of your codebase is covered by tests.
+
+```toml
+[test]
+# to require 90% line-level and function-level coverage
+coverageThreshold = 0.9
+```
+
+---
+
+If your test suite does not meet this threshold, `bun test` will exit with a non-zero exit code to signal a failure.
+
+```sh
+$ bun test --coverage
+<test output>
+$ echo $?
+1 # this is the exit code of the previous command
+```
+
+Different thresholds can be set for line-level and function-level coverage.
+
+```toml
+[test]
+# to set different thresholds for lines and functions
+coverageThreshold = { line = 0.5, function = 0.7 }
+```
+
+---
+
+See [Docs > Test runner > Coverage](/docs/test/coverage) for complete documentation on code coverage reporting in Bun.