groups.rb 5.25 KB
Newer Older
1
class Spinach::Features::Groups < Spinach::FeatureSteps
2 3
  include SharedAuthentication
  include SharedPaths
4
  include SharedGroup
5
  include SharedUser
6

Valery Sizov's avatar
Valery Sizov committed
7 8 9 10 11 12 13 14 15
  step 'I should see group "Owned"' do
    expect(page).to have_content '@owned'
  end

  step 'I am a signed out user' do
    logout
  end

  step 'Group "Owned" has a public project "Public-project"' do
16
    group = owned_group
Valery Sizov's avatar
Valery Sizov committed
17 18 19 20 21 22 23 24 25 26

    @project = create :empty_project, :public,
                 group: group,
                 name: "Public-project"
  end

  step 'I should see project "Public-project"' do
    expect(page).to have_content 'Public-project'
  end

27
  step 'I should see group "Owned" projects list' do
28
    owned_group.projects.each do |project|
29
      expect(page).to have_link project.name
30 31 32
    end
  end

33
  step 'I should see projects activity feed' do
34
    expect(page).to have_content 'joined project'
35 36
  end

37
  step 'I should see issues from group "Owned" assigned to me' do
randx's avatar
randx committed
38
    assigned_to_me(:issues).each do |issue|
39
      expect(page).to have_content issue.title
randx's avatar
randx committed
40 41 42
    end
  end

43 44 45 46 47 48
  step 'I should not see issues from the archived project' do
    @archived_project.issues.each do |issue|
      expect(page).not_to have_content issue.title
    end
  end

49 50 51 52 53 54
  step 'I should not see merge requests from the archived project' do
    @archived_project.merge_requests.each do |mr|
      expect(page).not_to have_content mr.title
    end
  end

55
  step 'I should see merge requests from group "Owned" assigned to me' do
randx's avatar
randx committed
56
    assigned_to_me(:merge_requests).each do |issue|
57
      expect(page).to have_content issue.title[0..80]
randx's avatar
randx committed
58 59 60
    end
  end

61
  step 'project from group "Owned" has issues assigned to me' do
randx's avatar
randx committed
62 63
    create :issue,
      project: project,
64
      assignees: [current_user],
randx's avatar
randx committed
65 66 67
      author: current_user
  end

68
  step 'project from group "Owned" has merge requests assigned to me' do
randx's avatar
randx committed
69
    create :merge_request,
70 71
      source_project: project,
      target_project: project,
randx's avatar
randx committed
72 73 74 75
      assignee: current_user,
      author: current_user
  end

Rémy Coutable's avatar
Rémy Coutable committed
76
  step 'I should be redirected to group page' do
Robert Speicher's avatar
Robert Speicher committed
77
    expect(current_path).to eq group_path(Group.last)
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
78 79
  end

Rémy Coutable's avatar
Rémy Coutable committed
80
  step 'I change group name' do
81
    page.within '#tab-edit' do
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
82 83 84
      fill_in 'group_name', with: 'new-name'
      click_button "Save group"
    end
85 86
  end

87
  step 'I change group "Owned" name to "new-name"' do
88
    fill_in 'group_name', with: 'new-name'
89
    fill_in 'group_path', with: 'new-name'
90 91 92
    click_button "Save group"
  end

93
  step 'I should see new group "Owned" name' do
94
    page.within ".navbar-gitlab" do
95
      expect(page).to have_content "new-name"
96 97 98
    end
  end

99
  step 'I change group "Owned" avatar' do
100
    attach_file(:group_avatar, File.join(Rails.root, 'spec', 'fixtures', 'banana_sample.gif'))
Steven Thonus's avatar
Steven Thonus committed
101
    click_button "Save group"
102
    owned_group.reload
Steven Thonus's avatar
Steven Thonus committed
103 104
  end

105
  step 'I should see new group "Owned" avatar' do
106
    expect(owned_group.avatar).to be_instance_of AvatarUploader
107
    expect(owned_group.avatar.url).to eq "/uploads/system/group/avatar/#{Group.find_by(name: "Owned").id}/banana_sample.gif"
Steven Thonus's avatar
Steven Thonus committed
108 109 110
  end

  step 'I should see the "Remove avatar" button' do
111
    expect(page).to have_link("Remove avatar")
Steven Thonus's avatar
Steven Thonus committed
112 113
  end

114
  step 'I have group "Owned" avatar' do
115
    attach_file(:group_avatar, File.join(Rails.root, 'spec', 'fixtures', 'banana_sample.gif'))
Steven Thonus's avatar
Steven Thonus committed
116
    click_button "Save group"
117
    owned_group.reload
Steven Thonus's avatar
Steven Thonus committed
118 119
  end

120
  step 'I remove group "Owned" avatar' do
Steven Thonus's avatar
Steven Thonus committed
121
    click_link "Remove avatar"
122
    owned_group.reload
Steven Thonus's avatar
Steven Thonus committed
123 124
  end

125
  step 'I should not see group "Owned" avatar' do
126
    expect(owned_group.avatar?).to eq false
Steven Thonus's avatar
Steven Thonus committed
127 128 129
  end

  step 'I should not see the "Remove avatar" button' do
130
    expect(page).not_to have_link("Remove avatar")
Steven Thonus's avatar
Steven Thonus committed
131 132
  end

Artem Sidorenko's avatar
Artem Sidorenko committed
133 134
  step 'Group "Owned" has archived project' do
    group = Group.find_by(name: 'Owned')
135
    @archived_project = create(:empty_project, :archived, namespace: group, path: "archived-project")
Artem Sidorenko's avatar
Artem Sidorenko committed
136 137 138 139 140 141
  end

  step 'I should see "archived" label' do
    expect(page).to have_xpath("//span[@class='label label-warning']", text: 'archived')
  end

142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
  step 'LDAP enabled' do
    allow(Gitlab.config.ldap).to receive(:enabled).and_return(true)
  end

  step 'LDAP disabled' do
    allow(Gitlab.config.ldap).to receive(:enabled).and_return(false)
  end

  step 'I add a new LDAP synchronization' do
    page.within('form#new_ldap_group_link') do
      find('#ldap_group_link_cn', visible: false).set('my-group-cn')
      # fill_in('LDAP Group cn', with: 'my-group-cn', visible: false)
      select 'Developer', from: "ldap_group_link_group_access"
      click_button 'Add synchronization'
    end
  end

  step 'I see a new LDAP synchronization listed' do
    expect(page).not_to have_content('No synchronizations yet')
    expect(page).to have_content('As Developer on ldap server')
  end

164
  step 'I visit group "NonExistentGroup" page' do
165
    visit group_path("NonExistentGroup")
166 167
  end

168 169 170
  step 'the archived project have some issues' do
    create :issue,
      project: @archived_project,
171
      assignees: [current_user],
172 173 174
      author: current_user
  end

175 176 177 178 179 180 181 182
  step 'the archived project have some merge requests' do
    create :merge_request,
      source_project: @archived_project,
      target_project: @archived_project,
      assignee: current_user,
      author: current_user
  end

183
  private
184

185
  def assigned_to_me(key)
186
    project.send(key).where(assignee_id: current_user.id)
randx's avatar
randx committed
187
  end
188 189

  def project
190
    owned_group.projects.first
191
  end
192
end