mirror of
https://gitlab.com/gitlab-org/gitlab-foss.git
synced 2025-08-20 14:11:11 +00:00
Extract the longest-matching ref from a commit path when multiple matches occur
Closes #1839
This commit is contained in:
@ -10,6 +10,7 @@ v 7.13.0 (unreleased)
|
|||||||
- Fix downloading of patches on public merge requests when user logged out (Stan Hu)
|
- Fix downloading of patches on public merge requests when user logged out (Stan Hu)
|
||||||
- The password for the default administrator (root) account has been changed from "5iveL!fe" to "password".
|
- The password for the default administrator (root) account has been changed from "5iveL!fe" to "password".
|
||||||
- Fix Error 500 when relative submodule resolves to a namespace that has a different name from its path (Stan Hu)
|
- Fix Error 500 when relative submodule resolves to a namespace that has a different name from its path (Stan Hu)
|
||||||
|
- Extract the longest-matching ref from a commit path when multiple matches occur (Stan Hu)
|
||||||
- Update maintenance documentation to explain no need to recompile asssets for omnibus installations (Stan Hu)
|
- Update maintenance documentation to explain no need to recompile asssets for omnibus installations (Stan Hu)
|
||||||
- Support commenting on diffs in side-by-side mode (Stan Hu)
|
- Support commenting on diffs in side-by-side mode (Stan Hu)
|
||||||
- Fix JavaScript error when clicking on the comment button on a diff line that has a comment already (Stan Hu)
|
- Fix JavaScript error when clicking on the comment button on a diff line that has a comment already (Stan Hu)
|
||||||
|
@ -55,12 +55,16 @@ module ExtractsPath
|
|||||||
valid_refs = @project.repository.ref_names
|
valid_refs = @project.repository.ref_names
|
||||||
valid_refs.select! { |v| id.start_with?("#{v}/") }
|
valid_refs.select! { |v| id.start_with?("#{v}/") }
|
||||||
|
|
||||||
if valid_refs.length != 1
|
if valid_refs.length == 0
|
||||||
# No exact ref match, so just try our best
|
# No exact ref match, so just try our best
|
||||||
pair = id.match(/([^\/]+)(.*)/).captures
|
pair = id.match(/([^\/]+)(.*)/).captures
|
||||||
else
|
else
|
||||||
|
# There is a distinct possibility that multiple refs prefix the ID.
|
||||||
|
# Use the longest match to maximize the chance that we have the
|
||||||
|
# right ref.
|
||||||
|
best_match = valid_refs.max_by(&:length)
|
||||||
# Partition the string into the ref and the path, ignoring the empty first value
|
# Partition the string into the ref and the path, ignoring the empty first value
|
||||||
pair = id.partition(valid_refs.first)[1..-1]
|
pair = id.partition(best_match)[1..-1]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -10,7 +10,8 @@ describe ExtractsPath do
|
|||||||
before do
|
before do
|
||||||
@project = project
|
@project = project
|
||||||
|
|
||||||
repo = double(ref_names: ['master', 'foo/bar/baz', 'v1.0.0', 'v2.0.0'])
|
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(:repository).and_return(repo)
|
||||||
allow(project).to receive(:path_with_namespace).
|
allow(project).to receive(:path_with_namespace).
|
||||||
and_return('gitlab/gitlab-ci')
|
and_return('gitlab/gitlab-ci')
|
||||||
@ -54,11 +55,17 @@ describe ExtractsPath do
|
|||||||
it "falls back to a primitive split for an invalid ref" do
|
it "falls back to a primitive split for an invalid ref" do
|
||||||
expect(extract_ref('stable')).to eq(['stable', ''])
|
expect(extract_ref('stable')).to eq(['stable', ''])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
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
|
||||||
end
|
end
|
||||||
|
|
||||||
context "with a path" do
|
context "with a path" do
|
||||||
it "extracts a valid branch" do
|
it "extracts a valid branch" do
|
||||||
expect(extract_ref('foo/bar/baz/CHANGELOG')).to eq(['foo/bar/baz', 'CHANGELOG'])
|
expect(extract_ref('foo/bar/baz/CHANGELOG')).to eq(
|
||||||
|
['foo/bar/baz', 'CHANGELOG'])
|
||||||
end
|
end
|
||||||
|
|
||||||
it "extracts a valid tag" do
|
it "extracts a valid tag" do
|
||||||
|
Reference in New Issue
Block a user