manage_members_spec.rb 3.2 KB
Newer Older
1 2
# frozen_string_literal: true

3 4
require 'spec_helper'

5
describe 'Groups > Members > Manage members' do
6
  include Select2Helper
7
  include Spec::Support::Helpers::Features::ListRowsHelpers
8 9 10 11 12

  let(:user1) { create(:user, name: 'John Doe') }
  let(:user2) { create(:user, name: 'Mary Jane') }
  let(:group) { create(:group) }

13
  before do
14
    sign_in(user1)
15 16
  end

17
  it 'update user to owner level', :js do
18 19 20 21 22 23 24 25 26 27 28 29 30
    group.add_owner(user1)
    group.add_developer(user2)

    visit group_group_members_path(group)

    page.within(second_row) do
      click_button('Developer')
      click_link('Owner')

      expect(page).to have_button('Owner')
    end
  end

31
  it 'add user to group', :js do
32 33 34 35 36 37 38 39 40 41 42 43
    group.add_owner(user1)

    visit group_group_members_path(group)

    add_user(user2.id, 'Reporter')

    page.within(second_row) do
      expect(page).to have_content(user2.name)
      expect(page).to have_button('Reporter')
    end
  end

44
  it 'do not disclose email addresses', :js do
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
    group.add_owner(user1)
    create(:user, email: 'undisclosed_email@gitlab.com', name: "Jane 'invisible' Doe")

    visit group_group_members_path(group)

    find('.select2-container').click
    select_input = find('.select2-input')

    select_input.send_keys('@gitlab.com')
    wait_for_requests

    expect(page).to have_content('No matches found')

    select_input.native.clear
    select_input.send_keys('undisclosed_email@gitlab.com')
    wait_for_requests

    expect(page).to have_content("Jane 'invisible' Doe")
  end

65
  it 'remove user from group', :js do
66 67 68 69 70
    group.add_owner(user1)
    group.add_developer(user2)

    visit group_group_members_path(group)

71 72 73 74 75
    accept_confirm do
      find(:css, '.project-members-page li', text: user2.name).find(:css, 'a.btn-remove').click
    end

    wait_for_requests
76 77 78 79 80

    expect(page).not_to have_content(user2.name)
    expect(group.users).not_to include(user2)
  end

81
  it 'add yourself to group when already an owner', :js do
82 83 84 85 86 87 88 89 90 91 92 93
    group.add_owner(user1)

    visit group_group_members_path(group)

    add_user(user1.id, 'Reporter')

    page.within(first_row) do
      expect(page).to have_content(user1.name)
      expect(page).to have_content('Owner')
    end
  end

94
  it 'invite user to group', :js do
95 96 97 98 99 100
    group.add_owner(user1)

    visit group_group_members_path(group)

    add_user('test@example.com', 'Reporter')

Stan Hu's avatar
Stan Hu committed
101 102
    click_link('Pending')

Martin Wortschack's avatar
Martin Wortschack committed
103
    page.within('.content-list.members-list') do
104 105 106 107 108 109
      expect(page).to have_content('test@example.com')
      expect(page).to have_content('Invited')
      expect(page).to have_button('Reporter')
    end
  end

110
  it 'guest can not manage other users' do
111 112 113 114 115
    group.add_guest(user1)
    group.add_developer(user2)

    visit group_group_members_path(group)

116 117
    expect(page).not_to have_selector '.invite-users-form'
    expect(page).not_to have_selector '.invite-group-form'
118 119 120 121 122 123 124 125 126 127

    page.within(second_row) do
      # Can not modify user2 role
      expect(page).not_to have_button 'Developer'

      # Can not remove user2
      expect(page).not_to have_css('a.btn-remove')
    end
  end

128
  def add_user(id, role)
129
    page.within ".invite-users-form" do
130 131
      select2(id, from: "#user_ids", multiple: true)
      select(role, from: "access_level")
132
      click_button "Invite"
133 134
    end
  end
135
end