BigW Consortium Gitlab

chat_names_spec.rb 2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 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