summaryrefslogtreecommitdiff
path: root/spec/features/projects/user_edits_files_spec.rb
diff options
context:
space:
mode:
authorRobert Speicher <robert@gitlab.com>2018-04-12 17:04:08 +0000
committerFilipa Lacerda <filipa@gitlab.com>2018-04-17 15:20:32 +0100
commit58590b8a94510a00fa7fd6df4204b21a65addf8f (patch)
tree876cbf4e8303a8b7887bfe62aa3ccb4ed7160a01 /spec/features/projects/user_edits_files_spec.rb
parent30acfab516e19679c8f19aaa38883daf98114258 (diff)
downloadgitlab-ce-58590b8a94510a00fa7fd6df4204b21a65addf8f.tar.gz
Merge branch 'dm-archived-read-only' into 'master'
Make archived projects completely read-only Closes #44788 See merge request gitlab-org/gitlab-ce!18136
Diffstat (limited to 'spec/features/projects/user_edits_files_spec.rb')
-rw-r--r--spec/features/projects/user_edits_files_spec.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/spec/features/projects/user_edits_files_spec.rb b/spec/features/projects/user_edits_files_spec.rb
index 05c2be473da..33836f5ed88 100644
--- a/spec/features/projects/user_edits_files_spec.rb
+++ b/spec/features/projects/user_edits_files_spec.rb
@@ -12,6 +12,23 @@ describe 'User edits files' do
sign_in(user)
end
+ shared_examples 'unavailable for an archived project' do
+ it 'does not show the edit link for an archived project', :js do
+ project.update!(archived: true)
+ visit project_tree_path(project, project.repository.root_ref)
+
+ click_link('.gitignore')
+
+ aggregate_failures 'available edit buttons' do
+ expect(page).not_to have_text('Edit')
+ expect(page).not_to have_text('Web IDE')
+
+ expect(page).not_to have_text('Replace')
+ expect(page).not_to have_text('Delete')
+ end
+ end
+ end
+
context 'when an user has write access' do
before do
project.add_master(user)
@@ -85,6 +102,8 @@ describe 'User edits files' do
expect(page).to have_css('.line_holder.new')
end
+
+ it_behaves_like 'unavailable for an archived project'
end
context 'when an user does not have write access' do
@@ -168,6 +187,10 @@ describe 'User edits files' do
expect(page).to have_content("From #{forked_project.full_path}")
expect(page).to have_content("into #{project2.full_path}")
end
+
+ it_behaves_like 'unavailable for an archived project' do
+ let(:project) { project2 }
+ end
end
end
end