Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'tooling/danger/title_linting.rb')
-rw-r--r--tooling/danger/title_linting.rb38
1 files changed, 38 insertions, 0 deletions
diff --git a/tooling/danger/title_linting.rb b/tooling/danger/title_linting.rb
new file mode 100644
index 00000000000..dcd83df7d93
--- /dev/null
+++ b/tooling/danger/title_linting.rb
@@ -0,0 +1,38 @@
+# frozen_string_literal: true
+
+module Tooling
+ module Danger
+ module TitleLinting
+ DRAFT_REGEX = /\A*#{Regexp.union(/(?i)(\[WIP\]\s*|WIP:\s*|WIP$)/, /(?i)(\[draft\]|\(draft\)|draft:|draft\s\-\s|draft$)/)}+\s*/i.freeze
+ CHERRY_PICK_REGEX = /cherry[\s-]*pick/i.freeze
+ RUN_ALL_RSPEC_REGEX = /RUN ALL RSPEC/i.freeze
+ RUN_AS_IF_FOSS_REGEX = /RUN AS-IF-FOSS/i.freeze
+
+ module_function
+
+ def sanitize_mr_title(title)
+ remove_draft_flag(title).gsub(/`/, '\\\`')
+ end
+
+ def remove_draft_flag(title)
+ title.gsub(DRAFT_REGEX, '')
+ end
+
+ def has_draft_flag?(title)
+ DRAFT_REGEX.match?(title)
+ end
+
+ def has_cherry_pick_flag?(title)
+ CHERRY_PICK_REGEX.match?(title)
+ end
+
+ def has_run_all_rspec_flag?(title)
+ RUN_ALL_RSPEC_REGEX.match?(title)
+ end
+
+ def has_run_as_if_foss_flag?(title)
+ RUN_AS_IF_FOSS_REGEX.match?(title)
+ end
+ end
+ end
+end