summaryrefslogtreecommitdiff
path: root/spec/features/projects/features_visibility_spec.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2019-10-31 21:06:28 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2019-10-31 21:06:28 +0000
commit8f210aebe1d740e8ee194f171f1f33a6e1fba313 (patch)
treef43c545801bb96fd0737f18493fb30ab92972627 /spec/features/projects/features_visibility_spec.rb
parent996f700997805b3590da8d8afdd19d193989078a (diff)
downloadgitlab-ce-8f210aebe1d740e8ee194f171f1f33a6e1fba313.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/features/projects/features_visibility_spec.rb')
-rw-r--r--spec/features/projects/features_visibility_spec.rb102
1 files changed, 49 insertions, 53 deletions
diff --git a/spec/features/projects/features_visibility_spec.rb b/spec/features/projects/features_visibility_spec.rb
index 8b7fef84dd7..9ec61743a11 100644
--- a/spec/features/projects/features_visibility_spec.rb
+++ b/spec/features/projects/features_visibility_spec.rb
@@ -3,9 +3,8 @@
require 'spec_helper'
describe 'Edit Project Settings' do
- set(:project) { create(:project, :public, :repository) }
-
let(:member) { create(:user) }
+ let!(:project) { create(:project, :public, :repository) }
let!(:issue) { create(:issue, project: project) }
let(:non_member) { create(:user) }
@@ -82,88 +81,85 @@ describe 'Edit Project Settings' do
end
describe 'project features visibility pages' do
- set(:pipeline) { create(:ci_empty_pipeline, project: project) }
- set(:job) { create(:ci_build, pipeline: pipeline) }
-
- where(:method_name, :build_url) do
- [
- [:builds, -> { project_job_path(project, job) }],
- [:issues, -> { project_issues_path(project) }],
- [:wiki, -> { project_wiki_path(project, :home) }],
- [:snippets, -> { project_snippets_path(project) }],
- [:merge_requests, -> { project_merge_requests_path(project) }]
- ]
+ let(:pipeline) { create(:ci_empty_pipeline, project: project) }
+ let(:job) { create(:ci_build, pipeline: pipeline) }
+
+ let(:tools) do
+ {
+ builds: project_job_path(project, job),
+ issues: project_issues_path(project),
+ wiki: project_wiki_path(project, :home),
+ snippets: project_snippets_path(project),
+ merge_requests: project_merge_requests_path(project)
+ }
end
- with_them do
- let(:url) { build_url.call }
- let(:attr_name) { "#{method_name}_access_level" }
-
- context 'normal user' do
- before do
- project.team.truncate
- sign_in(member)
- end
-
- it 'renders 200 if tool is enabled' do
- project.project_feature.update_attribute(attr_name, ProjectFeature::ENABLED)
+ context 'normal user' do
+ before do
+ sign_in(member)
+ end
+ it 'renders 200 if tool is enabled' do
+ tools.each do |method_name, url|
+ project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::ENABLED)
visit url
-
expect(page.status_code).to eq(200)
end
+ end
- it 'renders 404 if feature is disabled' do
- project.project_feature.update_attribute(attr_name, ProjectFeature::DISABLED)
-
+ it 'renders 404 if feature is disabled' do
+ tools.each do |method_name, url|
+ project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::DISABLED)
visit url
-
expect(page.status_code).to eq(404)
end
+ end
- it 'renders 404 if feature is enabled only for team members' do
- project.project_feature.update_attribute(attr_name, ProjectFeature::PRIVATE)
+ it 'renders 404 if feature is enabled only for team members' do
+ project.team.truncate
+ tools.each do |method_name, url|
+ project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::PRIVATE)
visit url
-
expect(page.status_code).to eq(404)
end
+ end
- it 'renders 200 if user is member of group' do
- group = create(:group)
- project.group = group
- project.save
-
- group.add_owner(member)
+ it 'renders 200 if user is member of group' do
+ group = create(:group)
+ project.group = group
+ project.save
- project.project_feature.update_attribute(attr_name, ProjectFeature::PRIVATE)
+ group.add_owner(member)
+ tools.each do |method_name, url|
+ project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::PRIVATE)
visit url
-
expect(page.status_code).to eq(200)
end
end
+ end
- context 'admin user' do
- before do
- non_member.update_attribute(:admin, true)
- project.team.truncate
- sign_in(non_member)
- end
+ context 'admin user' do
+ before do
+ non_member.update_attribute(:admin, true)
+ sign_in(non_member)
+ end
- it 'renders 404 if feature is disabled' do
+ it 'renders 404 if feature is disabled' do
+ tools.each do |method_name, url|
project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::DISABLED)
-
visit url
-
expect(page.status_code).to eq(404)
end
+ end
- it 'renders 200 if feature is enabled only for team members' do
- project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::PRIVATE)
+ it 'renders 200 if feature is enabled only for team members' do
+ project.team.truncate
+ tools.each do |method_name, url|
+ project.project_feature.update_attribute("#{method_name}_access_level", ProjectFeature::PRIVATE)
visit url
-
expect(page.status_code).to eq(200)
end
end