239 lines
7.5 KiB
Ruby
239 lines
7.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe TournamentsController, type: :controller do
|
|
before do
|
|
@tournament = create(:tournament)
|
|
@user = @tournament.owner
|
|
@another_user = create(:user)
|
|
@private_tournament = create(:tournament, user: @another_user, public: false)
|
|
@teams = create_list(:detached_team, 4)
|
|
end
|
|
|
|
describe 'GET #index' do
|
|
it 'returns a success response' do
|
|
get :index
|
|
expect(response).to be_successful
|
|
end
|
|
|
|
it 'returns all public tournaments' do
|
|
get :index
|
|
tournaments = deserialize_response response
|
|
public_tournaments = tournaments.select { |t| t[:public] }
|
|
expect(public_tournaments.map { |t| t[:id] }).to match_array(Tournament.where(public: true).map { |t| t[:id] })
|
|
end
|
|
|
|
it 'returns no private tournaments for unauthenticated users' do
|
|
get :index
|
|
tournaments = deserialize_response response
|
|
private_tournaments = tournaments.reject { |t| t[:public] }
|
|
expect(private_tournaments.size).to eq(0)
|
|
end
|
|
|
|
it 'returns private tournaments owned by the authenticated user' do
|
|
apply_authentication_headers_for @user
|
|
get :index
|
|
tournaments = deserialize_response response
|
|
expect(tournaments.filter { |t| !t[:public] }).to match_array(Tournament.where(owner: @owner, public: false))
|
|
end
|
|
|
|
it 'returns no private tournaments owned by another user' do
|
|
apply_authentication_headers_for @user
|
|
get :index
|
|
tournaments = deserialize_response response
|
|
expect(tournaments.map { |t| t[:id] }).not_to include(@private_tournament.id)
|
|
end
|
|
end
|
|
|
|
describe 'GET #show' do
|
|
it 'returns a success response' do
|
|
get :show, params: { id: @tournament.to_param }
|
|
expect(response).to be_successful
|
|
end
|
|
|
|
it 'returns the requested tournament' do
|
|
get :show, params: { id: @tournament.to_param }
|
|
expect(deserialize_response(response)[:id].to_i).to eq(@tournament.id)
|
|
end
|
|
end
|
|
|
|
describe 'POST #create' do
|
|
let(:create_data) do
|
|
{
|
|
name: Faker::Creature::Dog.name,
|
|
description: Faker::Lorem.sentence,
|
|
public: false,
|
|
teams: @teams.map { |team| { id: team.id } }
|
|
}
|
|
end
|
|
|
|
context 'without authentication headers' do
|
|
it 'renders an unauthorized error response' do
|
|
put :create, params: create_data
|
|
expect(response).to have_http_status(:unauthorized)
|
|
end
|
|
end
|
|
|
|
context 'with authentication headers' do
|
|
before(:each) do
|
|
apply_authentication_headers_for @user
|
|
end
|
|
|
|
context 'with existing teams' do
|
|
it 'creates a new Tournament' do
|
|
expect do
|
|
post :create, params: create_data
|
|
end.to change(Tournament, :count).by(1)
|
|
end
|
|
|
|
it 'associates the new tournament with the authenticated user' do
|
|
expect do
|
|
post :create, params: create_data
|
|
end.to change(@user.tournaments, :count).by(1)
|
|
end
|
|
|
|
it 'associates the given teams with the created tournament' do
|
|
post :create, params: create_data
|
|
body = deserialize_response response
|
|
tournament = Tournament.find(body[:id])
|
|
expect(tournament.teams).to match_array(@teams)
|
|
end
|
|
|
|
it 'generates a playoff stage' do
|
|
post :create, params: create_data
|
|
body = deserialize_response response
|
|
tournament = Tournament.find(body[:id])
|
|
expect(tournament.stages.first).to be_a(Stage)
|
|
end
|
|
|
|
it 'generates a playoff stage with all given teams' do
|
|
post :create, params: create_data
|
|
body = deserialize_response response
|
|
tournament = Tournament.find(body[:id])
|
|
included_teams = tournament.stages.first.matches.map { |m| m.match_scores.map(&:team) }.flatten.uniq
|
|
expect(included_teams).to match_array(@teams)
|
|
end
|
|
|
|
it 'renders a JSON response with the new tournament' do
|
|
post :create, params: create_data
|
|
expect(response).to have_http_status(:created)
|
|
expect(response.content_type).to eq('application/json')
|
|
expect(response.location).to eq(tournament_url(Tournament.last))
|
|
end
|
|
end
|
|
|
|
context 'with missing teams' do
|
|
it 'returns an error response' do
|
|
data = create_data
|
|
data[:teams] << { id: Team.last.id + 1 }
|
|
post :create, params: data
|
|
expect(response).to have_http_status(:not_found)
|
|
end
|
|
end
|
|
|
|
context 'with team names' do
|
|
it 'creates teams for given names' do
|
|
data = create_data
|
|
data.delete :teams
|
|
data[:teams] = (1..12).collect { { name: Faker::Creature::Dog.name } }
|
|
expect do
|
|
post :create, params: data
|
|
end.to change(Team, :count).by(data[:teams].count)
|
|
end
|
|
end
|
|
|
|
context 'with invalid parameters' do
|
|
it 'renders an unprocessable entity response' do
|
|
put :create, params: { teams: [1, 2, 3] }
|
|
expect(response).to have_http_status(:unprocessable_entity)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'PUT #update' do
|
|
let(:valid_update) do
|
|
{
|
|
name: Faker::Creature::Dog.name
|
|
}
|
|
end
|
|
|
|
context 'with valid params' do
|
|
context 'without authentication headers' do
|
|
it 'renders a unauthorized error response' do
|
|
put :update, params: { id: @tournament.to_param }.merge(valid_update)
|
|
expect(response).to have_http_status(:unauthorized)
|
|
end
|
|
end
|
|
|
|
context 'as owner' do
|
|
before(:each) do
|
|
apply_authentication_headers_for @tournament.owner
|
|
end
|
|
|
|
it 'updates the requested tournament' do
|
|
put :update, params: { id: @tournament.to_param }.merge(valid_update)
|
|
@tournament.reload
|
|
expect(@tournament.name).to eq(valid_update[:name])
|
|
end
|
|
|
|
it 'renders a JSON response with the tournament' do
|
|
put :update, params: { id: @tournament.to_param }.merge(valid_update)
|
|
expect(response).to have_http_status(:ok)
|
|
expect(response.content_type).to eq('application/json')
|
|
end
|
|
end
|
|
|
|
context 'as another user' do
|
|
before do
|
|
apply_authentication_headers_for create(:user)
|
|
end
|
|
|
|
it 'renders a forbidden error response' do
|
|
put :update, params: { id: @tournament.to_param }.merge(valid_update)
|
|
expect(response).to have_http_status(:forbidden)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'DELETE #destroy' do
|
|
context 'without authentication headers' do
|
|
it 'renders a unauthorized error response' do
|
|
delete :destroy, params: { id: @tournament.to_param }
|
|
expect(response).to have_http_status(:unauthorized)
|
|
end
|
|
end
|
|
|
|
context 'as owner' do
|
|
before(:each) do
|
|
apply_authentication_headers_for @tournament.owner
|
|
end
|
|
|
|
it 'destroys the requested tournament' do
|
|
expect do
|
|
delete :destroy, params: { id: @tournament.to_param }
|
|
end.to change(Tournament, :count).by(-1)
|
|
end
|
|
|
|
it 'destroys associated teams' do
|
|
expect do
|
|
delete :destroy, params: { id: @tournament.to_param }
|
|
end.to change(Team, :count).by(-@tournament.teams.size)
|
|
end
|
|
end
|
|
|
|
context 'as another user' do
|
|
before do
|
|
apply_authentication_headers_for create(:user)
|
|
end
|
|
|
|
it 'renders a forbidden error response' do
|
|
delete :destroy, params: { id: @tournament.to_param }
|
|
expect(response).to have_http_status(:forbidden)
|
|
end
|
|
end
|
|
end
|
|
end
|