blob: 38ca87fb5fd07ec769f3cb11923f4ebdca904134 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
# frozen_string_literal: true
SEE_DOC = "see the [SaaS feature documentation](https://docs.gitlab.com/ee/development/ee_features.html#saas-only-feature)."
SUGGEST_MR_COMMENT = <<~SUGGEST_COMMENT.freeze
```suggestion
group: "%<group>s"
```
#{SEE_DOC.capitalize}
SUGGEST_COMMENT
def check_yaml(saas_feature)
mr_group_label = helper.group_label
message_for_missing_group!(saas_feature: saas_feature, mr_group_label: mr_group_label) if saas_feature.group.nil?
rescue Psych::Exception
# YAML could not be parsed, fail the build.
fail "#{helper.html_link(saas_feature.path)} isn't valid YAML! #{SEE_DOC.capitalize}"
rescue StandardError => e
warn "There was a problem trying to check the SaaS feature file. Exception: #{e.class.name} - #{e.message}"
end
def message_for_missing_group!(saas_feature:, mr_group_label:)
mr_line = saas_feature.raw.lines.find_index do |line|
line.start_with?('group:')
end
if mr_line
markdown(format(SUGGEST_MR_COMMENT, group: mr_group_label), file: saas_feature.path, line: mr_line.succ)
elsif mr_group_label
warn %(
Consider setting `group: "#{mr_group_label}"` in #{helper.html_link(saas_feature.path)}. #{SEE_DOC.capitalize}
)
else
warn "Consider setting `group` in #{helper.html_link(saas_feature.path)}. #{SEE_DOC.capitalize}"
end
end
def message_for_group!(saas_feature:, mr_group_label:)
return if saas_feature.group_match_mr_label?(mr_group_label)
if mr_group_label
fail %(`group` is set to ~"#{saas_feature.group}" in #{helper.html_link(saas_feature.path)},
which does not match ~"#{mr_group_label}" set on the MR!)
end
helper.labels_to_add << saas_feature.group
end
def added_files
saas_feature.files(change_type: :added)
end
added_files.each do |saas_feature|
check_yaml(saas_feature)
end
|