2019-04-15 06:17:05 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2012-09-17 12:38:59 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2013-06-23 13:25:06 -04:00
|
|
|
describe Projects::TreeController do
|
2017-01-25 16:44:33 -05:00
|
|
|
let(:project) { create(:project, :repository) }
|
2012-09-17 12:38:59 -04:00
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
sign_in(user)
|
|
|
|
|
2018-07-11 10:36:08 -04:00
|
|
|
project.add_maintainer(user)
|
2012-09-17 12:38:59 -04:00
|
|
|
controller.instance_variable_set(:@project, project)
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "GET show" do
|
|
|
|
# Make sure any errors accessing the tree in our views bubble up to this spec
|
|
|
|
render_views
|
|
|
|
|
2015-01-24 13:02:58 -05:00
|
|
|
before do
|
2019-04-07 23:55:29 -04:00
|
|
|
expect(::Gitlab::GitalyClient).to receive(:allow_ref_name_caching).and_call_original
|
|
|
|
|
2015-06-23 01:24:39 -04:00
|
|
|
get(:show,
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
namespace_id: project.namespace.to_param,
|
|
|
|
project_id: project,
|
|
|
|
id: id
|
|
|
|
})
|
2015-01-24 13:02:58 -05:00
|
|
|
end
|
2012-09-17 12:38:59 -04:00
|
|
|
|
|
|
|
context "valid branch, no path" do
|
|
|
|
let(:id) { 'master' }
|
2015-02-12 13:17:35 -05:00
|
|
|
it { is_expected.to respond_with(:success) }
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "valid branch, valid path" do
|
2014-08-07 13:46:17 -04:00
|
|
|
let(:id) { 'master/encoding/' }
|
2015-02-12 13:17:35 -05:00
|
|
|
it { is_expected.to respond_with(:success) }
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "valid branch, invalid path" do
|
2013-04-03 08:55:08 -04:00
|
|
|
let(:id) { 'master/invalid-path/' }
|
2015-02-12 13:17:35 -05:00
|
|
|
it { is_expected.to respond_with(:not_found) }
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "invalid branch, valid path" do
|
2014-08-07 13:46:17 -04:00
|
|
|
let(:id) { 'invalid-branch/encoding/' }
|
2015-02-12 13:17:35 -05:00
|
|
|
it { is_expected.to respond_with(:not_found) }
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|
2015-07-20 19:55:45 -04:00
|
|
|
|
|
|
|
context "valid empty branch, invalid path" do
|
|
|
|
let(:id) { 'empty-branch/invalid-path/' }
|
|
|
|
it { is_expected.to respond_with(:not_found) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "valid empty branch" do
|
|
|
|
let(:id) { 'empty-branch' }
|
|
|
|
it { is_expected.to respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "invalid SHA commit ID" do
|
|
|
|
let(:id) { 'ff39438/.gitignore' }
|
|
|
|
it { is_expected.to respond_with(:not_found) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "valid SHA commit ID" do
|
|
|
|
let(:id) { '6d39438' }
|
|
|
|
it { is_expected.to respond_with(:success) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "valid SHA commit ID with path" do
|
|
|
|
let(:id) { '6d39438/.gitignore' }
|
2017-10-19 14:28:19 -04:00
|
|
|
it { expect(response).to have_gitlab_http_status(302) }
|
2015-07-20 19:55:45 -04:00
|
|
|
end
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|
2014-07-08 14:25:25 -04:00
|
|
|
|
2018-12-26 02:34:47 -05:00
|
|
|
describe 'GET show with whitespace in ref' do
|
|
|
|
render_views
|
|
|
|
|
|
|
|
let(:id) { "this ref/api/responses" }
|
|
|
|
|
|
|
|
it 'does not call make a Gitaly request' do
|
|
|
|
allow(::Gitlab::GitalyClient).to receive(:call).and_call_original
|
|
|
|
expect(::Gitlab::GitalyClient).not_to receive(:call).with(anything, :commit_service, :find_commit, anything, anything)
|
|
|
|
|
|
|
|
get(:show,
|
|
|
|
params: {
|
|
|
|
namespace_id: project.namespace.to_param,
|
|
|
|
project_id: project,
|
|
|
|
id: id
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-07-08 14:25:25 -04:00
|
|
|
describe 'GET show with blob path' do
|
|
|
|
render_views
|
|
|
|
|
|
|
|
before do
|
2015-06-23 01:24:39 -04:00
|
|
|
get(:show,
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
namespace_id: project.namespace.to_param,
|
|
|
|
project_id: project,
|
|
|
|
id: id
|
|
|
|
})
|
2014-07-08 14:25:25 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'redirect to blob' do
|
|
|
|
let(:id) { 'master/README.md' }
|
2015-02-12 13:53:23 -05:00
|
|
|
it 'redirects' do
|
2017-07-20 05:34:09 -04:00
|
|
|
redirect_url = "/#{project.full_path}/blob/master/README.md"
|
2017-06-21 09:48:12 -04:00
|
|
|
expect(subject)
|
|
|
|
.to redirect_to(redirect_url)
|
2015-02-12 13:53:23 -05:00
|
|
|
end
|
2014-07-08 14:25:25 -04:00
|
|
|
end
|
|
|
|
end
|
2015-09-17 01:45:22 -04:00
|
|
|
|
|
|
|
describe '#create_dir' do
|
|
|
|
render_views
|
|
|
|
|
|
|
|
before do
|
|
|
|
post(:create_dir,
|
2018-12-17 17:52:17 -05:00
|
|
|
params: {
|
|
|
|
namespace_id: project.namespace.to_param,
|
|
|
|
project_id: project,
|
|
|
|
id: 'master',
|
|
|
|
dir_name: path,
|
|
|
|
branch_name: branch_name,
|
|
|
|
commit_message: 'Test commit message'
|
|
|
|
})
|
2015-09-17 01:45:22 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'successful creation' do
|
|
|
|
let(:path) { 'files/new_dir'}
|
2017-04-19 20:37:44 -04:00
|
|
|
let(:branch_name) { 'master-test'}
|
2015-09-17 01:45:22 -04:00
|
|
|
|
|
|
|
it 'redirects to the new directory' do
|
2017-06-21 09:48:12 -04:00
|
|
|
expect(subject)
|
2017-07-20 05:34:09 -04:00
|
|
|
.to redirect_to("/#{project.full_path}/tree/#{branch_name}/#{path}")
|
2015-12-18 04:03:34 -05:00
|
|
|
expect(flash[:notice]).to eq('The directory has been successfully created.')
|
2015-09-17 01:45:22 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'unsuccessful creation' do
|
|
|
|
let(:path) { 'README.md' }
|
2017-04-19 20:37:44 -04:00
|
|
|
let(:branch_name) { 'master'}
|
2015-09-17 01:45:22 -04:00
|
|
|
|
|
|
|
it 'does not allow overwriting of existing files' do
|
2017-06-21 09:48:12 -04:00
|
|
|
expect(subject)
|
2017-07-20 05:34:09 -04:00
|
|
|
.to redirect_to("/#{project.full_path}/tree/master")
|
2017-04-19 20:37:44 -04:00
|
|
|
expect(flash[:alert]).to eq('A file with this name already exists')
|
2015-09-17 01:45:22 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2012-09-17 12:38:59 -04:00
|
|
|
end
|