Add specs for testing authorization and deny of chat user
This commit is contained in:
parent
6f714dfb4a
commit
4d7b44b5b7
2 changed files with 81 additions and 0 deletions
4
changelogs/unreleased/add-chat-names.yml
Normal file
4
changelogs/unreleased/add-chat-names.yml
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
---
|
||||||
|
title: Allow to connect Chat account with GitLab
|
||||||
|
merge_request: 7450
|
||||||
|
author:
|
77
spec/features/profiles/chat_names_spec.rb
Normal file
77
spec/features/profiles/chat_names_spec.rb
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
feature 'Profile > Chat', feature: true do
|
||||||
|
given(:user) { create(:user) }
|
||||||
|
given(:service) { create(:service) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
login_as(user)
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'uses authorization link' do
|
||||||
|
given(:params) do
|
||||||
|
{ team_id: 'T00', team_domain: 'my_chat_team', user_id: 'U01', user_name: 'my_chat_user' }
|
||||||
|
end
|
||||||
|
given!(:authorize_url) { ChatNames::AuthorizeUserService.new(service, params).execute }
|
||||||
|
given(:authorize_path) { URI.parse(authorize_url).request_uri }
|
||||||
|
|
||||||
|
before do
|
||||||
|
visit authorize_path
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'clicks authorize' do
|
||||||
|
before do
|
||||||
|
click_button 'Authorize'
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'goes to list of chat names and see chat account' do
|
||||||
|
expect(page.current_path).to eq(profile_chat_names_path)
|
||||||
|
expect(page).to have_content('my_chat_team')
|
||||||
|
expect(page).to have_content('my_chat_user')
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'second use of link is denied' do
|
||||||
|
visit authorize_path
|
||||||
|
|
||||||
|
expect(page).to have_http_status(:not_found)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'clicks deny' do
|
||||||
|
before do
|
||||||
|
click_button 'Deny'
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'goes to list of chat names and do not see chat account' do
|
||||||
|
expect(page.current_path).to eq(profile_chat_names_path)
|
||||||
|
expect(page).not_to have_content('my_chat_team')
|
||||||
|
expect(page).not_to have_content('my_chat_user')
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'second use of link is denied' do
|
||||||
|
visit authorize_path
|
||||||
|
|
||||||
|
expect(page).to have_http_status(:not_found)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'visits chat accounts' do
|
||||||
|
given!(:chat_name) { create(:chat_name, user: user, service: service) }
|
||||||
|
|
||||||
|
before do
|
||||||
|
visit profile_chat_names_path
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'sees chat user' do
|
||||||
|
expect(page).to have_content(chat_name.team_domain)
|
||||||
|
expect(page).to have_content(chat_name.chat_name)
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario 'removes chat account' do
|
||||||
|
click_link 'Remove'
|
||||||
|
|
||||||
|
expect(page).to have_content("You don't have any active chat names.")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in a new issue