2023-02-22 11:55:31 +11:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-05-11 21:14:33 +10:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2024-09-04 15:12:25 +10:00
|
|
|
RSpec.describe InvitesController do
|
2018-05-11 21:14:33 +10:00
|
|
|
render_views
|
|
|
|
|
2023-04-20 00:07:29 +10:00
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
|
2018-05-11 21:14:33 +10:00
|
|
|
before do
|
|
|
|
sign_in user
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #index' do
|
2023-04-20 00:07:29 +10:00
|
|
|
before do
|
|
|
|
Fabricate(:invite, user: user)
|
|
|
|
end
|
2018-05-11 21:14:33 +10:00
|
|
|
|
2022-07-05 10:41:40 +10:00
|
|
|
context 'when everyone can invite' do
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
|
2023-04-20 00:07:29 +10:00
|
|
|
get :index
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns http success' do
|
|
|
|
expect(response).to have_http_status(:success)
|
2022-07-05 10:41:40 +10:00
|
|
|
end
|
|
|
|
|
2023-04-20 00:07:29 +10:00
|
|
|
it 'returns private cache control headers' do
|
|
|
|
expect(response.headers['Cache-Control']).to include('private, no-store')
|
2018-05-11 21:14:33 +10:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-07-05 10:41:40 +10:00
|
|
|
context 'when not everyone can invite' do
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users])
|
2023-04-20 00:07:29 +10:00
|
|
|
get :index
|
2022-07-05 10:41:40 +10:00
|
|
|
end
|
|
|
|
|
2023-04-20 00:07:29 +10:00
|
|
|
it 'returns http forbidden' do
|
|
|
|
expect(response).to have_http_status(403)
|
2018-05-11 21:14:33 +10:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST #create' do
|
|
|
|
subject { post :create, params: { invite: { max_uses: '10', expires_in: 1800 } } }
|
|
|
|
|
2022-07-05 10:41:40 +10:00
|
|
|
context 'when everyone can invite' do
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
|
|
|
|
end
|
2018-05-11 21:14:33 +10:00
|
|
|
|
|
|
|
it 'succeeds to create a invite' do
|
2023-05-24 19:23:40 +10:00
|
|
|
expect { subject }.to change(Invite, :count).by(1)
|
2018-05-11 21:14:33 +10:00
|
|
|
expect(subject).to redirect_to invites_path
|
|
|
|
expect(Invite.last).to have_attributes(user_id: user.id, max_uses: 10)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-07-05 10:41:40 +10:00
|
|
|
context 'when not everyone can invite' do
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users])
|
|
|
|
end
|
2018-05-11 21:14:33 +10:00
|
|
|
|
2023-04-20 00:07:29 +10:00
|
|
|
it 'returns http forbidden' do
|
|
|
|
expect(subject).to have_http_status(403)
|
2018-05-11 21:14:33 +10:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-07-12 18:19:15 +10:00
|
|
|
describe 'DELETE #destroy' do
|
|
|
|
subject { delete :destroy, params: { id: invite.id } }
|
2023-04-20 00:07:29 +10:00
|
|
|
|
2024-07-12 18:19:15 +10:00
|
|
|
let(:invite) { Fabricate(:invite, user: user, expires_at: nil) }
|
2018-05-11 21:14:33 +10:00
|
|
|
|
2024-07-12 18:19:15 +10:00
|
|
|
it 'expires invite and redirects' do
|
|
|
|
expect { subject }
|
|
|
|
.to(change { invite.reload.expired? }.to(true))
|
|
|
|
expect(response)
|
|
|
|
.to redirect_to invites_path
|
2018-05-11 21:14:33 +10:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|