internal_access_spec.rb 22.8 KB
Newer Older
1 2
# frozen_string_literal: true

3 4
require 'spec_helper'

5
describe "Internal Project Access" do
6 7
  include AccessMatchers

8
  set(:project) { create(:project, :internal, :repository) }
9

10 11 12 13
  before do
    stub_feature_flags(job_log_json: false)
  end

14
  describe "Project should be internal" do
15
    describe '#internal?' do
D
Douwe Maan 已提交
16
      subject { project.internal? }
17 18
      it { is_expected.to be_truthy }
    end
19 20 21
  end

  describe "GET /:project_path" do
22
    subject { project_path(project) }
23

24 25
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
26
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
27 28 29 30 31 32
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
33 34 35
  end

  describe "GET /:project_path/tree/master" do
36
    subject { project_tree_path(project, project.repository.root_ref) }
37

38 39
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
40
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
41 42 43 44 45 46
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
47 48 49
  end

  describe "GET /:project_path/commits/master" do
50
    subject { project_commits_path(project, project.repository.root_ref, limit: 1) }
51

52 53
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
54
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
55 56 57 58 59 60
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
61 62 63
  end

  describe "GET /:project_path/commit/:sha" do
64
    subject { project_commit_path(project, project.repository.commit) }
65

66 67
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
68
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
69 70 71 72 73 74
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
75 76 77
  end

  describe "GET /:project_path/compare" do
78
    subject { project_compare_index_path(project) }
79

80 81
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
82
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
83 84 85 86 87 88
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
89 90
  end

91
  describe "GET /:project_path/settings/members" do
92
    subject { project_settings_members_path(project) }
93

94 95
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
96
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
97 98 99 100 101 102
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:visitor) }
    it { is_expected.to be_denied_for(:external) }
103 104
  end

105
  describe "GET /:project_path/settings/ci_cd" do
106
    subject { project_settings_ci_cd_path(project) }
107 108 109

    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
110
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
111 112 113 114
    it { is_expected.to be_denied_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
J
Jose Ivan Vargas 已提交
115 116 117 118 119
    it { is_expected.to be_denied_for(:visitor) }
    it { is_expected.to be_denied_for(:external) }
  end

  describe "GET /:project_path/settings/repository" do
120
    subject { project_settings_repository_path(project) }
J
Jose Ivan Vargas 已提交
121

122 123
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
124
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
125 126 127 128 129 130 131 132
    it { is_expected.to be_denied_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:visitor) }
    it { is_expected.to be_denied_for(:external) }
  end

133
  describe "GET /:project_path/blob" do
Z
Zeger-Jan van de Weg 已提交
134
    let(:commit) { project.repository.commit }
135
    subject { project_blob_path(project, File.join(commit.id, '.gitignore')) }
136

137 138
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
139
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
140 141 142 143 144 145
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
146 147 148
  end

  describe "GET /:project_path/edit" do
149
    subject { edit_project_path(project) }
150

151 152
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
153
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
154 155 156 157 158 159
    it { is_expected.to be_denied_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
160 161 162
  end

  describe "GET /:project_path/deploy_keys" do
163
    subject { project_deploy_keys_path(project) }
164

165 166
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
167
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
168 169 170 171 172 173
    it { is_expected.to be_denied_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
174 175 176
  end

  describe "GET /:project_path/issues" do
177
    subject { project_issues_path(project) }
178

179 180
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
181
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
182 183 184 185 186 187
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
188 189
  end

190 191 192 193 194 195
  describe "GET /:project_path/issues/:id/edit" do
    let(:issue) { create(:issue, project: project) }
    subject { edit_project_issue_path(project, issue) }

    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
196
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
197 198 199 200 201 202 203 204
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
  end

205
  describe "GET /:project_path/snippets" do
206
    subject { project_snippets_path(project) }
207

208 209
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
210
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
211 212 213 214 215 216
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
217 218 219
  end

  describe "GET /:project_path/snippets/new" do
220
    subject { new_project_snippet_path(project) }
221

222 223
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
224
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
225 226 227 228 229 230
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
231 232 233
  end

  describe "GET /:project_path/merge_requests" do
234
    subject { project_merge_requests_path(project) }
235

236 237
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
238
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
239 240 241 242 243 244
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
245 246 247
  end

  describe "GET /:project_path/merge_requests/new" do
248
    subject { project_new_merge_request_path(project) }
249

250 251
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
252
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
253 254 255 256 257 258
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
259 260 261
  end

  describe "GET /:project_path/branches" do
262
    subject { project_branches_path(project) }
263 264 265

    before do
      # Speed increase
266
      allow_any_instance_of(Project).to receive(:branches).and_return([])
267 268
    end

269 270
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
271
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
272 273 274 275 276 277
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
278 279 280
  end

  describe "GET /:project_path/tags" do
281
    subject { project_tags_path(project) }
282 283 284

    before do
      # Speed increase
285
      allow_any_instance_of(Project).to receive(:tags).and_return([])
286 287
    end

288 289
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
290
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
291 292 293 294 295 296
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
297 298
  end

299
  describe "GET /:project_path/settings/integrations" do
300
    subject { project_settings_integrations_path(project) }
301

302 303
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
304
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
305 306 307 308 309 310
    it { is_expected.to be_denied_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
311
  end
K
Kamil Trzcinski 已提交
312 313

  describe "GET /:project_path/pipelines" do
314
    subject { project_pipelines_path(project) }
K
Kamil Trzcinski 已提交
315

316 317
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
318
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
319 320 321 322 323 324
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
325 326 327 328
  end

  describe "GET /:project_path/pipelines/:id" do
    let(:pipeline) { create(:ci_pipeline, project: project) }
329
    subject { project_pipeline_path(project, pipeline) }
K
Kamil Trzcinski 已提交
330

331 332
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
333
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
334 335 336 337 338 339
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
340 341 342
  end

  describe "GET /:project_path/builds" do
343
    subject { project_jobs_path(project) }
K
Kamil Trzcinski 已提交
344 345

    context "when allowed for public and internal" do
346 347 348
      before do
        project.update(public_builds: true)
      end
K
Kamil Trzcinski 已提交
349

350 351
      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
352
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
353 354 355 356 357 358
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_allowed_for(:guest).of(project) }
      it { is_expected.to be_allowed_for(:user) }
      it { is_expected.to be_denied_for(:external) }
      it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
359 360 361
    end

    context "when disallowed for public and internal" do
362 363 364
      before do
        project.update(public_builds: false)
      end
K
Kamil Trzcinski 已提交
365

366 367
      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
368
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
369 370 371 372 373 374
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_denied_for(:guest).of(project) }
      it { is_expected.to be_denied_for(:user) }
      it { is_expected.to be_denied_for(:external) }
      it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
375 376 377 378 379 380
    end
  end

  describe "GET /:project_path/builds/:id" do
    let(:pipeline) { create(:ci_pipeline, project: project) }
    let(:build) { create(:ci_build, pipeline: pipeline) }
381
    subject { project_job_path(project, build.id) }
K
Kamil Trzcinski 已提交
382 383

    context "when allowed for public and internal" do
384 385 386
      before do
        project.update(public_builds: true)
      end
K
Kamil Trzcinski 已提交
387

388 389
      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
390
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
391 392 393 394 395 396
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_allowed_for(:guest).of(project) }
      it { is_expected.to be_allowed_for(:user) }
      it { is_expected.to be_denied_for(:external) }
      it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
397 398 399
    end

    context "when disallowed for public and internal" do
400 401 402
      before do
        project.update(public_builds: false)
      end
K
Kamil Trzcinski 已提交
403

404 405
      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
406
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
407 408 409 410 411
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_denied_for(:guest).of(project) }
      it { is_expected.to be_denied_for(:user) }
      it { is_expected.to be_denied_for(:external) }
412 413 414 415 416 417 418
      it { is_expected.to be_denied_for(:visitor) }
    end
  end

  describe 'GET /:project_path/builds/:id/trace' do
    let(:pipeline) { create(:ci_pipeline, project: project) }
    let(:build) { create(:ci_build, pipeline: pipeline) }
419
    subject { trace_project_job_path(project, build.id) }
420 421 422 423 424 425 426 427

    context 'when allowed for public and internal' do
      before do
        project.update(public_builds: true)
      end

      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
428
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
429 430 431 432 433 434 435 436 437 438 439 440 441 442 443
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_allowed_for(:guest).of(project) }
      it { is_expected.to be_allowed_for(:user) }
      it { is_expected.to be_denied_for(:external) }
      it { is_expected.to be_denied_for(:visitor) }
    end

    context 'when disallowed for public and internal' do
      before do
        project.update(public_builds: false)
      end

      it { is_expected.to be_allowed_for(:admin) }
      it { is_expected.to be_allowed_for(:owner).of(project) }
444
      it { is_expected.to be_allowed_for(:maintainer).of(project) }
445 446 447 448 449
      it { is_expected.to be_allowed_for(:developer).of(project) }
      it { is_expected.to be_allowed_for(:reporter).of(project) }
      it { is_expected.to be_denied_for(:guest).of(project) }
      it { is_expected.to be_denied_for(:user) }
      it { is_expected.to be_denied_for(:external) }
450
      it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
451 452 453
    end
  end

454
  describe "GET /:project_path/pipeline_schedules" do
455
    subject { project_pipeline_schedules_path(project) }
456 457 458

    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
459
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
460
    it { is_expected.to be_allowed_for(:developer).of(project) }
461 462 463
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
464 465 466 467
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
  end

K
Kamil Trzcinski 已提交
468
  describe "GET /:project_path/environments" do
469
    subject { project_environments_path(project) }
K
Kamil Trzcinski 已提交
470

471 472
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
473
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
474 475 476 477 478 479
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
480 481 482 483
  end

  describe "GET /:project_path/environments/:id" do
    let(:environment) { create(:environment, project: project) }
484
    subject { project_environment_path(project, environment) }
K
Kamil Trzcinski 已提交
485

486 487
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
488
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
489 490 491 492 493 494 495 496 497 498
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
  end

  describe "GET /:project_path/environments/:id/deployments" do
    let(:environment) { create(:environment, project: project) }
499
    subject { project_environment_deployments_path(project, environment) }
500 501 502

    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
503
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
504 505 506 507 508 509
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
510 511 512
  end

  describe "GET /:project_path/environments/new" do
513
    subject { new_project_environment_path(project) }
K
Kamil Trzcinski 已提交
514

515 516
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
517
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
518 519 520 521 522 523
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_denied_for(:reporter).of(project) }
    it { is_expected.to be_denied_for(:guest).of(project) }
    it { is_expected.to be_denied_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
K
Kamil Trzcinski 已提交
524
  end
525 526

  describe "GET /:project_path/container_registry" do
527
    let(:container_repository) { create(:container_repository) }
A
Andre Guedes 已提交
528

529
    before do
530
      stub_container_registry_tags(repository: :any, tags: ['latest'])
531
      stub_container_registry_config(enabled: true)
532
      project.container_repositories << container_repository
533 534
    end

535
    subject { project_container_registry_index_path(project) }
536

537 538
    it { is_expected.to be_allowed_for(:admin) }
    it { is_expected.to be_allowed_for(:owner).of(project) }
539
    it { is_expected.to be_allowed_for(:maintainer).of(project) }
540 541 542 543 544 545
    it { is_expected.to be_allowed_for(:developer).of(project) }
    it { is_expected.to be_allowed_for(:reporter).of(project) }
    it { is_expected.to be_allowed_for(:guest).of(project) }
    it { is_expected.to be_allowed_for(:user) }
    it { is_expected.to be_denied_for(:external) }
    it { is_expected.to be_denied_for(:visitor) }
546
  end
547
end