debian-mirror-gitlab/spec/lib/extracts_path_spec.rb

97 lines
2.8 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
require 'spec_helper'
describe ExtractsPath do
include ExtractsPath
2015-09-11 14:41:01 +05:30
include RepoHelpers
2015-09-25 12:07:36 +05:30
include Gitlab::Application.routes.url_helpers
2014-09-02 18:07:02 +05:30
let(:project) { double('project') }
before do
@project = project
2015-09-11 14:41:01 +05:30
repo = double(ref_names: ['master', 'foo/bar/baz', 'v1.0.0', 'v2.0.0',
'release/app', 'release/app/v1.0.0'])
allow(project).to receive(:repository).and_return(repo)
allow(project).to receive(:path_with_namespace).
and_return('gitlab/gitlab-ci')
end
describe '#assign_ref' do
let(:ref) { sample_commit[:id] }
let(:params) { { path: sample_commit[:line_code_path], ref: ref } }
before do
@project = create(:project)
end
it "log tree path should have no escape sequences" do
assign_ref_vars
expect(@logs_path).to eq("/#{@project.path_with_namespace}/refs/#{ref}/logs_tree/files/ruby/popen.rb")
end
context 'escaped sequences in ref' do
let(:ref) { "improve%2Fawesome" }
it "id should have no escape sequences" do
assign_ref_vars
expect(@ref).to eq('improve/awesome')
expect(@logs_path).to eq("/#{@project.path_with_namespace}/refs/#{ref}/logs_tree/files/ruby/popen.rb")
end
end
2014-09-02 18:07:02 +05:30
end
describe '#extract_ref' do
it "returns an empty pair when no @project is set" do
@project = nil
2015-04-26 12:48:37 +05:30
expect(extract_ref('master/CHANGELOG')).to eq(['', ''])
2014-09-02 18:07:02 +05:30
end
context "without a path" do
it "extracts a valid branch" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('master')).to eq(['master', ''])
2014-09-02 18:07:02 +05:30
end
it "extracts a valid tag" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('v2.0.0')).to eq(['v2.0.0', ''])
2014-09-02 18:07:02 +05:30
end
it "extracts a valid commit ref without a path" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('f4b14494ef6abf3d144c28e4af0c20143383e062')).to eq(
2014-09-02 18:07:02 +05:30
['f4b14494ef6abf3d144c28e4af0c20143383e062', '']
2015-04-26 12:48:37 +05:30
)
2014-09-02 18:07:02 +05:30
end
it "falls back to a primitive split for an invalid ref" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('stable')).to eq(['stable', ''])
2014-09-02 18:07:02 +05:30
end
2015-09-11 14:41:01 +05:30
it "extracts the longest matching ref" do
expect(extract_ref('release/app/v1.0.0/README.md')).to eq(
['release/app/v1.0.0', 'README.md'])
end
2014-09-02 18:07:02 +05:30
end
context "with a path" do
it "extracts a valid branch" do
2015-09-11 14:41:01 +05:30
expect(extract_ref('foo/bar/baz/CHANGELOG')).to eq(
['foo/bar/baz', 'CHANGELOG'])
2014-09-02 18:07:02 +05:30
end
it "extracts a valid tag" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('v2.0.0/CHANGELOG')).to eq(['v2.0.0', 'CHANGELOG'])
2014-09-02 18:07:02 +05:30
end
it "extracts a valid commit SHA" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('f4b14494ef6abf3d144c28e4af0c20143383e062/CHANGELOG')).to eq(
2014-09-02 18:07:02 +05:30
['f4b14494ef6abf3d144c28e4af0c20143383e062', 'CHANGELOG']
2015-04-26 12:48:37 +05:30
)
2014-09-02 18:07:02 +05:30
end
it "falls back to a primitive split for an invalid ref" do
2015-04-26 12:48:37 +05:30
expect(extract_ref('stable/CHANGELOG')).to eq(['stable', 'CHANGELOG'])
2014-09-02 18:07:02 +05:30
end
end
end
end