summaryrefslogtreecommitdiff
path: root/lib/tasks
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2022-06-07 09:09:00 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2022-06-07 09:09:00 +0000
commitbdd03bc52aee1c3f37e25ae9b1fc8a27885b7428 (patch)
treee409a6e1f76d9dc69c5413a06e9b4c4b3f74fef7 /lib/tasks
parentbed53d96d214fd96ea688d3e86e53457ce50043e (diff)
downloadgitlab-ce-bdd03bc52aee1c3f37e25ae9b1fc8a27885b7428.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/tasks')
-rw-r--r--lib/tasks/contracts.rake49
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/tasks/contracts.rake b/lib/tasks/contracts.rake
new file mode 100644
index 00000000000..75c350f5be5
--- /dev/null
+++ b/lib/tasks/contracts.rake
@@ -0,0 +1,49 @@
+# frozen_string_literal: true
+
+return if Rails.env.production?
+
+require 'pact/tasks/verification_task'
+
+contracts = File.expand_path('../../spec/contracts', __dir__)
+provider = File.expand_path('provider', contracts)
+
+# rubocop:disable Rails/RakeEnvironment
+namespace :contracts do
+ namespace :mr do
+ Pact::VerificationTask.new(:metadata) do |pact|
+ pact.uri(
+ "#{contracts}/contracts/merge_request_page-merge_request_metadata_endpoint.json",
+ pact_helper: "#{provider}/specs/metadata_helper.rb"
+ )
+ end
+
+ Pact::VerificationTask.new(:discussions) do |pact|
+ pact.uri(
+ "#{contracts}/contracts/merge_request_page-merge_request_discussions_endpoint.json",
+ pact_helper: "#{provider}/specs/discussions_helper.rb"
+ )
+ end
+
+ Pact::VerificationTask.new(:diffs) do |pact|
+ pact.uri(
+ "#{contracts}/contracts/merge_request_page-merge_request_diffs_endpoint.json",
+ pact_helper: "#{provider}/specs/diffs_helper.rb"
+ )
+ end
+
+ desc 'Run all merge request contract tests'
+ task 'test:merge_request', :contract_mr do |_t, arg|
+ raise(ArgumentError, 'Merge request contract tests require contract_mr to be set') unless arg[:contract_mr]
+
+ ENV['CONTRACT_MR'] = arg[:contract_mr]
+ errors = %w[metadata discussions diffs].each_with_object([]) do |task, err|
+ Rake::Task["contracts:mr:pact:verify:#{task}"].execute
+ rescue StandardError, SystemExit
+ err << "contracts:mr:pact:verify:#{task}"
+ end
+
+ raise StandardError, "Errors in tasks #{errors.join(', ')}" unless errors.empty?
+ end
+ end
+end
+# rubocop:enable Rails/RakeEnvironment