A custom orderer for RSpec that optimizes for test latency (mean time to failure) over test throughput.
If you do Test-Driven Development, you probably implement some version of this algorithm manually all the time. It's likely you have too many tests to run them all on every change, so you decide which tests to run based on those that are likely to fail and how quickly they run. This orderer uses a basic set of heuristics to automate that work:
- Never-run tests first, in arbitrary order
- Group remaining tests by the date at which they most recently failed.
- Sort groups such that the most recent failure date is first, and never-failing tests are at the end.
- Within a group, run the fastest tests first.
These heuristics are taken from JUnitMax. In fact, this project is basically my attempt to port the core ordering functionality, as I understand it, to RSpec.
In practice, I encourage you to try running as large a subset of your tests as you reasonably can to let the tool gather runtime data. Then start TDDing and simply rerunning that large group. Use RSpec's --fail-fast
option as well for the quickest feedback.
If you get strange failures, try deleting the history file (.rspec-run-data.store
by default). Please feel free to report a bug or submit a fix!
Install the gem and add to the application's Gemfile by executing:
$ bundle add rspec-ordering-mttf
If bundler is not being used to manage dependencies, install the gem by executing:
$ gem install rspec-ordering-mttf
Call RSpec::Ordering::Mttf.configure
with the RSpec configuration. This will configure a default global ordering of "mean time to failure."
RSpec.configure do |config|
RSpec::Ordering::Mttf.configure(config)
end
After checking out the repo, run bin/setup
to install dependencies. Then, run rake test
to run the tests. 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.
This gem uses Standard for code styling.
Bug reports and pull requests are welcome on GitHub at https://github.com/brandonduff/rspec-ordering-mttf.
The gem is available as open source under the terms of the MIT License.