2023-02-22 09:55:31 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-05-11 20:14:33 +09:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe InvitesController do
|
|
|
|
render_views
|
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in user
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'GET #index' do
|
|
|
|
subject { get :index }
|
|
|
|
|
2022-07-05 09:41:40 +09:00
|
|
|
let(:user) { Fabricate(:user) }
|
2018-05-11 20:14:33 +09:00
|
|
|
let!(:invite) { Fabricate(:invite, user: user) }
|
|
|
|
|
2022-07-05 09:41:40 +09:00
|
|
|
context 'when everyone can invite' do
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
|
|
|
|
end
|
|
|
|
|
2018-05-11 20:14:33 +09:00
|
|
|
it 'renders index page' do
|
|
|
|
expect(subject).to render_template :index
|
|
|
|
expect(assigns(:invites)).to include invite
|
|
|
|
expect(assigns(:invites).count).to eq 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-07-05 09:41:40 +09: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 20:14:33 +09:00
|
|
|
it 'returns 403' do
|
|
|
|
expect(subject).to have_http_status 403
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST #create' do
|
|
|
|
subject { post :create, params: { invite: { max_uses: '10', expires_in: 1800 } } }
|
|
|
|
|
2022-07-05 09:41:40 +09:00
|
|
|
context 'when everyone can invite' do
|
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions | UserRole::FLAGS[:invite_users])
|
|
|
|
end
|
2018-05-11 20:14:33 +09:00
|
|
|
|
|
|
|
it 'succeeds to create a invite' do
|
2018-10-04 19:36:53 +09:00
|
|
|
expect { subject }.to change { Invite.count }.by(1)
|
2018-05-11 20:14:33 +09: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 09:41:40 +09:00
|
|
|
context 'when not everyone can invite' do
|
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
UserRole.everyone.update(permissions: UserRole.everyone.permissions & ~UserRole::FLAGS[:invite_users])
|
|
|
|
end
|
2018-05-11 20:14:33 +09:00
|
|
|
|
|
|
|
it 'returns 403' do
|
|
|
|
expect(subject).to have_http_status 403
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'DELETE #create' do
|
|
|
|
subject { delete :destroy, params: { id: invite.id } }
|
|
|
|
|
2022-07-05 09:41:40 +09:00
|
|
|
let(:user) { Fabricate(:user) }
|
2018-05-11 20:14:33 +09:00
|
|
|
let!(:invite) { Fabricate(:invite, user: user, expires_at: nil) }
|
|
|
|
|
|
|
|
it 'expires invite' do
|
|
|
|
expect(subject).to redirect_to invites_path
|
|
|
|
expect(invite.reload).to be_expired
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|