diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-20 15:26:25 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-20 15:26:25 +0300 |
commit | a09983ae35713f5a2bbb100981116d31ce99826e (patch) | |
tree | 2ee2af7bd104d57086db360a7e6d8c9d5d43667a /spec/controllers/invites_controller_spec.rb | |
parent | 18c5ab32b738c0b6ecb4d0df3994000482f34bd8 (diff) |
Add latest changes from gitlab-org/gitlab@13-2-stable-ee
Diffstat (limited to 'spec/controllers/invites_controller_spec.rb')
-rw-r--r-- | spec/controllers/invites_controller_spec.rb | 37 |
1 files changed, 30 insertions, 7 deletions
diff --git a/spec/controllers/invites_controller_spec.rb b/spec/controllers/invites_controller_spec.rb index f2821bb67e8..a9e4073780d 100644 --- a/spec/controllers/invites_controller_spec.rb +++ b/spec/controllers/invites_controller_spec.rb @@ -4,21 +4,44 @@ require 'spec_helper' RSpec.describe InvitesController do let(:token) { '123456' } - let(:user) { create(:user) } - let(:member) { create(:project_member, invite_token: token, invite_email: 'test@abc.com', user: user) } + let_it_be(:user) { create(:user) } + let(:member) { create(:project_member, :invited, invite_token: token, invite_email: user.email) } + let(:project_members) { member.source.users } before do controller.instance_variable_set(:@member, member) sign_in(user) end - describe 'GET #accept' do + describe 'GET #show' do + it 'accepts user if invite email matches signed in user' do + expect do + get :show, params: { id: token } + end.to change { project_members.include?(user) }.from(false).to(true) + + expect(response).to have_gitlab_http_status(:found) + expect(flash[:notice]).to include 'You have been granted' + end + + it 'forces re-confirmation if email does not match signed in user' do + member.invite_email = 'bogus@email.com' + + expect do + get :show, params: { id: token } + end.not_to change { project_members.include?(user) } + + expect(response).to have_gitlab_http_status(:ok) + expect(flash[:notice]).to be_nil + end + end + + describe 'POST #accept' do it 'accepts user' do - get :accept, params: { id: token } - member.reload + expect do + post :accept, params: { id: token } + end.to change { project_members.include?(user) }.from(false).to(true) expect(response).to have_gitlab_http_status(:found) - expect(member.user).to eq(user) expect(flash[:notice]).to include 'You have been granted' end end @@ -26,8 +49,8 @@ RSpec.describe InvitesController do describe 'GET #decline' do it 'declines user' do get :decline, params: { id: token } - expect {member.reload}.to raise_error ActiveRecord::RecordNotFound + expect { member.reload }.to raise_error ActiveRecord::RecordNotFound expect(response).to have_gitlab_http_status(:found) expect(flash[:notice]).to include 'You have declined the invitation to join' end |