simplecov-rspec
is a Ruby gem that integrates SimpleCov with RSpec to ensure your
tests meet a minimum coverage threshold. It enhances your test suite by automatically
failing tests when coverage falls below a specified threshold and, optionally,
listing uncovered lines to help you improve coverage.
When simplecov-rspec
is used, RSpec will report an error if the percent of test
coverage falls below a defined threshold:
Coverage report generated for RSpec to /Projects/example_project/coverage. 284 / 286 LOC (99.3%) covered.
FAIL: RSpec Test coverage fell below 100%
If configured to list the lines that were not covered by tests, RSpec will additionally output:
2 lines are not covered by tests:
./lib/example_project.rb:74
./lib/example_project.rb:75
To install the gem, add to the following line to your application's gemspec OR Gemfile:
gemspec:
spec.add_development_dependency "simplecov-rspec", '~> 0.1'
Gemfile:
gem "simplecov-rspec", "~> 0.1", groups: [:development, :test]
and then run bundle install
If bundler is not being used to manage dependencies, install the gem by executing:
gem install simplecov-rspec
To use simplecov-rspec
, follow these steps:
- Add
require 'simplecov-rspec'
to yourspec_helper.rb
. - Replace
SimpleCov.start
withSimpleCov::RSpec.start
in yourspec_helper.rb
, ensuring this line appears before requiring your project files.
Here is an example spec_helper.rb
. Your spec helper may include
other code in addition to these:
require 'simplecov-rspec'
SimpleCov::RSpec.start
require 'my_project'
This will configure RSpec to fail when test coverage falls below 100%.
That is it!
To initialize simplecov-rspec with defaults, add the following to your spec_helper.rb
:
require 'simplecov-rspec'
SimpleCov::RSpec.start
This is equivalent to starting with the following options:
SimpleCov::RSpec.start(
coverage_threshold: 100,
fail_on_low_coverage: true,
list_uncovered_lines: false
)
The test coverage threshold is the minimum percent of lines covered by tests as tracked by SimpleCov.
To initialize SimpleCov with a test coverage threshold less than 100%:
SimpleCov::RSpec.start(coverage_threshold: 90)
A configuration block can be given to the start
method to further configure
SimpleCov:
# Initialize SimpleCov with a specific formatter
SimpleCov::RSpec.start { formatter = SimpleCov::Formatter::LcovFormatter }
This block is passed on to SimpleCov::RSpec.start
. See Configuring
SimpleCov
for details.
Environment variables can be used to configure simplecov-rspec
. These environment
variables take presidence over the values passed to SimpleCov::RSpec.start
.
COVERAGE_THRESHOLD
: Sets the minimum coverage threshold (0-100). Overridescoverage_threshold
.FAIL_ON_LOW_COVERAGE
: Controls whether tests fail if coverage is below the threshold. Set to 'true', 'yes', 'on', or '1' (case insensitive) to enable.LIST_UNCOVERED_LINES
: Determines if uncovered lines are listed. Set to 'true', 'yes', 'on', or '1' (case insensitive) to enable.
For example, here is a bash script to run tests in an infinite loop while writing
test output to fail.txt
:
while true; do COV_NO_FAIL=TRUE rspec >> fail.txt; done
In a CI system, you might want to set LIST_UNCOVERED_LINES=yes
in order to list
uncovered lines on different platforms than the one you run for local development.
If you want to contribute or experiment with the gem, follow these steps to set up your development environment:
After checking out the repo, run bin/setup
to install dependencies. Then, run rake
to run linting, tests, etc. just like the CI build. You can also run bin/console
for an interactive prompt that
will allow you to experiment.
To install this gem onto your local machine, run bundle exec rake install
. To
release a new version, update the version number in version.rb
, and then run
bundle exec rake release
, which will create a git tag for the version, push git
commits and the created tag, and push the .gem
file to
rubygems.org.
Bug reports and pull requests are welcome on GitHub at https://github.com/main-branch/simplecov-rspec. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the code of conduct.
All commit messages must follow the Conventional Commits standard. This helps us maintain a clear and structured commit history, automate versioning, and generate changelogs effectively.
To ensure compliance, this project includes:
-
A git commit-msg hook that validates your commit messages before they are accepted.
To activate the hook, you must have node installed and run
npm install
. -
A GitHub Actions workflow that will enforce the Conventional Commit standard as part of the continuous integration pipeline.
Any commit message that does not conform to the Conventional Commits standard will cause the workflow to fail and not allow the PR to be merged.
All pull requests must be merged using rebase merges. This ensures that commit messages from the feature branch are preserved in the release branch, keeping the history clean and meaningful.
The gem is available as open source under the terms of the MIT License.
Everyone interacting in the Simplecov::Rspec project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the code of conduct.