Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/NoRedInk/rspec-retry
retry randomly failing rspec example
https://github.com/NoRedInk/rspec-retry
Last synced: about 2 months ago
JSON representation
retry randomly failing rspec example
- Host: GitHub
- URL: https://github.com/NoRedInk/rspec-retry
- Owner: NoRedInk
- License: mit
- Created: 2012-07-21T06:59:52.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-11-24T07:45:40.000Z (about 1 year ago)
- Last Synced: 2024-11-08T20:03:03.865Z (about 2 months ago)
- Language: Ruby
- Size: 159 KB
- Stars: 586
- Watchers: 18
- Forks: 97
- Open Issues: 32
-
Metadata Files:
- Readme: README.md
- Changelog: changelog.md
- License: LICENSE
Awesome Lists containing this project
README
# RSpec::Retry ![Build Status](https://secure.travis-ci.org/NoRedInk/rspec-retry.svg?branch=master)
RSpec::Retry adds a ``:retry`` option for intermittently failing rspec examples.
If an example has the ``:retry`` option, rspec will retry the example the
specified number of times until the example succeeds.### Compatibility
| Rspec Version | Rspec-Retry Version |
|---------------|---------------------|
| > 3.8 | 0.6.2 but untested |
| > 3.3, <= 3.8 | 0.6.2 |
| 3.2 | 0.4.6 |
| 2.14.8 | 0.4.4 |### Maintenance Expectations
NoRedInk used to be a Ruby shop, and we open-sourced this in the hope that it will help other people.
However, we've been moving away from Ruby for some time now, and only plan to do maintenance on this repo when we have an internal need for it.
We don't plan to add any new functionality, and expect that it will fall behind the latest versions of Ruby and Rspec.That said, if you're reading this and you need this gem to do something new, feel free to fork it and publish your own gem!
If you open an issue here to let us know about your fork, we can add a link to it from this repo to help folks find something that's more actively maintained.## Installation
Add this line to your application's Gemfile:
```ruby
gem 'rspec-retry', group: :test # Unlike rspec, this doesn't need to be included in development group
```And then execute:
$ bundle
Or install it yourself as:
$ gem install rspec-retry
require in ``spec_helper.rb``
```ruby
# spec/spec_helper.rb
require 'rspec/retry'RSpec.configure do |config|
# show retry status in spec process
config.verbose_retry = true
# show exception that triggers a retry if verbose_retry is set to true
config.display_try_failure_messages = true# run retry only on features
config.around :each, :js do |ex|
ex.run_with_retry retry: 3
end# callback to be run between retries
config.retry_callback = proc do |ex|
# run some additional clean up task - can be filtered by example metadata
if ex.metadata[:js]
Capybara.reset!
end
end
end
```## Usage
```ruby
it 'should randomly succeed', :retry => 3 do
expect(rand(2)).to eq(1)
endit 'should succeed after a while', :retry => 3, :retry_wait => 10 do
expect(command('service myservice status')).to eq('started')
end
# run spec (following log is shown if verbose_retry options is true)
# RSpec::Retry: 2nd try ./spec/lib/random_spec.rb:49
# RSpec::Retry: 3rd try ./spec/lib/random_spec.rb:49
```### Calling `run_with_retry` programmatically
You can call `ex.run_with_retry(opts)` on an individual example.
## Configuration
- __:verbose_retry__(default: *false*) Print retry status
- __:display_try_failure_messages__ (default: *false*) If verbose retry is enabled, print what reason forced the retry
- __:default_retry_count__(default: *1*) If retry count is not set in an example, this value is used by default. Note that currently this is a 'try' count. If increased from the default of 1, all examples will be retried. We plan to fix this as a breaking change in version 1.0.
- __:default_sleep_interval__(default: *0*) Seconds to wait between retries
- __:clear_lets_on_failure__(default: *true*) Clear memoized values for ``let``s before retrying
- __:exceptions_to_hard_fail__(default: *[]*) List of exceptions that will trigger an immediate test failure without retry. Takes precedence over __:exceptions_to_retry__
- __:exceptions_to_retry__(default: *[]*) List of exceptions that will trigger a retry (when empty, all exceptions will)
- __:retry_callback__(default: *nil*) Callback function to be called between retries## Environment Variables
- __RSPEC_RETRY_RETRY_COUNT__ can override the retry counts even if a retry count is set in an example or default_retry_count is set in a configuration.## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Added some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create a pull request