60 lines
1.7 KiB
Ruby
60 lines
1.7 KiB
Ruby
require 'spec_helper'
|
|
|
|
RSpec.describe OrganizationsController do
|
|
let!(:organization) { Fabricate(:organization) }
|
|
let(:member) { Fabricate(:member, organization: organization) }
|
|
let(:user) { member.user }
|
|
|
|
describe 'GET #index' do
|
|
it 'populates and array of organizations' do
|
|
get :index
|
|
|
|
expect(assigns(:organizations)).to eq([organization])
|
|
end
|
|
end
|
|
|
|
describe 'POST #create' do
|
|
it 'only superdamins are authorized create to new organizations' do
|
|
login(member.user)
|
|
|
|
expect {
|
|
post :create, organization: { name: 'New cool organization' }
|
|
}.not_to change { Organization.count }
|
|
end
|
|
end
|
|
|
|
describe 'POST #update' do
|
|
context 'with a logged user (admins organization)' do
|
|
let(:member) { Fabricate(:member, organization: organization, manager: true) }
|
|
|
|
it 'allows to update organization' do
|
|
login(member.user)
|
|
|
|
post :update, id: organization.id, organization: { name: 'New org name' }
|
|
|
|
organization.reload
|
|
expect(organization.name).to eq('New org name')
|
|
end
|
|
end
|
|
|
|
context 'without a logged user' do
|
|
it 'does not allow to update organization' do
|
|
post :update, id: organization.id, organization: { name: 'New org name' }
|
|
|
|
expect(response).to redirect_to(root_path)
|
|
expect(flash[:error]).to eq('You are not authorized to perform this action.')
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#set_current' do
|
|
before { login(user) }
|
|
|
|
it 'stores the given organization as current organization in session' do
|
|
post 'set_current', id: organization.id
|
|
|
|
expect(session[:current_organization_id]).to eq(organization.id)
|
|
end
|
|
end
|
|
end
|