aboutsummaryrefslogtreecommitdiff
path: root/docs/guides/test/coverage-threshold.md
diff options
context:
space:
mode:
authorGravatar Colin McDonnell <colinmcd94@gmail.com> 2023-08-24 22:28:07 -0700
committerGravatar GitHub <noreply@github.com> 2023-08-24 22:28:07 -0700
commit73b3fb7b0fa7cc786e147ccf1247cd9883ad8e59 (patch)
treecf26d0aad9b0b90904989c07fc344e37c6fe5f2a /docs/guides/test/coverage-threshold.md
parent2bcbafe7d32c18f611f7c7bd20e4c9d4d92a18ea (diff)
downloadbun-73b3fb7b0fa7cc786e147ccf1247cd9883ad8e59.tar.gz
bun-73b3fb7b0fa7cc786e147ccf1247cd9883ad8e59.tar.zst
bun-73b3fb7b0fa7cc786e147ccf1247cd9883ad8e59.zip
Add guides for test runner (#4308)
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.