3715a0f29b
This was broken in 70f5291808
as a result of introducing the ability to filter by current user.
Closes #2320
100 lines
2.7 KiB
Ruby
100 lines
2.7 KiB
Ruby
class Spinach::Features::AdminGroups < Spinach::FeatureSteps
|
|
include SharedAuthentication
|
|
include SharedPaths
|
|
include SharedUser
|
|
include SharedActiveTab
|
|
include Select2Helper
|
|
|
|
When 'I visit admin group page' do
|
|
visit admin_group_path(current_group)
|
|
end
|
|
|
|
When 'I click new group link' do
|
|
click_link "New Group"
|
|
end
|
|
|
|
step 'I have group with projects' do
|
|
@group = create(:group)
|
|
@project = create(:project, group: @group)
|
|
@event = create(:closed_issue_event, project: @project)
|
|
|
|
@project.team << [current_user, :master]
|
|
end
|
|
|
|
step 'submit form with new group info' do
|
|
fill_in 'group_path', with: 'gitlab'
|
|
fill_in 'group_description', with: 'Group description'
|
|
click_button "Create group"
|
|
end
|
|
|
|
step 'I should see newly created group' do
|
|
expect(page).to have_content "Group: gitlab"
|
|
expect(page).to have_content "Group description"
|
|
end
|
|
|
|
step 'I should be redirected to group page' do
|
|
expect(current_path).to eq admin_group_path(Group.find_by(path: 'gitlab'))
|
|
end
|
|
|
|
When 'I select user "John Doe" from user list as "Reporter"' do
|
|
select2(user_john.id, from: "#user_ids", multiple: true)
|
|
page.within "#new_project_member" do
|
|
select "Reporter", from: "access_level"
|
|
end
|
|
click_button "Add users to group"
|
|
end
|
|
|
|
When 'I select user "johndoe@gitlab.com" from user list as "Reporter"' do
|
|
select2('johndoe@gitlab.com', from: "#user_ids", multiple: true)
|
|
page.within "#new_project_member" do
|
|
select "Reporter", from: "access_level"
|
|
end
|
|
click_button "Add users to group"
|
|
end
|
|
|
|
step 'I should see "John Doe" in team list in every project as "Reporter"' do
|
|
page.within ".group-users-list" do
|
|
expect(page).to have_content "John Doe"
|
|
expect(page).to have_content "Reporter"
|
|
end
|
|
end
|
|
|
|
step 'I should see "johndoe@gitlab.com" in team list in every project as "Reporter"' do
|
|
page.within ".group-users-list" do
|
|
expect(page).to have_content "johndoe@gitlab.com (invited)"
|
|
expect(page).to have_content "Reporter"
|
|
end
|
|
end
|
|
|
|
step 'I should be all groups' do
|
|
Group.all.each do |group|
|
|
expect(page).to have_content group.name
|
|
end
|
|
end
|
|
|
|
step 'we have user "John Doe" in group' do
|
|
current_group.add_reporter(user_john)
|
|
end
|
|
|
|
step 'I remove user "John Doe" from group' do
|
|
page.within "#user_#{user_john.id}" do
|
|
click_link 'Remove user from group'
|
|
end
|
|
end
|
|
|
|
step 'I should not see "John Doe" in team list' do
|
|
page.within ".group-users-list" do
|
|
expect(page).not_to have_content "John Doe"
|
|
end
|
|
end
|
|
|
|
protected
|
|
|
|
def current_group
|
|
@group ||= Group.first
|
|
end
|
|
|
|
def user_john
|
|
@user_john ||= User.find_by(name: "John Doe")
|
|
end
|
|
end
|