Skip to content

Commit

Permalink
Allow forward merge to work with .x patterns
Browse files Browse the repository at this point in the history
  • Loading branch information
philwebb committed Jun 5, 2020
1 parent 4a6e08c commit 39caf45
Showing 1 changed file with 14 additions and 1 deletion.
15 changes: 14 additions & 1 deletion git/hooks/forward-merge
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def find_forward_merge(message_file)
message = File.read(message_file)
message.each_line do |line|
$log.debug "Checking #{line} for message"
match = /^(?:Fixes|Closes) gh-(\d+) in ([\d\.]+(?:(?:M|RC)\d)?)$/.match(line)
match = /^(?:Fixes|Closes) gh-(\d+) in (\d\.\d\.[\dx](?:[\.\-](?:M|RC)\d)?)$/.match(line)
if match then
issue = match[1]
milestone = match[2]
Expand Down Expand Up @@ -60,6 +60,19 @@ def find_milestone(username, password, repository, title)
request.basic_auth(username, password)
response = http.request(request)
milestones = JSON.parse(response.body)
if title.end_with?(".x")
prefix = title.delete_suffix('.x')
$log.debug "Finding latest milestone from candidates starting with #{prefix}"
titles = milestones.map { |milestone| milestone['title'] }
titles = titles.select{ |title| title.start_with?(prefix) unless title.end_with?('.x')}
titles.sort_by { |v| Gem::Version.new(v) }
if(titles.empty?)
puts "Cannot find latest for milestone #{title}"
exit 1
end
title = titles.last
$log.debug "Found latest milestone #{title}"
end
milestones.each do |milestone|
$log.debug "Considering #{milestone['title']}"
return milestone['number'] if milestone['title'] == title
Expand Down

0 comments on commit 39caf45

Please sign in to comment.