RSpec for Sidekiq

[![RubyGems][gem_version_badge]][ruby_gems] [![Code Climate][code_climate_badge]][code_climate] [![Travis CI][travis_ci_badge]][travis_ci] [![Coveralls][coveralls_badge]][coveralls] [![Gemnasium][gemnasium_badge]][gemnasium] [![coderwall][coderwall_badge]][coderwall]

Simple testing of Sidekiq jobs via a collection of matchers and common tasks

[RubyGems][ruby_gems] | [Code Climate][code_climate] | [GitHub][github] | [Travis CI][travis_ci] | [Coveralls][coveralls] | [Gemnasium][gemnasium] | [RubyDoc][ruby_doc] | [Ruby Toolbox][ruby_toolbox]

Installation

# Gemfile
group :test do
  gem "rspec-sidekiq"
end

rspec-sidekiq requires sidekiq/testing by default so there is no need to include the line require "sidekiq/testing" inside your spec_helper.rb.

This has the effect of not pushing enqueued jobs to Redis but to a job array to enable testing (see Sidekiq's testing wiki). Thus, only include gem "rspec-sidekiq" in environments where this behaviour is required, such as the test group.

If you are using Sidekiq Batches (Sidekiq Pro feature), rspec-sidekiq replaces the implementation (using the NullObject pattern) enabling testing without a Redis instance. Mocha and RSpec stubbing is supported here.

Configuration

If you wish to modify the default behaviour, add the following to your spec_helper.rb file

RSpec::Sidekiq.configure do |config|
  # Clears all job queues before each example
  config.clear_all_enqueued_jobs = false # default => true
end

Matchers

be_processed_in

Describes the queue that the job should be processed in

sidekiq_options queue: :download # job option

it { should be_processed_in :download } # one liner
expect(AwesomeJob).to be_processed_in :download # new expect syntax

be_retryable

Describes if the job retries when there is a failure in it's execution

sidekiq_options retry: 5 # job option

it { should be_retryable true } # one liner
expect(AwesomeJob).to be_retryable true # new expect syntax
# ...or alternatively specifiy the number of times it should be retried
it { should be_retryable 5 } # one liner
expect(AwesomeJob).to be_retryable 5 # new expect syntax

be_unique

Describes if the job should be unique within it's queue

sidekiq_options unique: true # job option

it { should be_unique } # one liner
expect(AwesomeJob).to be_unique # new expect syntax

have_enqueued_job

Evaluates that there is an enqueued job with the specified arguments

expect(AwesomeJob).to have_enqueued_job("Awesome", true) # new expect syntax

have_enqueued_jobs

Evaluates the number of enqueued jobs for a specified job class

expect(AwesomeJob).to have_enqueued_jobs(1) # new expect syntax
# ...but you could just use
expect(AwesomeJob).to have(1).jobs
# ...or even
expect(AwesomeJob).to have(1).enqueued.jobs

Example

require "spec_helper"

describe AwesomeJob do
  it { should be_processed_in :download }
  it { should be_retryable false }
  it { should be_unique }

  it "enqueues another awesome job" do
    subject.perform

    expect(AnotherAwesomeJob).to have_enqueued_job("Awesome", true)
  end
end

Testing

bundle exec rspec spec

Contribute

Please do! If there's a feature missing that you'd love to see then get in on the action!

Issues/Pull Requests/Comments bring them on...

[code_climate]: https://codeclimate.com/github/philostler/rspec-sidekiq [code_climate_badge]: https://codeclimate.com/github/philostler/rspec-sidekiq.png [coderwall]: https://coderwall.com/philostler [coderwall_badge]: https://api.coderwall.com/philostler/endorsecount.png [coveralls]: https://coveralls.io/r/philostler/rspec-sidekiq [coveralls_badge]: https://coveralls.io/repos/philostler/rspec-sidekiq/badge.png?branch=master [gem_version_badge]: https://badge.fury.io/rb/rspec-sidekiq.png [gemnasium]: https://gemnasium.com/philostler/rspec-sidekiq [gemnasium_badge]: https://gemnasium.com/philostler/rspec-sidekiq.png [github]: http://github.com/philostler/rspec-sidekiq [ruby_doc]: http://rubydoc.info/github/philostler/rspec-sidekiq/master/frames [ruby_gems]: http://rubygems.org/gems/rspec-sidekiq [ruby_toolbox]: http://www.ruby-toolbox.com/projects/rspec-sidekiq [travis_ci]: http://travis-ci.org/philostler/rspec-sidekiq [travis_ci_badge]: https://secure.travis-ci.org/philostler/rspec-sidekiq.png