diff options
author | Dmitriy Zaporozhets <dzaporozhets@gitlab.com> | 2015-04-08 11:11:38 +0000 |
---|---|---|
committer | Dmitriy Zaporozhets <dzaporozhets@gitlab.com> | 2015-04-08 11:11:38 +0000 |
commit | 4902dca9661ebcaaaecd7deff967225b657423b5 (patch) | |
tree | 743d9209ba2aee172d070e283f2734228f8a95e1 | |
parent | 584fa0bdca76de20ed775800e255895e6be5fc06 (diff) | |
parent | 167a6b9eefd2076d08b4f1504f8b5ff3fb281026 (diff) | |
download | gitlab-ce-4902dca9661ebcaaaecd7deff967225b657423b5.tar.gz |
Merge branch 'rs-issue-2152' into 'master'
Render a 404 when RefsController#logs_tree gets an HTML request
Fixes #2152
See merge request !1748
-rw-r--r-- | app/controllers/projects/refs_controller.rb | 5 | ||||
-rw-r--r-- | spec/controllers/projects/refs_controller_spec.rb | 41 |
2 files changed, 46 insertions, 0 deletions
diff --git a/app/controllers/projects/refs_controller.rb b/app/controllers/projects/refs_controller.rb index 67acf45ab7f..ec3b2b8d75a 100644 --- a/app/controllers/projects/refs_controller.rb +++ b/app/controllers/projects/refs_controller.rb @@ -55,5 +55,10 @@ class Projects::RefsController < Projects::ApplicationController commit: last_commit } end + + respond_to do |format| + format.html { render_404 } + format.js + end end end diff --git a/spec/controllers/projects/refs_controller_spec.rb b/spec/controllers/projects/refs_controller_spec.rb new file mode 100644 index 00000000000..c254ab7cb6e --- /dev/null +++ b/spec/controllers/projects/refs_controller_spec.rb @@ -0,0 +1,41 @@ +require 'spec_helper' + +describe Projects::RefsController do + let(:project) { create(:project) } + let(:user) { create(:user) } + + before do + sign_in(user) + project.team << [user, :developer] + end + + describe 'GET #logs_tree' do + def default_get(format = :html) + get :logs_tree, namespace_id: project.namespace.to_param, + project_id: project.to_param, id: 'master', + path: 'foo/bar/baz.html', format: format + end + + def xhr_get(format = :html) + xhr :get, :logs_tree, namespace_id: project.namespace.to_param, + project_id: project.to_param, id: 'master', + path: 'foo/bar/baz.html', format: format + end + + it 'never throws MissingTemplate' do + expect { default_get }.not_to raise_error + expect { xhr_get }.not_to raise_error + end + + it 'renders 404 for non-JS requests' do + xhr_get + + expect(response).to be_not_found + end + + it 'renders JS' do + xhr_get(:js) + expect(response).to be_success + end + end +end |