Files
osem/spec/controllers/api/v1/tracks_controller_spec.rb
Andrew Kvalheim e30880229c Use be_successful instead of be_success
Rails 5.2 warns:

> The `success?` predicate is deprecated and will be removed in Rails 6.0.
> Please use `successful?` as provided by Rack::Response::Helpers.

RSpec correspondingly provides `be_successful`.
2022-01-23 14:06:02 -08:00

37 lines
1.0 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
describe Api::V1::TracksController do
let!(:conference) { create(:conference) }
let!(:conference_track) { create(:track, name: 'Conference Track', program_id: conference.program.id) }
let!(:track) { create(:track, name: 'Test Track') }
describe 'GET #index' do
context 'without conference scope' do
it 'returns all tracks' do
get :index, params: { format: :json }
json = JSON.parse(response.body)['tracks']
expect(response).to be_successful
expect(json.pluck('name')).to contain_exactly('Conference Track', 'Test Track')
end
end
context 'with conference scope' do
it 'returns all rooms of conference' do
get :index, params: { conference_id: conference.short_title, format: :json }
json = JSON.parse(response.body)['tracks']
expect(response).to be_successful
expect(json.length).to eq(1)
expect(json[0]['name']).to eq('Conference Track')
end
end
end
end