debian-mirror-gitlab/spec/controllers/projects/tree_controller_spec.rb

201 lines
4.9 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
require 'spec_helper'
describe Projects::TreeController do
2017-08-17 22:00:37 +05:30
let(:project) { create(:project, :repository) }
2014-09-02 18:07:02 +05:30
let(:user) { create(:user) }
before do
sign_in(user)
2018-11-18 11:00:15 +05:30
project.add_maintainer(user)
2014-09-02 18:07:02 +05:30
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-04-26 12:48:37 +05:30
before do
2019-07-07 11:18:12 +05:30
expect(::Gitlab::GitalyClient).to receive(:allow_ref_name_caching).and_call_original
2015-09-11 14:41:01 +05:30
get(:show,
2019-02-15 15:39:39 +05:30
params: {
namespace_id: project.namespace.to_param,
project_id: project,
id: id
})
2015-04-26 12:48:37 +05:30
end
2014-09-02 18:07:02 +05:30
context "valid branch, no path" do
let(:id) { 'master' }
2019-12-26 22:10:19 +05:30
2015-04-26 12:48:37 +05:30
it { is_expected.to respond_with(:success) }
2014-09-02 18:07:02 +05:30
end
context "valid branch, valid path" do
let(:id) { 'master/encoding/' }
2019-12-26 22:10:19 +05:30
2015-04-26 12:48:37 +05:30
it { is_expected.to respond_with(:success) }
2014-09-02 18:07:02 +05:30
end
context "valid branch, invalid path" do
let(:id) { 'master/invalid-path/' }
2019-12-26 22:10:19 +05:30
it 'redirects' do
expect(subject)
2020-03-13 15:44:24 +05:30
.to redirect_to("/#{project.full_path}/-/tree/master")
2019-12-26 22:10:19 +05:30
end
2014-09-02 18:07:02 +05:30
end
context "invalid branch, valid path" do
let(:id) { 'invalid-branch/encoding/' }
2019-12-26 22:10:19 +05:30
2015-04-26 12:48:37 +05:30
it { is_expected.to respond_with(:not_found) }
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
context "valid empty branch, invalid path" do
let(:id) { 'empty-branch/invalid-path/' }
2019-12-26 22:10:19 +05:30
it 'redirects' do
expect(subject)
2020-03-13 15:44:24 +05:30
.to redirect_to("/#{project.full_path}/-/tree/empty-branch")
2019-12-26 22:10:19 +05:30
end
2015-09-11 14:41:01 +05:30
end
context "valid empty branch" do
let(:id) { 'empty-branch' }
2019-12-26 22:10:19 +05:30
2015-09-11 14:41:01 +05:30
it { is_expected.to respond_with(:success) }
end
context "invalid SHA commit ID" do
let(:id) { 'ff39438/.gitignore' }
2019-12-26 22:10:19 +05:30
2015-09-11 14:41:01 +05:30
it { is_expected.to respond_with(:not_found) }
end
context "valid SHA commit ID" do
let(:id) { '6d39438' }
2019-12-26 22:10:19 +05:30
2015-09-11 14:41:01 +05:30
it { is_expected.to respond_with(:success) }
end
context "valid SHA commit ID with path" do
let(:id) { '6d39438/.gitignore' }
2019-12-26 22:10:19 +05:30
2020-03-13 15:44:24 +05:30
it { expect(response).to have_gitlab_http_status(:found) }
end
end
describe "GET show" do
context 'lfs_blob_ids instance variable' do
let(:id) { 'master' }
context 'with vue tree view enabled' do
before do
get(:show, params: { namespace_id: project.namespace.to_param, project_id: project, id: id })
end
it 'is not set' do
expect(assigns[:lfs_blob_ids]).to be_nil
end
end
context 'with vue tree view disabled' do
before do
stub_feature_flags(vue_file_list: false)
get(:show, params: { namespace_id: project.namespace.to_param, project_id: project, id: id })
end
it 'is set' do
expect(assigns[:lfs_blob_ids]).not_to be_nil
end
end
2015-09-11 14:41:01 +05:30
end
2014-09-02 18:07:02 +05:30
end
2019-07-31 22:56:46 +05:30
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-09-02 18:07:02 +05:30
describe 'GET show with blob path' do
render_views
before do
2015-09-11 14:41:01 +05:30
get(:show,
2019-02-15 15:39:39 +05:30
params: {
namespace_id: project.namespace.to_param,
project_id: project,
id: id
})
2014-09-02 18:07:02 +05:30
end
context 'redirect to blob' do
let(:id) { 'master/README.md' }
2019-12-26 22:10:19 +05:30
2015-04-26 12:48:37 +05:30
it 'redirects' do
2020-03-13 15:44:24 +05:30
redirect_url = "/#{project.full_path}/-/blob/master/README.md"
2017-09-10 17:25:29 +05:30
expect(subject)
.to redirect_to(redirect_url)
2015-04-26 12:48:37 +05:30
end
2014-09-02 18:07:02 +05:30
end
end
2015-10-24 18:46:33 +05:30
describe '#create_dir' do
render_views
before do
post(:create_dir,
2019-02-15 15:39:39 +05:30
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-10-24 18:46:33 +05:30
end
context 'successful creation' do
let(:path) { 'files/new_dir'}
2017-08-17 22:00:37 +05:30
let(:branch_name) { 'master-test'}
2015-10-24 18:46:33 +05:30
it 'redirects to the new directory' do
2017-09-10 17:25:29 +05:30
expect(subject)
2020-03-13 15:44:24 +05:30
.to redirect_to("/#{project.full_path}/-/tree/#{branch_name}/#{path}")
expect(flash[:notice]).to eq('The directory has been successfully created.')
2015-10-24 18:46:33 +05:30
end
end
context 'unsuccessful creation' do
let(:path) { 'README.md' }
2017-08-17 22:00:37 +05:30
let(:branch_name) { 'master'}
2015-10-24 18:46:33 +05:30
it 'does not allow overwriting of existing files' do
2017-09-10 17:25:29 +05:30
expect(subject)
2020-03-13 15:44:24 +05:30
.to redirect_to("/#{project.full_path}/-/tree/master")
2017-08-17 22:00:37 +05:30
expect(flash[:alert]).to eq('A file with this name already exists')
2015-10-24 18:46:33 +05:30
end
end
end
2014-09-02 18:07:02 +05:30
end