mirror of
https://gitlab.com/gitlab-org/gitlab-foss.git
synced 2025-08-16 15:57:22 +00:00
Add latest changes from gitlab-org/gitlab@master
This commit is contained in:
@ -42,23 +42,29 @@ OPTIONAL_REVIEW_TEMPLATE = "%{role} review is optional for %{category}".freeze
|
||||
NOT_AVAILABLE_TEMPLATE = 'No %{role} available'.freeze
|
||||
TIMEZONE_EXPERIMENT = true
|
||||
|
||||
def mr_author
|
||||
roulette.team.find { |person| person.username == gitlab.mr_author }
|
||||
def note_for_spins_role(spins, role)
|
||||
spins.each do |spin|
|
||||
note = note_for_spin_role(spin, role)
|
||||
|
||||
return note if note
|
||||
end
|
||||
|
||||
NOT_AVAILABLE_TEMPLATE % { role: role }
|
||||
end
|
||||
|
||||
def note_for_category_role(spin, role)
|
||||
def note_for_spin_role(spin, role)
|
||||
if spin.optional_role == role
|
||||
return OPTIONAL_REVIEW_TEMPLATE % { role: role.capitalize, category: helper.label_for_category(spin.category) }
|
||||
end
|
||||
|
||||
spin.public_send(role)&.markdown_name(timezone_experiment: TIMEZONE_EXPERIMENT, author: mr_author) || NOT_AVAILABLE_TEMPLATE % { role: role } # rubocop:disable GitlabSecurity/PublicSend
|
||||
spin.public_send(role)&.markdown_name(timezone_experiment: spin.timezone_experiment, author: roulette.team_mr_author) # rubocop:disable GitlabSecurity/PublicSend
|
||||
end
|
||||
|
||||
def markdown_row_for_spin(spin)
|
||||
reviewer_note = note_for_category_role(spin, :reviewer)
|
||||
maintainer_note = note_for_category_role(spin, :maintainer)
|
||||
def markdown_row_for_spins(category, spins_array)
|
||||
reviewer_note = note_for_spins_role(spins_array, :reviewer)
|
||||
maintainer_note = note_for_spins_role(spins_array, :maintainer)
|
||||
|
||||
"| #{helper.label_for_category(spin.category)} | #{reviewer_note} | #{maintainer_note} |"
|
||||
"| #{helper.label_for_category(category)} | #{reviewer_note} | #{maintainer_note} |"
|
||||
end
|
||||
|
||||
changes = helper.changes_by_category
|
||||
@ -70,26 +76,20 @@ changes.delete(:docs)
|
||||
categories = changes.keys - [:unknown]
|
||||
|
||||
# Ensure to spin for database reviewer/maintainer when ~database is applied (e.g. to review SQL queries)
|
||||
categories << :database if gitlab.mr_labels.include?('database') && !categories.include?(:database)
|
||||
categories << :database if helper.gitlab_helper&.mr_labels&.include?('database') && !categories.include?(:database)
|
||||
|
||||
if changes.any?
|
||||
project = helper.project_name
|
||||
branch_name = gitlab.mr_json['source_branch']
|
||||
|
||||
markdown(MESSAGE)
|
||||
timezone_roulette_spins = roulette.spin(project, categories, timezone_experiment: true)
|
||||
random_roulette_spins = roulette.spin(project, categories, timezone_experiment: false)
|
||||
|
||||
roulette_spins = roulette.spin(project, categories, branch_name, timezone_experiment: TIMEZONE_EXPERIMENT)
|
||||
rows = roulette_spins.map do |spin|
|
||||
# MR includes QA changes, but also other changes, and author isn't an SET
|
||||
if spin.category == :qa && categories.size > 1 && mr_author && !mr_author.reviewer?(project, spin.category, [])
|
||||
spin.optional_role = :maintainer
|
||||
end
|
||||
|
||||
spin.optional_role = :maintainer if spin.category == :test
|
||||
|
||||
markdown_row_for_spin(spin)
|
||||
rows = timezone_roulette_spins.map do |spin|
|
||||
fallback_spin = random_roulette_spins.find { |random_roulette_spins| random_roulette_spins.category == spin.category }
|
||||
markdown_row_for_spins(spin.category, [spin, fallback_spin])
|
||||
end
|
||||
|
||||
markdown(MESSAGE)
|
||||
markdown(CATEGORY_TABLE_HEADER + rows.join("\n")) unless rows.empty?
|
||||
|
||||
unknown = changes.fetch(:unknown, [])
|
||||
|
Reference in New Issue
Block a user