JSONSpectacular
JSON assertions with noise-free reports on complex nested structures.
Installation
Add this line to your application's Gemfile:
group :test do
gem 'json_spectacular', require: false
endAdd json_spectacular to your spec/rails_helper.rb
require 'json_spectacular'
# ...
RSpec.configure do |config|
# ...
%i[request controller].each do |spec_type|
config.include JSONSpectacular::RSpec, type: spec_type
end
endAnd then execute:
bundle installUsage
Asserting JSON responses
RSpec.describe 'making some valid request', type: :request do
context 'some important context' do
it 'should return some complicated JSON' do
perform_request
expect(json_response).to eql_json([
{
"a" => [
1, 2, 3
],
"c" => { "d" => "d'"}
},
{
"b" => [
1, 2, 3
],
"c" => { "d" => "d'"}
}
])
end
end
endThe json_response helper automatically parses the last response object as json, and the assertion eql_json reports failures in a format that is much clearer than anything provided by RSpec.
The full expected and actual values are still reported, but below is a separate report that only includes the paths to the failed nested values and their differences, removing the need to manually compare the two complete objects to find the difference.
Test suite
json_spectacular comes with close-to-complete test coverage. You can run the test suite as follows:
rspecContributing
- Fork it ( https://github.com/greena13/json_spectacular/fork )
- Create your feature branch (
git checkout -b my-new-feature) - Commit your changes (
git commit -am 'Add some feature') - Push to the branch (
git push origin my-new-feature) - Create a new Pull Request