diff options
author | Douwe Maan <douwe@gitlab.com> | 2016-05-20 21:04:55 +0000 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2016-05-20 21:04:55 +0000 |
commit | a97cb8f8b81defc2fac460aefa41d3522f388b18 (patch) | |
tree | 84c4bd253998da06834739fbb21feac7e33f9d2c /spec/controllers | |
parent | 56eb42007ae8c3c390b35bf336884b3bad3591c5 (diff) | |
parent | 6fb9bf87c4f202dee9815c10cad9486a1077cc99 (diff) | |
download | gitlab-ce-a97cb8f8b81defc2fac460aefa41d3522f388b18.tar.gz |
Merge branch 'issue_9013' into 'master'
Let users set notification levels in projects which they are not members
Fixes #9013
See merge request !3986
Diffstat (limited to 'spec/controllers')
-rw-r--r-- | spec/controllers/projects/notification_settings_controller_spec.rb | 14 | ||||
-rw-r--r-- | spec/controllers/projects_controller_spec.rb | 34 |
2 files changed, 48 insertions, 0 deletions
diff --git a/spec/controllers/projects/notification_settings_controller_spec.rb b/spec/controllers/projects/notification_settings_controller_spec.rb index 4908b545648..c5d17d97ec9 100644 --- a/spec/controllers/projects/notification_settings_controller_spec.rb +++ b/spec/controllers/projects/notification_settings_controller_spec.rb @@ -34,5 +34,19 @@ describe Projects::NotificationSettingsController do expect(response.status).to eq 200 end end + + context 'not authorized' do + let(:private_project) { create(:project, :private) } + before { sign_in(user) } + + it 'returns 404' do + put :update, + namespace_id: private_project.namespace.to_param, + project_id: private_project.to_param, + notification_setting: { level: :participating } + + expect(response.status).to eq(404) + end + end end end diff --git a/spec/controllers/projects_controller_spec.rb b/spec/controllers/projects_controller_spec.rb index 069cd917e5a..91b46c4d65c 100644 --- a/spec/controllers/projects_controller_spec.rb +++ b/spec/controllers/projects_controller_spec.rb @@ -8,6 +8,40 @@ describe ProjectsController do let(:txt) { fixture_file_upload(Rails.root + 'spec/fixtures/doc_sample.txt', 'text/plain') } describe "GET show" do + context "user not project member" do + before { sign_in(user) } + + context "user does not have access to project" do + let(:private_project) { create(:project, :private) } + + it "does not initialize notification setting" do + get :show, namespace_id: private_project.namespace.path, id: private_project.path + expect(assigns(:notification_setting)).to be_nil + end + end + + context "user has access to project" do + context "and does not have notification setting" do + it "initializes notification as disabled" do + get :show, namespace_id: public_project.namespace.path, id: public_project.path + expect(assigns(:notification_setting).level).to eq("global") + end + end + + context "and has notification setting" do + before do + setting = user.notification_settings_for(public_project) + setting.level = :watch + setting.save + end + + it "shows current notification setting" do + get :show, namespace_id: public_project.namespace.path, id: public_project.path + expect(assigns(:notification_setting).level).to eq("watch") + end + end + end + end context "rendering default project view" do render_views |