2019-02-05 12:16:18 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-04-08 06:44:57 -04:00
|
|
|
require 'digest/md5'
|
|
|
|
|
2019-02-05 12:16:18 -05:00
|
|
|
MESSAGE = <<MARKDOWN
|
|
|
|
## Reviewer roulette
|
|
|
|
|
|
|
|
Changes that require review have been detected! A merge request is normally
|
|
|
|
reviewed by both a reviewer and a maintainer in its primary category (e.g.
|
|
|
|
~frontend or ~backend), and by a maintainer in all other categories.
|
|
|
|
MARKDOWN
|
|
|
|
|
|
|
|
CATEGORY_TABLE_HEADER = <<MARKDOWN
|
|
|
|
|
|
|
|
To spread load more evenly across eligible reviewers, Danger has randomly picked
|
2020-04-22 11:09:27 -04:00
|
|
|
a candidate for each review slot. Feel free to
|
|
|
|
[override these selections](https://about.gitlab.com/handbook/engineering/projects/#gitlab)
|
|
|
|
if you think someone else would be better-suited, or the chosen person is unavailable.
|
2019-02-05 12:16:18 -05:00
|
|
|
|
2020-02-03 10:08:45 -05:00
|
|
|
To read more on how to use the reviewer roulette, please take a look at the
|
|
|
|
[Engineering workflow](https://about.gitlab.com/handbook/engineering/workflow/#basics)
|
|
|
|
and [code review guidelines](https://docs.gitlab.com/ee/development/code_review.html).
|
|
|
|
|
2019-02-05 12:16:18 -05:00
|
|
|
Once you've decided who will review this merge request, mention them as you
|
|
|
|
normally would! Danger does not (yet?) automatically notify them for you.
|
|
|
|
|
|
|
|
| Category | Reviewer | Maintainer |
|
|
|
|
| -------- | -------- | ---------- |
|
|
|
|
MARKDOWN
|
|
|
|
|
|
|
|
UNKNOWN_FILES_MESSAGE = <<MARKDOWN
|
|
|
|
|
|
|
|
These files couldn't be categorised, so Danger was unable to suggest a reviewer.
|
|
|
|
Please consider creating a merge request to
|
2019-11-27 07:06:30 -05:00
|
|
|
[add support](https://gitlab.com/gitlab-org/gitlab/blob/master/lib/gitlab/danger/helper.rb)
|
2019-02-05 12:16:18 -05:00
|
|
|
for them.
|
|
|
|
MARKDOWN
|
|
|
|
|
2020-06-15 08:08:44 -04:00
|
|
|
OPTIONAL_REVIEW_TEMPLATE = "%{role} review is optional for %{category}".freeze
|
|
|
|
NOT_AVAILABLE_TEMPLATE = 'No %{role} available'.freeze
|
2019-05-30 06:50:40 -04:00
|
|
|
|
2020-07-06 14:09:13 -04:00
|
|
|
def mr_author
|
|
|
|
roulette.team.find { |person| person.username == gitlab.mr_author }
|
|
|
|
end
|
|
|
|
|
2020-06-15 08:08:44 -04:00
|
|
|
def note_for_category_role(spin, role)
|
|
|
|
if spin.optional_role == role
|
|
|
|
return OPTIONAL_REVIEW_TEMPLATE % { role: role.capitalize, category: helper.label_for_category(spin.category) }
|
2020-04-02 23:07:58 -04:00
|
|
|
end
|
2019-02-05 12:16:18 -05:00
|
|
|
|
2020-06-15 08:08:44 -04:00
|
|
|
spin.public_send(role)&.markdown_name || NOT_AVAILABLE_TEMPLATE % { role: role } # rubocop:disable GitlabSecurity/PublicSend
|
2020-04-02 23:07:58 -04:00
|
|
|
end
|
|
|
|
|
2020-06-15 08:08:44 -04:00
|
|
|
def markdown_row_for_spin(spin)
|
|
|
|
reviewer_note = note_for_category_role(spin, :reviewer)
|
|
|
|
maintainer_note = note_for_category_role(spin, :maintainer)
|
|
|
|
|
|
|
|
"| #{helper.label_for_category(spin.category)} | #{reviewer_note} | #{maintainer_note} |"
|
2019-02-05 12:16:18 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
changes = helper.changes_by_category
|
2019-02-14 11:45:53 -05:00
|
|
|
|
2019-04-25 20:23:30 -04:00
|
|
|
# Ignore any files that are known but uncategorized. Prompt for any unknown files
|
2019-02-14 11:45:53 -05:00
|
|
|
changes.delete(:none)
|
2019-02-05 12:16:18 -05:00
|
|
|
categories = changes.keys - [:unknown]
|
|
|
|
|
2019-07-19 13:33:48 -04:00
|
|
|
# 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)
|
|
|
|
|
2020-05-07 05:09:51 -04:00
|
|
|
if changes.any?
|
2019-02-05 12:16:18 -05:00
|
|
|
project = helper.project_name
|
2020-06-15 08:08:44 -04:00
|
|
|
branch_name = gitlab.mr_json['source_branch']
|
2020-04-02 23:07:58 -04:00
|
|
|
|
2020-06-15 08:08:44 -04:00
|
|
|
roulette_spins = roulette.spin(project, categories, branch_name)
|
2020-07-06 14:09:13 -04:00
|
|
|
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.reviewer?(project, spin.category, [])
|
|
|
|
spin.optional_role = :maintainer
|
|
|
|
end
|
|
|
|
|
|
|
|
spin.optional_role = :maintainer if spin.category == :test
|
|
|
|
|
|
|
|
markdown_row_for_spin(spin)
|
|
|
|
end
|
2020-06-15 08:08:44 -04:00
|
|
|
|
|
|
|
unknown = changes.fetch(:unknown, [])
|
2019-02-05 12:16:18 -05:00
|
|
|
|
|
|
|
markdown(MESSAGE)
|
|
|
|
markdown(CATEGORY_TABLE_HEADER + rows.join("\n")) unless rows.empty?
|
2019-07-19 13:33:48 -04:00
|
|
|
markdown(UNKNOWN_FILES_MESSAGE + helper.markdown_list(unknown)) unless unknown.empty?
|
2019-02-05 12:16:18 -05:00
|
|
|
end
|