summaryrefslogtreecommitdiff
path: root/spec/features/admin/admin_projects_spec.rb
blob: aab2e6d7cef5e15ea27dc2045aa8838331f7ffcc (plain)
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe "Admin::Projects" do
  include Spec::Support::Helpers::Features::MembersHelpers
  include Select2Helper

  let(:user) { create :user }
  let(:project) { create(:project) }
  let(:current_user) { create(:admin) }

  before do
    sign_in(current_user)
    gitlab_enable_admin_mode_sign_in(current_user)
  end

  describe "GET /admin/projects" do
    let!(:archived_project) { create :project, :public, :archived }

    before do
      expect(project).to be_persisted
      visit admin_projects_path
    end

    it "is ok" do
      expect(current_path).to eq(admin_projects_path)
    end

    it 'renders projects list without archived project' do
      expect(page).to have_content(project.name)
      expect(page).not_to have_content(archived_project.name)
    end

    it 'renders all projects', :js do
      find(:css, '#sort-projects-dropdown').click
      click_link 'Show archived projects'

      expect(page).to have_content(project.name)
      expect(page).to have_content(archived_project.name)
      expect(page).to have_xpath("//span[@class='badge badge-warning']", text: 'archived')
    end

    it 'renders only archived projects', :js do
      find(:css, '#sort-projects-dropdown').click
      click_link 'Show archived projects only'

      expect(page).to have_content(archived_project.name)
      expect(page).not_to have_content(project.name)
    end
  end

  describe "GET /admin/projects/:namespace_id/:id" do
    before do
      expect(project).to be_persisted

      visit admin_projects_path
      click_link project.name
    end

    it "has project info" do
      expect(current_path).to eq admin_project_path(project)
      expect(page).to have_content(project.path)
      expect(page).to have_content(project.name)
      expect(page).to have_content(project.full_name)
      expect(page).to have_content(project.creator.name)
      expect(page).to have_content(project.id)
    end
  end

  describe 'transfer project' do
    # The gitlab-shell transfer will fail for a project without a repository
    let(:project) { create(:project, :repository) }

    before do
      create(:group, name: 'Web')

      allow_next_instance_of(Projects::TransferService) do |instance|
        allow(instance).to receive(:move_uploads_to_new_namespace).and_return(true)
      end
    end

    it 'transfers project to group web', :js do
      visit admin_project_path(project)

      click_button 'Search for Namespace'
      click_link 'group: web'
      click_button 'Transfer'

      expect(page).to have_content("Web / #{project.name}")
      expect(page).to have_content('Namespace: Web')
    end
  end

  context 'when `vue_project_members_list` feature flag is enabled', :js do
    describe 'admin adds themselves to the project' do
      before do
        project.add_maintainer(user)
        stub_feature_flags(invite_members_group_modal: false)
      end

      it 'adds admin to the project as developer', :js do
        visit project_project_members_path(project)

        page.within '.invite-users-form' do
          select2(current_user.id, from: '#user_ids', multiple: true)
          select 'Developer', from: 'access_level'
        end

        click_button 'Invite'

        expect(find_member_row(current_user)).to have_content('Developer')
      end
    end

    describe 'admin removes themselves from the project' do
      before do
        project.add_maintainer(user)
        project.add_developer(current_user)
      end

      it 'removes admin from the project' do
        visit project_project_members_path(project)

        expect(find_member_row(current_user)).to have_content('Developer')

        page.within find_member_row(current_user) do
          click_button 'Leave'
        end

        page.within('[role="dialog"]') do
          click_button('Leave')
        end

        expect(current_path).to match dashboard_projects_path
      end
    end
  end

  context 'when `vue_project_members_list` feature flag is disabled' do
    before do
      stub_feature_flags(vue_project_members_list: false)
    end

    describe 'admin adds themselves to the project' do
      before do
        project.add_maintainer(user)
        stub_feature_flags(invite_members_group_modal: false)
      end

      it 'adds admin to the project as developer', :js do
        visit project_project_members_path(project)

        page.within '.invite-users-form' do
          select2(current_user.id, from: '#user_ids', multiple: true)
          select 'Developer', from: 'access_level'
        end

        click_button 'Invite'

        page.within '.content-list' do
          expect(page).to have_content(current_user.name)
          expect(page).to have_content('Developer')
        end
      end
    end

    describe 'admin removes themselves from the project' do
      before do
        project.add_maintainer(user)
        project.add_developer(current_user)
      end

      it 'removes admin from the project' do
        visit project_project_members_path(project)

        page.within '.content-list' do
          expect(page).to have_content(current_user.name)
          expect(page).to have_content('Developer')
        end

        find(:css, '.content-list li', text: current_user.name).find(:css, 'a.btn-danger').click

        expect(page).not_to have_selector(:css, '.content-list')
      end
    end
  end
end