diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-06-07 09:09:00 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-06-07 09:09:00 +0000 |
commit | bdd03bc52aee1c3f37e25ae9b1fc8a27885b7428 (patch) | |
tree | e409a6e1f76d9dc69c5413a06e9b4c4b3f74fef7 /lib/tasks | |
parent | bed53d96d214fd96ea688d3e86e53457ce50043e (diff) | |
download | gitlab-ce-bdd03bc52aee1c3f37e25ae9b1fc8a27885b7428.tar.gz |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/tasks')
-rw-r--r-- | lib/tasks/contracts.rake | 49 |
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 |