pact_broker 2.89.1 → 2.93.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +58 -0
- data/db/ddl_statements/all_verifications.rb +21 -0
- data/db/migrations/20210608_add_uuid_to_webhook.rb +1 -0
- data/db/migrations/20210701_recreate_all_verifications.rb +18 -0
- data/db/migrations/20211101_recreate_all_verifications.rb +10 -0
- data/db/migrations/20211102_create_table_temp_integrations.rb +26 -0
- data/db/migrations/20211103_migrate_integrations.rb +21 -0
- data/db/migrations/20211104_switch_integrations_and_temp_integrations.rb +25 -0
- data/db/migrations/20211120_create_pact_version_provider_tag_successful_verifications.rb +23 -0
- data/db/migrations/20211121_migrate_pact_version_provider_tag_successful_verifications_data.rb +11 -0
- data/docs/CONFIGURATION.md +30 -0
- data/lib/pact_broker/api/decorators/embedded_environment_decorator.rb +25 -0
- data/lib/pact_broker/api/decorators/matrix_decorator.rb +17 -2
- data/lib/pact_broker/api/decorators/version_decorator.rb +2 -0
- data/lib/pact_broker/api/renderers/html_pact_renderer.rb +4 -0
- data/lib/pact_broker/api/resources/deployed_versions_for_version_and_environment.rb +2 -2
- data/lib/pact_broker/api/resources/released_versions_for_version_and_environment.rb +5 -1
- data/lib/pact_broker/api/resources/verifications.rb +1 -1
- data/lib/pact_broker/app.rb +1 -1
- data/lib/pact_broker/certificates/service.rb +32 -2
- data/lib/pact_broker/config/runtime_configuration.rb +9 -0
- data/lib/pact_broker/config/runtime_configuration_database_methods.rb +6 -0
- data/lib/pact_broker/config/runtime_configuration_logging_methods.rb +6 -2
- data/lib/pact_broker/db/clean_incremental.rb +26 -9
- data/lib/pact_broker/db/data_migrations/migrate_integrations.rb +40 -0
- data/lib/pact_broker/db/data_migrations/migrate_pact_version_provider_tag_successful_verifications.rb +38 -0
- data/lib/pact_broker/db/migrate_data.rb +2 -0
- data/lib/pact_broker/deployments/deployed_version.rb +9 -1
- data/lib/pact_broker/doc/views/webhooks.markdown +23 -0
- data/lib/pact_broker/domain/pacticipant.rb +38 -6
- data/lib/pact_broker/initializers/database_connection.rb +6 -4
- data/lib/pact_broker/integrations/integration.rb +34 -10
- data/lib/pact_broker/integrations/repository.rb +22 -0
- data/lib/pact_broker/integrations/service.rb +2 -2
- data/lib/pact_broker/locale/en.yml +1 -2
- data/lib/pact_broker/matrix/quick_row.rb +16 -0
- data/lib/pact_broker/pacticipants/repository.rb +5 -0
- data/lib/pact_broker/pacticipants/service.rb +1 -1
- data/lib/pact_broker/pacts/merger.rb +8 -4
- data/lib/pact_broker/pacts/pact_publication_dataset_module.rb +52 -59
- data/lib/pact_broker/pacts/pact_publication_wip_dataset_module.rb +37 -4
- data/lib/pact_broker/pacts/pacts_for_verification_repository.rb +2 -2
- data/lib/pact_broker/pacts/repository.rb +1 -0
- data/lib/pact_broker/repositories.rb +5 -0
- data/lib/pact_broker/tasks/clean_task.rb +11 -0
- data/lib/pact_broker/test/http_test_data_builder.rb +1 -0
- data/lib/pact_broker/test/test_data_builder.rb +42 -9
- data/lib/pact_broker/ui/views/index/_css_and_js.haml +1 -0
- data/lib/pact_broker/ui/views/layouts/main.haml +4 -0
- data/lib/pact_broker/ui/views/matrix/show.haml +1 -0
- data/lib/pact_broker/verifications/pact_version_provider_tag_successful_verification.rb +11 -0
- data/lib/pact_broker/verifications/repository.rb +16 -0
- data/lib/pact_broker/version.rb +1 -1
- data/lib/pact_broker/webhooks/pact_and_verification_parameters.rb +1 -2
- data/pact_broker.gemspec +8 -1
- data/public/css/bootstrap-grid.css +170 -17
- data/public/css/bootstrap-grid.css.map +1 -1
- data/public/css/bootstrap-grid.min.css +5 -5
- data/public/css/bootstrap-grid.min.css.map +1 -1
- data/public/css/bootstrap-reboot.css +16 -22
- data/public/css/bootstrap-reboot.css.map +1 -1
- data/public/css/bootstrap-reboot.min.css +5 -5
- data/public/css/bootstrap-reboot.min.css.map +1 -1
- data/public/css/bootstrap.css +585 -308
- data/public/css/bootstrap.css.map +1 -1
- data/public/css/bootstrap.min.css +5 -5
- data/public/css/bootstrap.min.css.map +1 -1
- data/public/images/question.svg +1 -0
- data/public/javascripts/set-css-asset-base-url.js +23 -0
- data/public/js/bootstrap.bundle.js +1294 -1335
- data/public/js/bootstrap.bundle.js.map +1 -1
- data/public/js/bootstrap.bundle.min.js +4 -4
- data/public/js/bootstrap.bundle.min.js.map +1 -1
- data/public/js/bootstrap.js +1232 -1310
- data/public/js/bootstrap.js.map +1 -1
- data/public/js/bootstrap.min.js +4 -4
- data/public/js/bootstrap.min.js.map +1 -1
- data/public/stylesheets/index.css +14 -5
- data/public/stylesheets/matrix.css +6 -1
- data/public/stylesheets/pact.css +6 -1
- metadata +19 -1068
- data/.codeclimate.yml +0 -49
- data/.csslintrc +0 -2
- data/.dockerignore +0 -2
- data/.eslintignore +0 -1
- data/.eslintrc.yml +0 -277
- data/.github/FUNDING.yml +0 -4
- data/.github/ISSUE_TEMPLATE.md +0 -32
- data/.github/PULL_REQUEST_TEMPLATE.md +0 -9
- data/.github/workflows/release_gem.yml +0 -52
- data/.github/workflows/test-ruby-3.yml +0 -19
- data/.github/workflows/test.yml +0 -95
- data/.github/workflows/trigger_pact_docs_update.yml +0 -23
- data/.gitignore +0 -45
- data/.optic/.gitignore +0 -2
- data/.optic/api/specification.json +0 -1
- data/.optic/ignore +0 -14
- data/.rspec +0 -3
- data/.rubocop.yml +0 -314
- data/.ruby-version +0 -1
- data/CODE_OF_CONDUCT.md +0 -76
- data/CONTRIBUTING.md +0 -29
- data/DEVELOPER_DOCUMENTATION.md +0 -161
- data/DEVELOPER_SETUP.md +0 -165
- data/Dockerfile +0 -52
- data/ISSUES.md +0 -31
- data/LICENSE.txt +0 -22
- data/MATRIX.md +0 -4
- data/RELEASING.md +0 -5
- data/Rakefile +0 -23
- data/UPGRADING.md +0 -18
- data/config/boot.rb +0 -21
- data/config/database.travis.yml +0 -13
- data/config/database.yml +0 -79
- data/config.ru +0 -11
- data/db/test/backwards_compatibility/.rspec +0 -3
- data/db/test/backwards_compatibility/Appraisals +0 -57
- data/db/test/backwards_compatibility/Gemfile +0 -12
- data/db/test/backwards_compatibility/Rakefile +0 -72
- data/db/test/backwards_compatibility/config.ru +0 -21
- data/db/test/backwards_compatibility/gemfiles/1.18.0.gemfile +0 -15
- data/db/test/backwards_compatibility/gemfiles/1.18.0.gemfile.lock +0 -212
- data/db/test/backwards_compatibility/gemfiles/2.0.0.gemfile +0 -15
- data/db/test/backwards_compatibility/gemfiles/2.0.0.gemfile.lock +0 -210
- data/db/test/backwards_compatibility/gemfiles/2.1.0.gemfile +0 -15
- data/db/test/backwards_compatibility/gemfiles/2.1.0.gemfile.lock +0 -211
- data/db/test/backwards_compatibility/gemfiles/2.2.0.gemfile +0 -15
- data/db/test/backwards_compatibility/gemfiles/2.2.0.gemfile.lock +0 -199
- data/db/test/backwards_compatibility/gemfiles/2.3.0.gemfile +0 -14
- data/db/test/backwards_compatibility/gemfiles/2.3.0.gemfile.lock +0 -198
- data/db/test/backwards_compatibility/gemfiles/2.4.2.gemfile +0 -14
- data/db/test/backwards_compatibility/gemfiles/2.4.2.gemfile.lock +0 -198
- data/db/test/backwards_compatibility/gemfiles/2.5.1.gemfile +0 -14
- data/db/test/backwards_compatibility/gemfiles/2.5.1.gemfile.lock +0 -198
- data/db/test/backwards_compatibility/gemfiles/2.6.0.gemfile +0 -14
- data/db/test/backwards_compatibility/gemfiles/2.6.0.gemfile.lock +0 -198
- data/db/test/backwards_compatibility/gemfiles/head.gemfile +0 -14
- data/db/test/backwards_compatibility/gemfiles/head.gemfile.lock +0 -182
- data/db/test/backwards_compatibility/spec/fixtures/foo-bar.json +0 -22
- data/db/test/backwards_compatibility/spec/publish_pact_spec.rb +0 -72
- data/db/test/backwards_compatibility/spec/spec_helper.rb +0 -20
- data/db/test/backwards_compatibility/spec/support/fixture_helpers.rb +0 -12
- data/db/test/backwards_compatibility/spec/support/request_helpers.rb +0 -19
- data/db/test/change_migration_strategy/Rakefile +0 -21
- data/db/test/change_migration_strategy/before/Gemfile +0 -7
- data/docker-compose-ci-mysql.yml +0 -38
- data/docker-compose-dev-postgres.yml +0 -43
- data/docker-compose-issue-repro-with-pact-broker-docker-image.yml +0 -44
- data/docker-compose-test.yml +0 -102
- data/docs/configuration.yml +0 -385
- data/docs/images/Pactflow logo - black small.png +0 -0
- data/example/Gemfile +0 -6
- data/example/README.md +0 -64
- data/example/config/pact_broker.yml +0 -9
- data/example/config/puma.rb +0 -3
- data/example/config.ru +0 -10
- data/issue-reproduction/Dockerfile-pact-broker +0 -42
- data/lib/pact_broker/versions/latest_version.rb +0 -21
- data/optic.yml +0 -5
- data/pact_broker_client-pact_broker.json +0 -133
- data/public/js/npm.js +0 -13
- data/regression/.gitignore +0 -1
- data/regression/can_i_deploy_spec.rb +0 -43
- data/regression/index_spec.rb +0 -26
- data/regression/regression_helper.rb +0 -63
- data/regression/script/approval-all.sh +0 -6
- data/regression/script/clear.sh +0 -3
- data/regression/script/run.sh +0 -3
- data/scaffolding/README.md +0 -23
- data/scaffolding/run.rb +0 -242
- data/scaffolding/templates/decorator.rb.erb +0 -15
- data/scaffolding/templates/decorator_spec.erb.rb +0 -0
- data/scaffolding/templates/migration.erb +0 -12
- data/scaffolding/templates/model.erb +0 -14
- data/scaffolding/templates/repository.rb.erb +0 -18
- data/scaffolding/templates/repository_spec.rb.erb +0 -9
- data/scaffolding/templates/resource.erb +0 -46
- data/scaffolding/templates/resource_spec.rb.erb +0 -78
- data/scaffolding/templates/service.rb.erb +0 -22
- data/scaffolding/templates/service_spec.rb.erb +0 -9
- data/script/data/auto-create-things-for-tags.rb +0 -22
- data/script/data/branches.rb +0 -35
- data/script/data/contract-published-requiring-verification.rb +0 -26
- data/script/data/environments.rb +0 -45
- data/script/data/expand-currently-deployed.rb +0 -47
- data/script/data/issue-494.rb +0 -25
- data/script/data/pending.rb +0 -26
- data/script/data/tags.rb +0 -35
- data/script/data/verify-pact-for-multiple-selectors.rb +0 -30
- data/script/data/webhook.rb +0 -22
- data/script/db-spec.sh +0 -16
- data/script/demonstrate-version-branches.rb +0 -33
- data/script/dev/rubocop-modified-files.sh +0 -3
- data/script/dev/webhook-server-with-random-errors.sh +0 -25
- data/script/docker/db-execute-sql-file.sh +0 -2
- data/script/docker/db-psql.sh +0 -3
- data/script/docker/db-reload.sh +0 -11
- data/script/docker/db-restore.sh +0 -5
- data/script/docker/db-rm.sh +0 -3
- data/script/docker/db-start.sh +0 -7
- data/script/docker/mysql-db-start.sh +0 -10
- data/script/docker-container/test.sh +0 -3
- data/script/docs/generate-api-docs.rb +0 -117
- data/script/docs/generate-configuration-docs.rb +0 -107
- data/script/docs/regenerate-api-docs.sh +0 -11
- data/script/exercise-api-for-optic.sh +0 -3
- data/script/foo-bar-verification.json +0 -59
- data/script/foo-bar.json +0 -33
- data/script/generate-certificates-for-webooks-certificate-spec.rb +0 -49
- data/script/generate-erd +0 -55
- data/script/github-issues/add-branch-support/issue-text.txt +0 -7
- data/script/github-issues/add-branch-support/issues.txt +0 -0
- data/script/github-issues/add-branch-support/raise-issue-in-client-repos.sh +0 -10
- data/script/github-issues/add-branch-support-for-provider-versions/issue-text.txt +0 -9
- data/script/github-issues/add-branch-support-for-provider-versions/issues.txt +0 -6
- data/script/github-issues/add-branch-support-for-provider-versions/raise-issue-in-client-repos.sh +0 -10
- data/script/github-issues/branch-consumer-version-selector/issue-text.txt +0 -52
- data/script/github-issues/branch-consumer-version-selector/issues.txt +0 -9
- data/script/github-issues/branch-consumer-version-selector/raise-issue-in-client-repos.sh +0 -10
- data/script/github-issues/consumer-version-selectors-docs/issue-text.txt +0 -11
- data/script/github-issues/consumer-version-selectors-docs/issues.txt +0 -6
- data/script/github-issues/consumer-version-selectors-docs/raise-issue-in-client-repos.sh +0 -10
- data/script/github-issues/deployed-and-released-selectors-docs/issue-text.txt +0 -26
- data/script/github-issues/deployed-and-released-selectors-docs/issues.txt +0 -9
- data/script/github-issues/deployed-and-released-selectors-docs/raise-issue-in-client-repos.sh +0 -10
- data/script/github-issues/include-pending-by-default/issue-text.txt +0 -5
- data/script/github-issues/include-pending-by-default/issues.txt +0 -10
- data/script/github-issues/include-pending-by-default/raise-issue-in-client-repos.sh +0 -10
- data/script/import-pg-database.sh +0 -5
- data/script/insert-self-signed-certificate-from-url.rb +0 -35
- data/script/prod/clean-up.sql +0 -11
- data/script/prod/migrate-latest-pacts.sh +0 -29
- data/script/prod/redact-data.sql +0 -16
- data/script/pry.rb +0 -31
- data/script/publish-2.sh +0 -4
- data/script/publish-new.sh +0 -31
- data/script/publish-not-a-pact.sh +0 -4
- data/script/publish-verification.sh +0 -5
- data/script/publish.sh +0 -28
- data/script/query.rb +0 -20
- data/script/recreate-docker-pg-db.sh +0 -20
- data/script/recreate-mysql-db.sh +0 -18
- data/script/recreate-pg-db.sh +0 -16
- data/script/recreate-test-database.sh +0 -2
- data/script/release-via-github-action.sh +0 -7
- data/script/release.sh +0 -11
- data/script/reproduce-issue-can-i-deploy-ignore.rb +0 -48
- data/script/reproduce-issue-starting-up.rb +0 -38
- data/script/reproduce-issue.rb +0 -37
- data/script/restart.sh +0 -18
- data/script/run-with-ssl.rb +0 -44
- data/script/seed-example-matrix.rb +0 -105
- data/script/seed-for-webhook-test.rb +0 -59
- data/script/seed-matrix.rb +0 -90
- data/script/seed.rb +0 -101
- data/script/test/approval-all.sh +0 -6
- data/script/test/run-rake-on-docker-compose-mysql.sh +0 -8
- data/script/trigger-release.sh +0 -30
- data/script/update-hal-browser +0 -6
- data/script/watch.sh +0 -7
- data/script/webhook-server.ru +0 -10
- data/spec/features/base_equality_only_on_content_that_affects_verification_results_spec.rb +0 -34
- data/spec/features/can_i_deploy_spec.rb +0 -31
- data/spec/features/create_branch_version_spec.rb +0 -29
- data/spec/features/create_environment_spec.rb +0 -47
- data/spec/features/create_pacticipant_spec.rb +0 -36
- data/spec/features/create_tag_spec.rb +0 -42
- data/spec/features/create_version_spec.rb +0 -56
- data/spec/features/create_webhook_spec.rb +0 -189
- data/spec/features/delete_environment_spec.rb +0 -16
- data/spec/features/delete_integration_spec.rb +0 -27
- data/spec/features/delete_label_spec.rb +0 -28
- data/spec/features/delete_pact_spec.rb +0 -31
- data/spec/features/delete_pact_versions_for_branch_spec.rb +0 -34
- data/spec/features/delete_pact_versions_spec.rb +0 -29
- data/spec/features/delete_tagged_pact_versions_spec.rb +0 -28
- data/spec/features/delete_verification_spec.rb +0 -27
- data/spec/features/delete_version_spec.rb +0 -22
- data/spec/features/delete_webhook_spec.rb +0 -34
- data/spec/features/edit_webhook_spec.rb +0 -61
- data/spec/features/end_deployment_spec.rb +0 -29
- data/spec/features/end_support_spec.rb +0 -67
- data/spec/features/execute_unsaved_webhook_spec.rb +0 -53
- data/spec/features/execute_webhook_spec.rb +0 -92
- data/spec/features/get_branch_version_spec.rb +0 -12
- data/spec/features/get_can_i_deploy_badge_spec.rb +0 -13
- data/spec/features/get_currently_deployed_versions_for_environment_spec.rb +0 -76
- data/spec/features/get_currently_deployed_versions_for_version_spec.rb +0 -27
- data/spec/features/get_currently_supported_versions_for_environment_spec.rb +0 -57
- data/spec/features/get_dashboard_spec.rb +0 -29
- data/spec/features/get_deployed_versions_for_version_and_environment.rb +0 -27
- data/spec/features/get_diff_spec.rb +0 -53
- data/spec/features/get_environment_spec.rb +0 -19
- data/spec/features/get_environments_spec.rb +0 -30
- data/spec/features/get_integrations_dot_file_spec.rb +0 -23
- data/spec/features/get_integrations_spec.rb +0 -17
- data/spec/features/get_label_spec.rb +0 -28
- data/spec/features/get_latest_pact_badge_spec.rb +0 -54
- data/spec/features/get_latest_tagged_pact_badge_spec.rb +0 -38
- data/spec/features/get_latest_tagged_pact_spec.rb +0 -22
- data/spec/features/get_latest_untagged_pact_badge_spec.rb +0 -38
- data/spec/features/get_latest_untagged_pact_spec.rb +0 -22
- data/spec/features/get_latest_verification_for_pact_spec.rb +0 -59
- data/spec/features/get_matrix_badge_spec.rb +0 -50
- data/spec/features/get_matrix_for_consumer_and_provider_spec.rb +0 -22
- data/spec/features/get_matrix_spec.rb +0 -34
- data/spec/features/get_pact_spec.rb +0 -65
- data/spec/features/get_pact_version.rb +0 -36
- data/spec/features/get_pact_versions_spec.rb +0 -34
- data/spec/features/get_pacticipants_by_label_spec.rb +0 -27
- data/spec/features/get_previous_distinct_version.rb +0 -51
- data/spec/features/get_provider_pacts_for_verification_spec.rb +0 -95
- data/spec/features/get_provider_pacts_spec.rb +0 -93
- data/spec/features/get_released_versions_for_version_and_environment.rb +0 -27
- data/spec/features/get_tagged_pact_versions_spec.rb +0 -26
- data/spec/features/get_triggered_webhooks_for_pact_spec.rb +0 -20
- data/spec/features/get_triggered_webhooks_for_verification_spec.rb +0 -21
- data/spec/features/get_verifications_for_consumer_version_spec.rb +0 -33
- data/spec/features/get_version_spec.rb +0 -44
- data/spec/features/get_versions_spec.rb +0 -39
- data/spec/features/label_pacticipant_spec.rb +0 -22
- data/spec/features/merge_pact_spec.rb +0 -63
- data/spec/features/metadata_spec.rb +0 -66
- data/spec/features/metrics_spec.rb +0 -23
- data/spec/features/pending_pacts_spec.rb +0 -109
- data/spec/features/pending_pacts_with_tags_spec.rb +0 -138
- data/spec/features/publish_not_a_pact_spec.rb +0 -37
- data/spec/features/publish_pact_all_in_one_approval_spec.rb +0 -72
- data/spec/features/publish_pact_all_in_one_spec.rb +0 -61
- data/spec/features/publish_pact_spec.rb +0 -124
- data/spec/features/publish_verification_results_and_version_spec.rb +0 -70
- data/spec/features/publish_verification_spec.rb +0 -72
- data/spec/features/record_deployment_spec.rb +0 -106
- data/spec/features/record_release_spec.rb +0 -84
- data/spec/features/record_undeployment_spec.rb +0 -67
- data/spec/features/tag_version_spec.rb +0 -13
- data/spec/features/update_environment_spec.rb +0 -44
- data/spec/features/update_matrix_spec.rb +0 -146
- data/spec/features/update_pacticipant_spec.rb +0 -98
- data/spec/features/update_version_spec.rb +0 -100
- data/spec/features/update_webhook_spec.rb +0 -47
- data/spec/features/wip_pacts_spec.rb +0 -387
- data/spec/fixtures/a_consumer-a_provider-2.json +0 -22
- data/spec/fixtures/a_consumer-a_provider-3.json +0 -22
- data/spec/fixtures/a_consumer-a_provider-conflict.json +0 -22
- data/spec/fixtures/a_consumer-a_provider-merged.json +0 -34
- data/spec/fixtures/a_consumer-a_provider.json +0 -22
- data/spec/fixtures/approvals/clean_incremental_dry_run.approved.json +0 -100
- data/spec/fixtures/approvals/docs_webhooks_executing_a_saved_webhook_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_executing_a_saved_webhook_post.approved.json +0 -43
- data/spec/fixtures/approvals/docs_webhooks_executing_an_unsaved_webhook_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_executing_an_unsaved_webhook_post.approved.json +0 -63
- data/spec/fixtures/approvals/docs_webhooks_logs_of_triggered_webhook_get.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_logs_of_triggered_webhook_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_pact_webhooks_get.approved.json +0 -45
- data/spec/fixtures/approvals/docs_webhooks_pact_webhooks_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_triggered_webhooks_for_pact_publication_get.approved.json +0 -52
- data/spec/fixtures/approvals/docs_webhooks_triggered_webhooks_for_pact_publication_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_triggered_webhooks_for_verification_publication_get.approved.json +0 -32
- data/spec/fixtures/approvals/docs_webhooks_triggered_webhooks_for_verification_publication_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhook_get.approved.json +0 -74
- data/spec/fixtures/approvals/docs_webhooks_webhook_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhook_put.approved.json +0 -77
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_a_provider_get.approved.json +0 -41
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_a_provider_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_consumer_and_provider_get.approved.json +0 -45
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_consumer_and_provider_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_consumer_get.approved.json +0 -41
- data/spec/fixtures/approvals/docs_webhooks_webhooks_for_consumer_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhooks_get.approved.json +0 -45
- data/spec/fixtures/approvals/docs_webhooks_webhooks_options.approved.json +0 -20
- data/spec/fixtures/approvals/docs_webhooks_webhooks_post.approved.json +0 -78
- data/spec/fixtures/approvals/docs_webhooks_webhooks_status_get.approved.json +0 -79
- data/spec/fixtures/approvals/docs_webhooks_webhooks_status_options.approved.json +0 -20
- data/spec/fixtures/approvals/get_provider_pacts_for_verification.approved.json +0 -56
- data/spec/fixtures/approvals/matrix_integration_environment_spec.approved.json +0 -62
- data/spec/fixtures/approvals/matrix_integration_ignore_spec.approved.json +0 -124
- data/spec/fixtures/approvals/matrix_integration_spec.approved.json +0 -173
- data/spec/fixtures/approvals/modifiable_resources.approved.json +0 -105
- data/spec/fixtures/approvals/publish_contract_no_branch.approved.json +0 -165
- data/spec/fixtures/approvals/publish_contract_nothing_exists.approved.json +0 -156
- data/spec/fixtures/approvals/publish_contract_nothing_exists_with_webhook.approved.json +0 -156
- data/spec/fixtures/approvals/publish_contract_verification_already_exists.approved.json +0 -147
- data/spec/fixtures/approvals/publish_contract_with_validation_error.approved.json +0 -41
- data/spec/fixtures/approvals/publish_contracts_results_decorator.approved.json +0 -61
- data/spec/fixtures/certificate-invalid.pem +0 -29
- data/spec/fixtures/certificate.pem +0 -53
- data/spec/fixtures/certificates/cacert.pem +0 -21
- data/spec/fixtures/certificates/cert.pem +0 -20
- data/spec/fixtures/certificates/key.pem +0 -27
- data/spec/fixtures/certificates/self-signed.badssl.com.pem +0 -21
- data/spec/fixtures/consumer-provider.json +0 -25
- data/spec/fixtures/dashboard.json +0 -87
- data/spec/fixtures/expected.gv +0 -4
- data/spec/fixtures/foo-bar.json +0 -22
- data/spec/fixtures/invalid-publish-contract-body.json +0 -38
- data/spec/fixtures/renderer_pact.json +0 -34
- data/spec/fixtures/update_pacticipant.json +0 -5
- data/spec/fixtures/updated_pacticipant.json +0 -11
- data/spec/fixtures/verification.json +0 -11
- data/spec/fixtures/webhook_valid.json +0 -17
- data/spec/fixtures/webhook_valid_with_pacticipants.json +0 -23
- data/spec/integration/app_spec.rb +0 -209
- data/spec/integration/endpoints/group_spec.rb +0 -19
- data/spec/integration/pact_metdata_spec.rb +0 -105
- data/spec/integration/ui/index_spec.rb +0 -50
- data/spec/integration/ui/matrix_spec.rb +0 -36
- data/spec/integration/webhooks/certificate_spec.rb +0 -47
- data/spec/integration/webhooks/contract_publication_spec.rb +0 -68
- data/spec/integration/webhooks/contract_requiring_verification_published_spec.rb +0 -67
- data/spec/integration/webhooks/pact_publication_spec.rb +0 -51
- data/spec/integration/webhooks_documentation_spec.rb +0 -348
- data/spec/lib/pact/doc/generator_spec.rb +0 -80
- data/spec/lib/pact/doc/interaction_view_model_spec.rb +0 -232
- data/spec/lib/pact/doc/markdown/consumer_contract_renderer_spec.rb +0 -71
- data/spec/lib/pact/doc/markdown/index_renderer_spec.rb +0 -29
- data/spec/lib/pact_broker/api/contracts/environment_schema_spec.rb +0 -91
- data/spec/lib/pact_broker/api/contracts/pacticipant_schema_spec.rb +0 -46
- data/spec/lib/pact_broker/api/contracts/pacts_for_verification_json_query_schema_combinations_spec.rb +0 -87
- data/spec/lib/pact_broker/api/contracts/pacts_for_verification_json_query_schema_spec.rb +0 -358
- data/spec/lib/pact_broker/api/contracts/pacts_for_verification_query_string_schema_spec.rb +0 -97
- data/spec/lib/pact_broker/api/contracts/publish_contracts_schema_spec.rb +0 -127
- data/spec/lib/pact_broker/api/contracts/put_pact_params_contract_spec.rb +0 -133
- data/spec/lib/pact_broker/api/contracts/verification_contract_spec.rb +0 -112
- data/spec/lib/pact_broker/api/contracts/webhook_contract_spec.rb +0 -379
- data/spec/lib/pact_broker/api/decorators/dashboard_decorator_spec.rb +0 -94
- data/spec/lib/pact_broker/api/decorators/embedded_label_decorator_spec.rb +0 -34
- data/spec/lib/pact_broker/api/decorators/embedded_tag_decorator_spec.rb +0 -41
- data/spec/lib/pact_broker/api/decorators/embedded_version_decorator_spec.rb +0 -39
- data/spec/lib/pact_broker/api/decorators/extended_pact_decorator_spec.rb +0 -62
- data/spec/lib/pact_broker/api/decorators/integration_decorator_spec.rb +0 -86
- data/spec/lib/pact_broker/api/decorators/integrations_decorator_spec.rb +0 -29
- data/spec/lib/pact_broker/api/decorators/label_decorator_spec.rb +0 -42
- data/spec/lib/pact_broker/api/decorators/latest_pact_decorator_spec.rb +0 -25
- data/spec/lib/pact_broker/api/decorators/matrix_decorator_spec.rb +0 -259
- data/spec/lib/pact_broker/api/decorators/pact_collection_decorator_spec.rb +0 -23
- data/spec/lib/pact_broker/api/decorators/pact_decorator_spec.rb +0 -136
- data/spec/lib/pact_broker/api/decorators/pact_version_decorator_spec.rb +0 -61
- data/spec/lib/pact_broker/api/decorators/pact_webhooks_status_decorator_spec.rb +0 -138
- data/spec/lib/pact_broker/api/decorators/pacticipant_collection_decorator_spec.rb +0 -62
- data/spec/lib/pact_broker/api/decorators/pacticipant_decorator_spec.rb +0 -89
- data/spec/lib/pact_broker/api/decorators/pacts_for_verification_query_decorator_spec.rb +0 -175
- data/spec/lib/pact_broker/api/decorators/provider_pacts_decorator_spec.rb +0 -58
- data/spec/lib/pact_broker/api/decorators/publish_contracts_results_decorator_spec.rb +0 -53
- data/spec/lib/pact_broker/api/decorators/reason_decorator_spec.rb +0 -95
- data/spec/lib/pact_broker/api/decorators/relationships_csv_decorator_spec.rb +0 -28
- data/spec/lib/pact_broker/api/decorators/representable_pact_spec.rb +0 -29
- data/spec/lib/pact_broker/api/decorators/tag_decorator_spec.rb +0 -57
- data/spec/lib/pact_broker/api/decorators/tagged_pact_versions_decorator_spec.rb +0 -79
- data/spec/lib/pact_broker/api/decorators/triggered_webhook_decorator_spec.rb +0 -69
- data/spec/lib/pact_broker/api/decorators/triggered_webhooks_decorator_spec.rb +0 -28
- data/spec/lib/pact_broker/api/decorators/verifiable_pact_decorator_spec.rb +0 -94
- data/spec/lib/pact_broker/api/decorators/verifiable_pacts_decorator_spec.rb +0 -29
- data/spec/lib/pact_broker/api/decorators/verification_decorator_spec.rb +0 -81
- data/spec/lib/pact_broker/api/decorators/verification_summary_decorator_spec.rb +0 -65
- data/spec/lib/pact_broker/api/decorators/version_decorator_spec.rb +0 -121
- data/spec/lib/pact_broker/api/decorators/versions_decorator_spec.rb +0 -49
- data/spec/lib/pact_broker/api/decorators/webhook_decorator_spec.rb +0 -210
- data/spec/lib/pact_broker/api/decorators/webhook_execution_result_decorator_spec.rb +0 -128
- data/spec/lib/pact_broker/api/decorators/webhook_request_template_decorator_spec.rb +0 -78
- data/spec/lib/pact_broker/api/decorators/webhooks_decorator_spec.rb +0 -48
- data/spec/lib/pact_broker/api/middleware/basic_auth_spec.rb +0 -312
- data/spec/lib/pact_broker/api/middleware/configuration_spec.rb +0 -43
- data/spec/lib/pact_broker/api/pact_broker_urls_spec.rb +0 -221
- data/spec/lib/pact_broker/api/renderers/html_pact_renderer_spec.rb +0 -141
- data/spec/lib/pact_broker/api/renderers/integrations_dot_renderer_spec.rb +0 -29
- data/spec/lib/pact_broker/api/resources/all_webhooks_spec.rb +0 -145
- data/spec/lib/pact_broker/api/resources/badge_spec.rb +0 -212
- data/spec/lib/pact_broker/api/resources/can_i_deploy_badge_spec.rb +0 -80
- data/spec/lib/pact_broker/api/resources/can_i_deploy_pacticipant_version_spec.rb +0 -31
- data/spec/lib/pact_broker/api/resources/can_i_deploy_spec.rb +0 -51
- data/spec/lib/pact_broker/api/resources/dashboard_spec.rb +0 -36
- data/spec/lib/pact_broker/api/resources/default_base_resource_approval_spec.rb +0 -60
- data/spec/lib/pact_broker/api/resources/default_base_resource_spec.rb +0 -224
- data/spec/lib/pact_broker/api/resources/error_response_body_generator_spec.rb +0 -69
- data/spec/lib/pact_broker/api/resources/group_spec.rb +0 -82
- data/spec/lib/pact_broker/api/resources/latest_pact_spec.rb +0 -80
- data/spec/lib/pact_broker/api/resources/latest_provider_pacts_spec.rb +0 -52
- data/spec/lib/pact_broker/api/resources/latest_verifications_for_consumer_version_spec.rb +0 -68
- data/spec/lib/pact_broker/api/resources/matrix_badge_spec.rb +0 -11
- data/spec/lib/pact_broker/api/resources/matrix_spec.rb +0 -42
- data/spec/lib/pact_broker/api/resources/pact_spec.rb +0 -178
- data/spec/lib/pact_broker/api/resources/pact_triggered_webhooks_spec.rb +0 -54
- data/spec/lib/pact_broker/api/resources/pacticipant_spec.rb +0 -60
- data/spec/lib/pact_broker/api/resources/pacticipant_webhooks_spec.rb +0 -238
- data/spec/lib/pact_broker/api/resources/pacticipants_spec.rb +0 -87
- data/spec/lib/pact_broker/api/resources/provider_pacts_for_verification_spec.rb +0 -116
- data/spec/lib/pact_broker/api/resources/provider_pacts_spec.rb +0 -75
- data/spec/lib/pact_broker/api/resources/released_version_spec.rb +0 -61
- data/spec/lib/pact_broker/api/resources/tag_spec.rb +0 -166
- data/spec/lib/pact_broker/api/resources/tagged_pact_versions_spec.rb +0 -96
- data/spec/lib/pact_broker/api/resources/triggered_webhook_logs_spec.rb +0 -32
- data/spec/lib/pact_broker/api/resources/verification_spec.rb +0 -87
- data/spec/lib/pact_broker/api/resources/verification_triggered_webhooks_spec.rb +0 -67
- data/spec/lib/pact_broker/api/resources/verifications_spec.rb +0 -135
- data/spec/lib/pact_broker/api/resources/webhook_execution_spec.rb +0 -92
- data/spec/lib/pact_broker/api/resources/webhook_spec.rb +0 -115
- data/spec/lib/pact_broker/app_basic_auth_spec.rb +0 -122
- data/spec/lib/pact_broker/app_spec.rb +0 -348
- data/spec/lib/pact_broker/badges/service_spec.rb +0 -348
- data/spec/lib/pact_broker/build_http_options_spec.rb +0 -47
- data/spec/lib/pact_broker/certificates/service_spec.rb +0 -80
- data/spec/lib/pact_broker/config/load_spec.rb +0 -110
- data/spec/lib/pact_broker/config/runtime_configuration_documentation_spec.rb +0 -30
- data/spec/lib/pact_broker/config/runtime_configuration_logging_methods_spec.rb +0 -22
- data/spec/lib/pact_broker/config/runtime_configuration_spec.rb +0 -71
- data/spec/lib/pact_broker/config/save_spec.rb +0 -100
- data/spec/lib/pact_broker/config/space_delimited_integer_list_spec.rb +0 -47
- data/spec/lib/pact_broker/config/space_delimited_string_list_spec.rb +0 -45
- data/spec/lib/pact_broker/configuration_spec.rb +0 -167
- data/spec/lib/pact_broker/contracts/service_spec.rb +0 -193
- data/spec/lib/pact_broker/db/clean_incremental_spec.rb +0 -120
- data/spec/lib/pact_broker/db/clean_old_spec.rb +0 -123
- data/spec/lib/pact_broker/db/clean_spec.rb +0 -153
- data/spec/lib/pact_broker/db/data_migrations/create_branches_spec.rb +0 -57
- data/spec/lib/pact_broker/db/data_migrations/migrate_webhook_headers_spec.rb +0 -78
- data/spec/lib/pact_broker/db/data_migrations/set_consumer_ids_for_pact_publications_spec.rb +0 -40
- data/spec/lib/pact_broker/db/data_migrations/set_interactions_counts_spec.rb +0 -38
- data/spec/lib/pact_broker/db/data_migrations/set_latest_version_sequence_value_spec.rb +0 -68
- data/spec/lib/pact_broker/db/data_migrations/set_pacticipant_main_branch_spec.rb +0 -41
- data/spec/lib/pact_broker/db/delete_overwritten_data_spec.rb +0 -161
- data/spec/lib/pact_broker/db/log_quietener_spec.rb +0 -52
- data/spec/lib/pact_broker/db/validate_encoding_spec.rb +0 -66
- data/spec/lib/pact_broker/deployments/deployed_version_service_spec.rb +0 -42
- data/spec/lib/pact_broker/deployments/deployed_version_spec.rb +0 -109
- data/spec/lib/pact_broker/deployments/environment_service_spec.rb +0 -58
- data/spec/lib/pact_broker/deployments/environment_spec.rb +0 -27
- data/spec/lib/pact_broker/diagnostic/resources/dependencies_spec.rb +0 -85
- data/spec/lib/pact_broker/diagnostic/resources/heartbeat_spec.rb +0 -34
- data/spec/lib/pact_broker/doc/controllers/app_spec.rb +0 -82
- data/spec/lib/pact_broker/doc/coverage_spec.rb +0 -39
- data/spec/lib/pact_broker/domain/group_spec.rb +0 -25
- data/spec/lib/pact_broker/domain/index_item_spec.rb +0 -24
- data/spec/lib/pact_broker/domain/order_versions_spec.rb +0 -84
- data/spec/lib/pact_broker/domain/pact_spec.rb +0 -27
- data/spec/lib/pact_broker/domain/tag_spec.rb +0 -134
- data/spec/lib/pact_broker/domain/verification_spec.rb +0 -133
- data/spec/lib/pact_broker/domain/version_spec.rb +0 -490
- data/spec/lib/pact_broker/domain/webhook_request_spec.rb +0 -196
- data/spec/lib/pact_broker/domain/webhook_spec.rb +0 -168
- data/spec/lib/pact_broker/errors/error_logger_spec.rb +0 -65
- data/spec/lib/pact_broker/errors_spec.rb +0 -54
- data/spec/lib/pact_broker/events/subscriber_spec.rb +0 -43
- data/spec/lib/pact_broker/feature_toggle_spec.rb +0 -80
- data/spec/lib/pact_broker/groups/service_spec.rb +0 -52
- data/spec/lib/pact_broker/hash_refinements_spec.rb +0 -63
- data/spec/lib/pact_broker/index/service_spec.rb +0 -400
- data/spec/lib/pact_broker/index/service_view_spec.rb +0 -144
- data/spec/lib/pact_broker/integrations/integration_spec.rb +0 -108
- data/spec/lib/pact_broker/integrations/service_spec.rb +0 -282
- data/spec/lib/pact_broker/labels/repository_spec.rb +0 -124
- data/spec/lib/pact_broker/labels/service_spec.rb +0 -28
- data/spec/lib/pact_broker/matrix/aggregated_row_spec.rb +0 -100
- data/spec/lib/pact_broker/matrix/can_i_deploy_query_schema_spec.rb +0 -72
- data/spec/lib/pact_broker/matrix/deployment_status_summary_spec.rb +0 -300
- data/spec/lib/pact_broker/matrix/every_row_spec.rb +0 -133
- data/spec/lib/pact_broker/matrix/head_row_spec.rb +0 -89
- data/spec/lib/pact_broker/matrix/integration_environment_spec.rb +0 -187
- data/spec/lib/pact_broker/matrix/integration_ignore_spec.rb +0 -238
- data/spec/lib/pact_broker/matrix/integration_spec.rb +0 -504
- data/spec/lib/pact_broker/matrix/parse_can_i_deploy_query_spec.rb +0 -77
- data/spec/lib/pact_broker/matrix/parse_query_spec.rb +0 -141
- data/spec/lib/pact_broker/matrix/quick_row_spec.rb +0 -74
- data/spec/lib/pact_broker/matrix/repository_dependency_spec.rb +0 -56
- data/spec/lib/pact_broker/matrix/repository_query_limit_spec.rb +0 -78
- data/spec/lib/pact_broker/matrix/repository_spec.rb +0 -888
- data/spec/lib/pact_broker/matrix/row_spec.rb +0 -74
- data/spec/lib/pact_broker/matrix/service_spec.rb +0 -200
- data/spec/lib/pact_broker/messages_spec.rb +0 -29
- data/spec/lib/pact_broker/metrics/service_spec.rb +0 -131
- data/spec/lib/pact_broker/pacticipants/find_potential_duplicate_pacticipant_names_spec.rb +0 -63
- data/spec/lib/pact_broker/pacticipants/generate_display_name_spec.rb +0 -39
- data/spec/lib/pact_broker/pacticipants/repository_spec.rb +0 -239
- data/spec/lib/pact_broker/pacticipants/service_spec.rb +0 -217
- data/spec/lib/pact_broker/pacts/build_verifiable_pact_notices_spec.rb +0 -75
- data/spec/lib/pact_broker/pacts/content_spec.rb +0 -447
- data/spec/lib/pact_broker/pacts/create_formatted_diff_spec.rb +0 -29
- data/spec/lib/pact_broker/pacts/diff_spec.rb +0 -99
- data/spec/lib/pact_broker/pacts/generate_interaction_sha_spec.rb +0 -45
- data/spec/lib/pact_broker/pacts/generate_sha_spec.rb +0 -92
- data/spec/lib/pact_broker/pacts/merger_spec.rb +0 -171
- data/spec/lib/pact_broker/pacts/metadata_spec.rb +0 -147
- data/spec/lib/pact_broker/pacts/pact_params_spec.rb +0 -111
- data/spec/lib/pact_broker/pacts/pact_publication_clean_selector_dataset_module_spec.rb +0 -97
- data/spec/lib/pact_broker/pacts/pact_publication_dataset_module_spec.rb +0 -499
- data/spec/lib/pact_broker/pacts/pact_publication_latest_verification_spec.rb +0 -29
- data/spec/lib/pact_broker/pacts/pact_publication_selector_dataset_module_spec.rb +0 -185
- data/spec/lib/pact_broker/pacts/pact_publication_spec.rb +0 -559
- data/spec/lib/pact_broker/pacts/pact_version_spec.rb +0 -343
- data/spec/lib/pact_broker/pacts/repository_find_for_currently_deployed_spec.rb +0 -124
- data/spec/lib/pact_broker/pacts/repository_find_for_currently_supported_releases_spec.rb +0 -159
- data/spec/lib/pact_broker/pacts/repository_find_for_verification_fallback_spec.rb +0 -87
- data/spec/lib/pact_broker/pacts/repository_find_for_verification_spec.rb +0 -380
- data/spec/lib/pact_broker/pacts/repository_find_wip_pact_versions_for_provider_branch_spec.rb +0 -282
- data/spec/lib/pact_broker/pacts/repository_find_wip_pact_versions_for_provider_spec.rb +0 -375
- data/spec/lib/pact_broker/pacts/repository_spec.rb +0 -1079
- data/spec/lib/pact_broker/pacts/selected_pact_spec.rb +0 -23
- data/spec/lib/pact_broker/pacts/selector_spec.rb +0 -77
- data/spec/lib/pact_broker/pacts/selectors_spec.rb +0 -30
- data/spec/lib/pact_broker/pacts/service_spec.rb +0 -355
- data/spec/lib/pact_broker/pacts/sort_content_spec.rb +0 -57
- data/spec/lib/pact_broker/pacts/squash_pacts_for_verification_spec.rb +0 -70
- data/spec/lib/pact_broker/pacts/verifiable_pact_messages_spec.rb +0 -253
- data/spec/lib/pact_broker/pacts/verifiable_pact_spec.rb +0 -0
- data/spec/lib/pact_broker/relationships/groupify_spec.rb +0 -43
- data/spec/lib/pact_broker/tags/repository_spec.rb +0 -144
- data/spec/lib/pact_broker/tags/service_spec.rb +0 -66
- data/spec/lib/pact_broker/ui/controllers/can_i_deploy_spec.rb +0 -26
- data/spec/lib/pact_broker/ui/controllers/clusters_spec.rb +0 -27
- data/spec/lib/pact_broker/ui/controllers/index_spec.rb +0 -132
- data/spec/lib/pact_broker/ui/view_models/index_item_spec.rb +0 -173
- data/spec/lib/pact_broker/ui/view_models/index_items_spec.rb +0 -35
- data/spec/lib/pact_broker/ui/view_models/matrix_deployed_version_spec.rb +0 -29
- data/spec/lib/pact_broker/ui/view_models/matrix_line_spec.rb +0 -41
- data/spec/lib/pact_broker/verifications/pseudo_branch_status_spec.rb +0 -56
- data/spec/lib/pact_broker/verifications/repository_spec.rb +0 -350
- data/spec/lib/pact_broker/verifications/sequence_spec.rb +0 -73
- data/spec/lib/pact_broker/verifications/service_spec.rb +0 -266
- data/spec/lib/pact_broker/verifications/summary_for_consumer_version_spec.rb +0 -72
- data/spec/lib/pact_broker/versions/abbreviate_number_spec.rb +0 -23
- data/spec/lib/pact_broker/versions/branch_service_spec.rb +0 -71
- data/spec/lib/pact_broker/versions/branch_version_repository_spec.rb +0 -81
- data/spec/lib/pact_broker/versions/branch_version_spec.rb +0 -27
- data/spec/lib/pact_broker/versions/parse_semantic_version_spec.rb +0 -42
- data/spec/lib/pact_broker/versions/repository_spec.rb +0 -302
- data/spec/lib/pact_broker/versions/service_spec.rb +0 -137
- data/spec/lib/pact_broker/webhooks/check_host_whitelist_spec.rb +0 -85
- data/spec/lib/pact_broker/webhooks/execution_configuration_spec.rb +0 -18
- data/spec/lib/pact_broker/webhooks/job_spec.rb +0 -188
- data/spec/lib/pact_broker/webhooks/pact_and_verification_parameters_spec.rb +0 -16
- data/spec/lib/pact_broker/webhooks/redact_logs_spec.rb +0 -60
- data/spec/lib/pact_broker/webhooks/render_spec.rb +0 -221
- data/spec/lib/pact_broker/webhooks/repository_spec.rb +0 -933
- data/spec/lib/pact_broker/webhooks/service_spec.rb +0 -184
- data/spec/lib/pact_broker/webhooks/status_spec.rb +0 -54
- data/spec/lib/pact_broker/webhooks/trigger_service_spec.rb +0 -461
- data/spec/lib/pact_broker/webhooks/triggered_webhook_spec.rb +0 -40
- data/spec/lib/pact_broker/webhooks/webhook_request_logger_spec.rb +0 -207
- data/spec/lib/pact_broker/webhooks/webhook_request_template_spec.rb +0 -227
- data/spec/lib/pact_broker/webhooks/webhook_spec.rb +0 -39
- data/spec/lib/rack/hal_browser/redirect_spec.rb +0 -63
- data/spec/lib/rack/pact_broker/add_pact_broker_version_header_spec.rb +0 -16
- data/spec/lib/rack/pact_broker/database_transaction_spec.rb +0 -77
- data/spec/lib/rack/pact_broker/invalid_uri_protection_spec.rb +0 -50
- data/spec/lib/rack/pact_broker/request_target_spec.rb +0 -69
- data/spec/lib/rack/pact_broker/set_base_url_spec.rb +0 -86
- data/spec/lib/rack/pact_broker/use_when_spec.rb +0 -49
- data/spec/lib/sequel/plugins/insert_ignore_spec.rb +0 -82
- data/spec/lib/sequel/plugins/upsert_spec.rb +0 -159
- data/spec/lib/webmachine/rack_adapter_monkey_patch_spec.rb +0 -49
- data/spec/migrations/20180201_create_head_matrix_spec.rb +0 -132
- data/spec/migrations/23_pact_versions_spec.rb +0 -77
- data/spec/migrations/24_populate_pact_contents_spec.rb +0 -22
- data/spec/migrations/34_latest_tagged_pacts_spec.rb +0 -84
- data/spec/migrations/34_pact_revisions_spec.rb +0 -82
- data/spec/migrations/41_migrate_execution_data_spec.rb +0 -109
- data/spec/migrations/42_delete_ophan_webhook_data_spec.rb +0 -98
- data/spec/migrations/44_add_provider_version_to_verification_spec.rb +0 -56
- data/spec/migrations/50_create_latest_matrix_spec.rb +0 -181
- data/spec/migrations/change_migration_strategy_spec.rb +0 -85
- data/spec/migrations/rollback_spec.rb +0 -8
- data/spec/service_consumers/hal_relation_proxy_app.rb +0 -61
- data/spec/service_consumers/pact_helper.rb +0 -61
- data/spec/service_consumers/provider_states_for_pact_broker_client.rb +0 -341
- data/spec/service_consumers/provider_states_for_pact_broker_client_2.rb +0 -36
- data/spec/service_consumers/provider_states_for_pact_ruby.rb +0 -158
- data/spec/spec_helper.rb +0 -65
- data/spec/support/approvals.rb +0 -55
- data/spec/support/database.rb +0 -9
- data/spec/support/database_cleaner.rb +0 -44
- data/spec/support/documentation.rb +0 -64
- data/spec/support/fixture_helpers.rb +0 -10
- data/spec/support/fixture_pact.rb +0 -34
- data/spec/support/foo-bar.json +0 -34
- data/spec/support/generated_index.md +0 -4
- data/spec/support/generated_markdown.md +0 -55
- data/spec/support/interaction_view_model.json +0 -63
- data/spec/support/interaction_view_model_with_terms.json +0 -50
- data/spec/support/logging.rb +0 -6
- data/spec/support/markdown_pact.json +0 -48
- data/spec/support/markdown_pact_v3.json +0 -44
- data/spec/support/markdown_pact_with_html.json +0 -27
- data/spec/support/markdown_pact_with_markdown_chars_in_names.json +0 -11
- data/spec/support/metadata_test_server.rb +0 -40
- data/spec/support/migration_helpers.rb +0 -16
- data/spec/support/rack_helpers.rb +0 -20
- data/spec/support/rspec_match_hash.rb +0 -26
- data/spec/support/rspec_matchers.rb +0 -9
- data/spec/support/shared_context.rb +0 -32
- data/spec/support/shared_examples_for_responses.rb +0 -96
- data/spec/support/simplecov.rb +0 -23
- data/spec/support/ssl_pact_broker_server.rb +0 -46
- data/spec/support/ssl_webhook_server.rb +0 -39
- data/spec/support/test_data_builder.rb +0 -3
- data/spec/support/verification_job.rb +0 -37
- data/spec/support/warning_silencer.rb +0 -10
- data/spec/support/webhook_endpoint_middleware.rb +0 -22
- data/tasks/audit.rake +0 -6
- data/tasks/database/annotate.rb +0 -48
- data/tasks/database/table_dependency_calculator.rb +0 -8
- data/tasks/database.rb +0 -161
- data/tasks/db.rake +0 -147
- data/tasks/development.rake +0 -52
- data/tasks/docker_database.rb +0 -26
- data/tasks/pact.rake +0 -16
- data/tasks/release.rake +0 -6
- data/tasks/rspec.rake +0 -32
- data/tasks/test_db.rake +0 -32
- data/vendor/hal-browser/.gitignore +0 -1
@@ -1,933 +0,0 @@
|
|
1
|
-
require "spec_helper"
|
2
|
-
require "pact_broker/webhooks/repository"
|
3
|
-
|
4
|
-
module PactBroker
|
5
|
-
module Webhooks
|
6
|
-
describe Repository do
|
7
|
-
let(:url) { "http://example.org" }
|
8
|
-
let(:body) { {"some" => "json" } }
|
9
|
-
let(:headers) { {"Content-Type" => "application/json", "Accept" => "application/json"} }
|
10
|
-
let(:request) do
|
11
|
-
Webhooks::WebhookRequestTemplate.new(
|
12
|
-
method: "post",
|
13
|
-
url: url,
|
14
|
-
headers: headers,
|
15
|
-
username: "username",
|
16
|
-
password: "password",
|
17
|
-
body: body)
|
18
|
-
end
|
19
|
-
let(:event) do
|
20
|
-
PactBroker::Webhooks::WebhookEvent.new(name: "something_happened")
|
21
|
-
end
|
22
|
-
let(:events) { [event]}
|
23
|
-
let(:webhook) { Domain::Webhook.new(request: request, events: events) }
|
24
|
-
let(:consumer) { td.create_pacticipant("Consumer").and_return(:pacticipant) }
|
25
|
-
let(:provider) { td.create_pacticipant("Provider").and_return(:pacticipant) }
|
26
|
-
let(:webhook_consumer) { Domain::WebhookPacticipant.new(name: consumer.name) }
|
27
|
-
let(:webhook_provider) { Domain::WebhookPacticipant.new(name: provider.name) }
|
28
|
-
let(:uuid) { "the-uuid" }
|
29
|
-
let(:created_webhook_record) { ::DB::PACT_BROKER_DB[:webhooks].order(:id).last }
|
30
|
-
let(:created_events) { ::DB::PACT_BROKER_DB[:webhook_events].where(webhook_id: created_webhook_record[:id]).order(:name).all }
|
31
|
-
let(:expected_webhook_record) do
|
32
|
-
{
|
33
|
-
uuid: "the-uuid",
|
34
|
-
method: "post",
|
35
|
-
url: "http://example.org",
|
36
|
-
username: "username",
|
37
|
-
password: "cGFzc3dvcmQ=",
|
38
|
-
body: body.to_json,
|
39
|
-
consumer_id: consumer.id,
|
40
|
-
provider_id: provider.id
|
41
|
-
}
|
42
|
-
end
|
43
|
-
|
44
|
-
describe "#create" do
|
45
|
-
subject { Repository.new.create(uuid, webhook, consumer, provider) }
|
46
|
-
|
47
|
-
it "saves webhook" do
|
48
|
-
subject
|
49
|
-
expect(created_webhook_record).to include expected_webhook_record
|
50
|
-
end
|
51
|
-
|
52
|
-
it "saves the webhook headers as JSON" do
|
53
|
-
subject
|
54
|
-
expect(JSON.parse(created_webhook_record[:headers])).to eq headers
|
55
|
-
end
|
56
|
-
|
57
|
-
it "saves the webhook events" do
|
58
|
-
expect(subject.events.first[:name]).to eq "something_happened"
|
59
|
-
end
|
60
|
-
|
61
|
-
context "when consumer and provider domain objects are set on the object rather than passed in" do
|
62
|
-
let(:webhook) { Domain::Webhook.new(request: request, events: events, consumer: webhook_consumer, provider: webhook_provider) }
|
63
|
-
|
64
|
-
subject { Repository.new.create(uuid, webhook, nil, nil) }
|
65
|
-
|
66
|
-
it "sets the consumer and provider relationships" do
|
67
|
-
expect(subject.consumer.name).to eq consumer.name
|
68
|
-
expect(subject.provider.name).to eq provider.name
|
69
|
-
end
|
70
|
-
end
|
71
|
-
end
|
72
|
-
|
73
|
-
describe "delete_by_uuid" do
|
74
|
-
before do
|
75
|
-
Repository.new.create uuid, webhook, consumer, provider
|
76
|
-
Repository.new.create "another-uuid", webhook, consumer, provider
|
77
|
-
end
|
78
|
-
|
79
|
-
subject { Repository.new.delete_by_uuid(uuid) }
|
80
|
-
|
81
|
-
it "deletes the webhook" do
|
82
|
-
expect { subject }.to change { ::DB::PACT_BROKER_DB[:webhooks].where(uuid: uuid).count }.by(-1)
|
83
|
-
end
|
84
|
-
end
|
85
|
-
|
86
|
-
describe "delete_by_pacticipant" do
|
87
|
-
before do
|
88
|
-
td.create_consumer("other-consumer")
|
89
|
-
.create_provider("other-provider")
|
90
|
-
.create_consumer_version
|
91
|
-
.create_pact
|
92
|
-
.create_webhook(uuid: "other-uuid")
|
93
|
-
.create_triggered_webhook
|
94
|
-
.create_webhook_execution
|
95
|
-
.create_consumer("foo")
|
96
|
-
.create_provider("bar")
|
97
|
-
.create_consumer_version
|
98
|
-
.create_pact
|
99
|
-
.create_webhook(uuid: "1234")
|
100
|
-
.create_triggered_webhook
|
101
|
-
.create_webhook_execution
|
102
|
-
.create_webhook(uuid: "5555")
|
103
|
-
.create_triggered_webhook
|
104
|
-
.create_webhook_execution
|
105
|
-
# simulate resource already deleted
|
106
|
-
Webhook.where(uuid: "5555").delete
|
107
|
-
end
|
108
|
-
|
109
|
-
context "when the pacticipant is the consumer" do
|
110
|
-
|
111
|
-
subject { Repository.new.delete_by_pacticipant td.consumer }
|
112
|
-
|
113
|
-
it "deletes the matching webhook" do
|
114
|
-
expect { subject }.to change { Webhook.where(uuid: "1234").count }.by(-1)
|
115
|
-
end
|
116
|
-
|
117
|
-
it "does not delete the unmatching webhooks" do
|
118
|
-
expect { subject }.to change { Webhook.count }.by(-1)
|
119
|
-
end
|
120
|
-
|
121
|
-
it "deletes the triggered webhooks" do
|
122
|
-
expect { subject }.to change { TriggeredWebhook.count }.by(-2)
|
123
|
-
end
|
124
|
-
end
|
125
|
-
|
126
|
-
context "when the pacticipant is the provider" do
|
127
|
-
subject { Repository.new.delete_by_pacticipant(td.provider) }
|
128
|
-
|
129
|
-
it "deletes the matching webhooks" do
|
130
|
-
expect { subject }.to change { Webhook.where(uuid: "1234").count }.by(-1)
|
131
|
-
end
|
132
|
-
|
133
|
-
it "does not delete the unmatching webhooks" do
|
134
|
-
expect { subject }.to change { Webhook.count }.by(-1)
|
135
|
-
end
|
136
|
-
|
137
|
-
it "deletes the triggered webhooks" do
|
138
|
-
expect { subject }.to change { TriggeredWebhook.count }.by(-2)
|
139
|
-
end
|
140
|
-
end
|
141
|
-
end
|
142
|
-
|
143
|
-
describe "delete_by_consumer_and_provider" do
|
144
|
-
before do
|
145
|
-
td.create_consumer("foo")
|
146
|
-
.create_provider("other-provider")
|
147
|
-
.create_consumer_version
|
148
|
-
.create_pact
|
149
|
-
.create_webhook(uuid: "other-uuid")
|
150
|
-
.comment("kept because doesn't match provider")
|
151
|
-
.create_triggered_webhook
|
152
|
-
.create_webhook_execution
|
153
|
-
.create_provider("bar")
|
154
|
-
.create_consumer_version
|
155
|
-
.create_pact
|
156
|
-
.create_webhook(uuid: "1234")
|
157
|
-
.create_triggered_webhook
|
158
|
-
.create_webhook_execution
|
159
|
-
.create_webhook(uuid: "5555")
|
160
|
-
.create_triggered_webhook
|
161
|
-
.create_webhook_execution
|
162
|
-
# simulate resource already deleted
|
163
|
-
Webhook.where(uuid: "5555").delete
|
164
|
-
end
|
165
|
-
|
166
|
-
subject { Repository.new.delete_by_consumer_and_provider(td.consumer, td.provider) }
|
167
|
-
|
168
|
-
it "deletes the webhooks that match both consumer and provider" do
|
169
|
-
expect { subject }.to change { Webhook.where(uuid: "1234").count }.by(-1)
|
170
|
-
end
|
171
|
-
|
172
|
-
it "does not delete the unmatching webhooks" do
|
173
|
-
expect { subject }.to change { Webhook.count }.by(-1)
|
174
|
-
end
|
175
|
-
|
176
|
-
it "deletes the triggered webhooks" do
|
177
|
-
expect { subject }.to change { TriggeredWebhook.count }.by(-2)
|
178
|
-
end
|
179
|
-
end
|
180
|
-
|
181
|
-
describe "find_by_uuid" do
|
182
|
-
subject { Repository.new.find_by_uuid(uuid) }
|
183
|
-
|
184
|
-
context "when a webhook is found" do
|
185
|
-
before do
|
186
|
-
Repository.new.create uuid, webhook, consumer, provider
|
187
|
-
end
|
188
|
-
|
189
|
-
it "returns a webhook with the consumer set" do
|
190
|
-
expect(subject.consumer.name).to eq consumer.name
|
191
|
-
end
|
192
|
-
|
193
|
-
it "returns a webhook with the provider set" do
|
194
|
-
expect(subject.provider.name).to eq provider.name
|
195
|
-
end
|
196
|
-
|
197
|
-
it "returns a webhook with the uuid set" do
|
198
|
-
expect(subject.uuid).to eq uuid
|
199
|
-
end
|
200
|
-
|
201
|
-
it "returns a webhook with the body set" do
|
202
|
-
expect(subject.request.body).to eq body
|
203
|
-
end
|
204
|
-
|
205
|
-
it "returns a webhook with the headers set" do
|
206
|
-
expect(subject.request.headers).to eq headers
|
207
|
-
end
|
208
|
-
|
209
|
-
it "returns a webhook with the username set" do
|
210
|
-
expect(subject.request.username).to eq "username"
|
211
|
-
end
|
212
|
-
|
213
|
-
it "returns a webhook with the password set" do
|
214
|
-
expect(subject.request.password).to eq "password"
|
215
|
-
end
|
216
|
-
|
217
|
-
it "returns a webhook with the url set" do
|
218
|
-
expect(subject.request.url).to eq url
|
219
|
-
end
|
220
|
-
|
221
|
-
it "returns a webhook with a created_at date" do
|
222
|
-
expect(subject.created_at).to be_datey
|
223
|
-
end
|
224
|
-
|
225
|
-
it "returns a webhook with a updated_at date" do
|
226
|
-
expect(subject.updated_at).to be_datey
|
227
|
-
end
|
228
|
-
|
229
|
-
context "when the body is a XML string" do
|
230
|
-
let(:body) { "<xml>Why would you do this?</xml>" }
|
231
|
-
|
232
|
-
it "returns the body as the XML String, not an JSON Object" do
|
233
|
-
expect(subject.request.body).to eq body
|
234
|
-
end
|
235
|
-
end
|
236
|
-
|
237
|
-
context "when the optional attributes are nil" do
|
238
|
-
let(:body) { nil }
|
239
|
-
let(:headers) { nil }
|
240
|
-
|
241
|
-
it "does not blow up" do
|
242
|
-
expect(subject.request.body).to eq body
|
243
|
-
expect(subject.request.headers).to eq({})
|
244
|
-
end
|
245
|
-
end
|
246
|
-
end
|
247
|
-
|
248
|
-
context "when a webhook is not found" do
|
249
|
-
it "returns nil" do
|
250
|
-
expect(subject).to be nil
|
251
|
-
end
|
252
|
-
end
|
253
|
-
|
254
|
-
end
|
255
|
-
|
256
|
-
describe "update_by_uuid" do
|
257
|
-
before do
|
258
|
-
td.create_consumer("Foo")
|
259
|
-
.create_provider
|
260
|
-
.create_webhook(old_webhook_params)
|
261
|
-
.create_consumer("Foo2")
|
262
|
-
end
|
263
|
-
|
264
|
-
let(:uuid) { "1234" }
|
265
|
-
let(:old_webhook_params) do
|
266
|
-
{
|
267
|
-
events: [{ name: "something" }],
|
268
|
-
uuid: uuid,
|
269
|
-
method: "POST",
|
270
|
-
url: "http://example.org",
|
271
|
-
body: '{"foo":1}',
|
272
|
-
headers: {"Content-Type" => "application/json"},
|
273
|
-
username: "username",
|
274
|
-
password: "password"
|
275
|
-
}
|
276
|
-
end
|
277
|
-
let(:new_request_webhook_params) do
|
278
|
-
{
|
279
|
-
method: "GET",
|
280
|
-
url: "http://example.com",
|
281
|
-
body: "foo",
|
282
|
-
headers: {"Content-Type" => "text/plain"}
|
283
|
-
}
|
284
|
-
end
|
285
|
-
let(:new_request) { PactBroker::Domain::WebhookRequest.new(new_request_webhook_params) }
|
286
|
-
let(:new_event) do
|
287
|
-
PactBroker::Webhooks::WebhookEvent.new(name: "something_else")
|
288
|
-
end
|
289
|
-
let(:new_consumer) { Domain::WebhookPacticipant.new(name: "Foo2") }
|
290
|
-
let(:new_webhook) do
|
291
|
-
PactBroker::Domain::Webhook.new(
|
292
|
-
consumer: new_consumer,
|
293
|
-
events: [new_event],
|
294
|
-
request: new_request
|
295
|
-
)
|
296
|
-
end
|
297
|
-
|
298
|
-
subject { Repository.new.update_by_uuid(uuid, new_webhook) }
|
299
|
-
|
300
|
-
it "updates the webhook" do
|
301
|
-
expect(subject.uuid).to eq uuid
|
302
|
-
expect(subject.request.method).to eq "GET"
|
303
|
-
expect(subject.request.url).to eq "http://example.com"
|
304
|
-
expect(subject.request.body).to eq "foo"
|
305
|
-
expect(subject.request.headers).to eq "Content-Type" => "text/plain"
|
306
|
-
expect(subject.request.username).to eq nil
|
307
|
-
expect(subject.request.password).to eq nil
|
308
|
-
expect(subject.events.first.name).to eq "something_else"
|
309
|
-
expect(subject.consumer.name).to eq "Foo2"
|
310
|
-
end
|
311
|
-
|
312
|
-
context "when the updated params do not contain a consumer or provider" do
|
313
|
-
let(:new_webhook) do
|
314
|
-
PactBroker::Domain::Webhook.new(
|
315
|
-
events: [new_event],
|
316
|
-
request: new_request
|
317
|
-
)
|
318
|
-
end
|
319
|
-
|
320
|
-
it "removes the existing consumer or provider" do
|
321
|
-
expect(subject.consumer).to be nil
|
322
|
-
end
|
323
|
-
end
|
324
|
-
end
|
325
|
-
|
326
|
-
describe "find_all" do
|
327
|
-
before do
|
328
|
-
allow(PactBroker).to receive(:policy_scope!).and_call_original
|
329
|
-
Repository.new.create uuid, webhook, consumer, provider
|
330
|
-
Repository.new.create "some-other-uuid", webhook, consumer, provider
|
331
|
-
end
|
332
|
-
|
333
|
-
subject { Repository.new.find_all }
|
334
|
-
|
335
|
-
it "returns a list of webhooks" do
|
336
|
-
expect(subject.size).to be 2
|
337
|
-
expect(subject.first).to be_instance_of Domain::Webhook
|
338
|
-
end
|
339
|
-
|
340
|
-
it "uses the policy" do
|
341
|
-
expect(PactBroker).to receive(:policy_scope!)
|
342
|
-
subject
|
343
|
-
end
|
344
|
-
end
|
345
|
-
|
346
|
-
describe "find_by_consumer_and_provider" do
|
347
|
-
let(:consumer) { td.consumer }
|
348
|
-
let(:provider) { td.provider }
|
349
|
-
|
350
|
-
subject { Repository.new.find_by_consumer_and_provider(consumer, provider) }
|
351
|
-
|
352
|
-
context "when a webhook exists with a matching consumer and provider" do
|
353
|
-
before do
|
354
|
-
td.create_consumer("Consumer")
|
355
|
-
.create_provider("Another Provider")
|
356
|
-
.create_webhook
|
357
|
-
.create_provider("Provider")
|
358
|
-
.create_webhook
|
359
|
-
end
|
360
|
-
|
361
|
-
it "returns an array of webhooks" do
|
362
|
-
expect(subject).to be_instance_of Array
|
363
|
-
expect(subject.first.uuid).to eq td.webhook.uuid
|
364
|
-
end
|
365
|
-
end
|
366
|
-
|
367
|
-
context "when a webhook does not exist with a matching consumer and provider" do
|
368
|
-
before do
|
369
|
-
td
|
370
|
-
.create_consumer("Consumer")
|
371
|
-
.create_provider("Provider")
|
372
|
-
.create_webhook
|
373
|
-
.create_provider("Another Provider")
|
374
|
-
end
|
375
|
-
|
376
|
-
it "returns an empty array" do
|
377
|
-
expect(subject).to eq []
|
378
|
-
end
|
379
|
-
end
|
380
|
-
|
381
|
-
context "when the consumer argument is nil" do
|
382
|
-
let(:consumer) { nil }
|
383
|
-
|
384
|
-
before do
|
385
|
-
td.create_provider("Provider")
|
386
|
-
.create_consumer("Consumer")
|
387
|
-
.create_provider_webhook
|
388
|
-
.create_webhook
|
389
|
-
end
|
390
|
-
|
391
|
-
it "returns all the webhooks where the provider matches and the consumer id is nil" do
|
392
|
-
expect(subject.size).to be 1
|
393
|
-
expect(subject.first.consumer).to be nil
|
394
|
-
expect(subject.first.provider).to_not be nil
|
395
|
-
end
|
396
|
-
end
|
397
|
-
|
398
|
-
context "when the provider argument is nil" do
|
399
|
-
let(:provider) { nil }
|
400
|
-
|
401
|
-
before do
|
402
|
-
td.create_consumer("Consumer")
|
403
|
-
.create_provider("Provider")
|
404
|
-
.create_consumer_webhook
|
405
|
-
.create_webhook
|
406
|
-
end
|
407
|
-
|
408
|
-
it "returns all the webhooks where the consumer matches and the provider id is nil" do
|
409
|
-
expect(subject.size).to be 1
|
410
|
-
expect(subject.first.provider).to be nil
|
411
|
-
expect(subject.first.consumer).to_not be nil
|
412
|
-
end
|
413
|
-
end
|
414
|
-
end
|
415
|
-
|
416
|
-
describe "find_webhooks_to_trigger" do
|
417
|
-
before do
|
418
|
-
allow(PactBroker).to receive(:policy_scope!).and_call_original
|
419
|
-
end
|
420
|
-
|
421
|
-
let(:enabled) { true }
|
422
|
-
|
423
|
-
subject { Repository.new.find_webhooks_to_trigger(consumer: td.consumer, provider: td.provider, event_name: "contract_published") }
|
424
|
-
|
425
|
-
it "does not use a policy" do
|
426
|
-
td.create_webhook(event_names: ["contract_published"], enabled: enabled, description: "Enabled webhook")
|
427
|
-
.create_consumer("Foo")
|
428
|
-
.create_provider("Bar")
|
429
|
-
expect(PactBroker).to_not receive(:policy_scope!)
|
430
|
-
is_expected.to contain_exactly(
|
431
|
-
have_attributes(description: "Enabled webhook")
|
432
|
-
)
|
433
|
-
end
|
434
|
-
|
435
|
-
context "when the webhook is disabled" do
|
436
|
-
before do
|
437
|
-
td.create_webhook(event_names: ["contract_published"], enabled: enabled)
|
438
|
-
.create_consumer("Foo")
|
439
|
-
.create_provider("Bar")
|
440
|
-
end
|
441
|
-
let(:enabled) { false }
|
442
|
-
|
443
|
-
it "finds no webhooks to trigger" do
|
444
|
-
is_expected.to be_empty
|
445
|
-
end
|
446
|
-
end
|
447
|
-
|
448
|
-
context "when the webhook is specified for a consumer and all providers" do
|
449
|
-
before do
|
450
|
-
td.create_consumer("Foo1")
|
451
|
-
.create_provider("Bar1")
|
452
|
-
.create_webhook(provider: nil, event_names: ["contract_published"], description: "Right webhook")
|
453
|
-
end
|
454
|
-
|
455
|
-
let(:webhook_consumer) { Domain::WebhookPacticipant.new(name: td.consumer.name) }
|
456
|
-
|
457
|
-
it "finds one webhook to trigger" do
|
458
|
-
is_expected.to contain_exactly(
|
459
|
-
have_attributes(description: "Right webhook")
|
460
|
-
)
|
461
|
-
end
|
462
|
-
end
|
463
|
-
|
464
|
-
context "when the webhook is specified for matching consumer but not provider" do
|
465
|
-
before do
|
466
|
-
td.create_consumer("Foo1")
|
467
|
-
.create_provider("Bar1")
|
468
|
-
.create_webhook(event_names: ["contract_published"])
|
469
|
-
.create_provider("Bar3")
|
470
|
-
end
|
471
|
-
|
472
|
-
it "finds no webhooks to trigger" do
|
473
|
-
is_expected.to be_empty
|
474
|
-
end
|
475
|
-
end
|
476
|
-
|
477
|
-
context "when the webhook is specified for matching consumer label" do
|
478
|
-
before do
|
479
|
-
td.create_webhook(
|
480
|
-
event_names: ["contract_published"],
|
481
|
-
consumer_label: "my_label",
|
482
|
-
description: "Labeled webhook"
|
483
|
-
)
|
484
|
-
.create_consumer("Consumer")
|
485
|
-
.create_label("my_label")
|
486
|
-
.create_provider("Provider")
|
487
|
-
end
|
488
|
-
|
489
|
-
it "finds one webhook to trigger" do
|
490
|
-
is_expected.to contain_exactly(
|
491
|
-
have_attributes(description: "Labeled webhook")
|
492
|
-
)
|
493
|
-
end
|
494
|
-
end
|
495
|
-
|
496
|
-
context "when the webhook is specified for matching consumer label and specific provider" do
|
497
|
-
before do
|
498
|
-
td.create_provider("Provider")
|
499
|
-
.create_webhook(
|
500
|
-
event_names: ["contract_published"],
|
501
|
-
consumer_label: "my_label",
|
502
|
-
description: "Labeled webhook"
|
503
|
-
)
|
504
|
-
.create_consumer("Consumer")
|
505
|
-
.create_label("my_label")
|
506
|
-
end
|
507
|
-
|
508
|
-
it "finds one webhook to trigger" do
|
509
|
-
is_expected.to contain_exactly(
|
510
|
-
have_attributes(description: "Labeled webhook")
|
511
|
-
)
|
512
|
-
end
|
513
|
-
end
|
514
|
-
|
515
|
-
context "when the webhook is specified for consumer label that does not match" do
|
516
|
-
before do
|
517
|
-
td.create_webhook(event_names: ["contract_published"], consumer_label: "my_label")
|
518
|
-
.create_consumer("Consumer")
|
519
|
-
.create_label("other_label")
|
520
|
-
.create_provider("Provider")
|
521
|
-
end
|
522
|
-
|
523
|
-
it "finds no webhooks to trigger" do
|
524
|
-
is_expected.to be_empty
|
525
|
-
end
|
526
|
-
end
|
527
|
-
|
528
|
-
context "when the webhook is specified for matching provider label" do
|
529
|
-
before do
|
530
|
-
td.create_webhook(
|
531
|
-
event_names: ["contract_published"],
|
532
|
-
provider_label: "my_label",
|
533
|
-
description: "Labeled webhook"
|
534
|
-
)
|
535
|
-
.create_consumer("Consumer")
|
536
|
-
.create_provider("Provider")
|
537
|
-
.create_label("my_label")
|
538
|
-
end
|
539
|
-
|
540
|
-
it "finds one webhook to trigger" do
|
541
|
-
is_expected.to contain_exactly(
|
542
|
-
have_attributes(description: "Labeled webhook")
|
543
|
-
)
|
544
|
-
end
|
545
|
-
end
|
546
|
-
|
547
|
-
context "when the webhook is specified for matching provider label and specific consumer" do
|
548
|
-
before do
|
549
|
-
td.create_consumer("Consumer")
|
550
|
-
.create_webhook(
|
551
|
-
event_names: ["contract_published"],
|
552
|
-
provider_label: "my_label",
|
553
|
-
description: "Labeled webhook"
|
554
|
-
)
|
555
|
-
.create_provider("Provider")
|
556
|
-
.create_label("my_label")
|
557
|
-
end
|
558
|
-
|
559
|
-
it "finds one webhook to trigger" do
|
560
|
-
is_expected.to contain_exactly(
|
561
|
-
have_attributes(description: "Labeled webhook")
|
562
|
-
)
|
563
|
-
end
|
564
|
-
end
|
565
|
-
|
566
|
-
context "when the webhook is specified for provider label that does not match" do
|
567
|
-
before do
|
568
|
-
td.create_webhook(event_names: ["contract_published"], provider_label: "my_label")
|
569
|
-
.create_consumer("Consumer")
|
570
|
-
.create_provider("Provider")
|
571
|
-
.create_label("other_label")
|
572
|
-
end
|
573
|
-
|
574
|
-
it "find no webhooks to trigger" do
|
575
|
-
is_expected.to be_empty
|
576
|
-
end
|
577
|
-
end
|
578
|
-
|
579
|
-
context "when the webhook is specified for consumer and provider label" do
|
580
|
-
before do
|
581
|
-
td.create_webhook(
|
582
|
-
event_names: ["contract_published"],
|
583
|
-
consumer_label: "clabel",
|
584
|
-
provider_label: "plabel",
|
585
|
-
description: "Labeled webhook"
|
586
|
-
)
|
587
|
-
.create_webhook(
|
588
|
-
event_names: ["contract_published"],
|
589
|
-
consumer_label: "clabel",
|
590
|
-
provider_label: "plabel2",
|
591
|
-
description: "Labeled consumer webhook"
|
592
|
-
)
|
593
|
-
.create_webhook(
|
594
|
-
event_names: ["contract_published"],
|
595
|
-
consumer_label: "clabel2",
|
596
|
-
provider_label: "plabel",
|
597
|
-
description: "Labeled provider webhook"
|
598
|
-
)
|
599
|
-
.create_consumer("Consumer")
|
600
|
-
.create_label("clabel")
|
601
|
-
.create_provider("Provider")
|
602
|
-
.create_label("plabel")
|
603
|
-
end
|
604
|
-
|
605
|
-
it "finds one webhook to trigger" do
|
606
|
-
is_expected.to contain_exactly(
|
607
|
-
have_attributes(description: "Labeled webhook")
|
608
|
-
)
|
609
|
-
end
|
610
|
-
end
|
611
|
-
end
|
612
|
-
|
613
|
-
describe "create_triggered_webhook" do
|
614
|
-
before do
|
615
|
-
td.create_consumer
|
616
|
-
.create_provider
|
617
|
-
.create_webhook
|
618
|
-
.create_consumer_version
|
619
|
-
.create_pact
|
620
|
-
.create_verification
|
621
|
-
end
|
622
|
-
|
623
|
-
let(:event_context) { { "some" => "info" } }
|
624
|
-
|
625
|
-
subject { Repository.new.create_triggered_webhook "1234", td.webhook, td.pact, td.verification, "publication", "some_event", event_context }
|
626
|
-
|
627
|
-
it "creates a TriggeredWebhook" do
|
628
|
-
expect(subject.webhook_uuid ).to eq td.webhook.uuid
|
629
|
-
expect(subject.consumer).to eq td.consumer
|
630
|
-
expect(subject.provider).to eq td.provider
|
631
|
-
expect(subject.verification).to eq td.verification
|
632
|
-
expect(subject.uuid).to eq "1234"
|
633
|
-
expect(subject.trigger_type).to eq "publication"
|
634
|
-
expect(subject.event_name).to eq "some_event"
|
635
|
-
expect(subject.event_context).to eq event_context
|
636
|
-
end
|
637
|
-
|
638
|
-
it "sets the webhook" do
|
639
|
-
expect(subject.webhook.uuid).to eq td.webhook.uuid
|
640
|
-
end
|
641
|
-
|
642
|
-
it "sets the webhook_uuid" do
|
643
|
-
expect(subject.webhook_uuid).to eq td.webhook.uuid
|
644
|
-
end
|
645
|
-
|
646
|
-
it "sets the consumer" do
|
647
|
-
expect(subject.consumer).to eq td.consumer
|
648
|
-
end
|
649
|
-
|
650
|
-
it "sets the provider" do
|
651
|
-
expect(subject.provider).to eq td.provider
|
652
|
-
end
|
653
|
-
|
654
|
-
it "sets the PactPublication" do
|
655
|
-
expect(subject.pact_publication.id).to eq td.pact.id
|
656
|
-
end
|
657
|
-
|
658
|
-
context "without a verification" do
|
659
|
-
subject { Repository.new.create_triggered_webhook "1234", td.webhook, td.pact, nil, "publication", "some_event", {} }
|
660
|
-
|
661
|
-
it "does not set the verification" do
|
662
|
-
expect(subject.verification).to be nil
|
663
|
-
end
|
664
|
-
end
|
665
|
-
end
|
666
|
-
|
667
|
-
describe "create_execution" do
|
668
|
-
before do
|
669
|
-
td.create_consumer
|
670
|
-
.create_provider
|
671
|
-
.create_consumer_version
|
672
|
-
.create_pact
|
673
|
-
.create_webhook
|
674
|
-
.create_triggered_webhook
|
675
|
-
end
|
676
|
-
|
677
|
-
let(:webhook_domain) { Repository.new.find_by_uuid td.webhook.uuid }
|
678
|
-
let(:webhook_execution_result) { instance_double("PactBroker::Domain::WebhookExecutionResult", success?: true, logs: "logs") }
|
679
|
-
let(:repository) { Repository.new }
|
680
|
-
|
681
|
-
subject { repository.create_execution td.triggered_webhook, webhook_execution_result }
|
682
|
-
|
683
|
-
it "saves a new webhook execution " do
|
684
|
-
expect { subject }.to change { Execution.count }.by(1)
|
685
|
-
end
|
686
|
-
|
687
|
-
it "sets the success" do
|
688
|
-
expect(subject.success).to be true
|
689
|
-
end
|
690
|
-
|
691
|
-
it "sets the logs" do
|
692
|
-
expect(subject.logs).to eq "logs"
|
693
|
-
end
|
694
|
-
|
695
|
-
context "when the triggered webhook has been deleted in the meantime" do
|
696
|
-
before do
|
697
|
-
TriggeredWebhook.where(id: td.triggered_webhook.id).delete
|
698
|
-
allow(repository).to receive(:logger).and_return(logger)
|
699
|
-
end
|
700
|
-
|
701
|
-
let(:logger) { double("logger") }
|
702
|
-
|
703
|
-
it "just logs the error" do
|
704
|
-
expect(logger).to receive(:info).with(/triggered webhook with id #{td.triggered_webhook.id}/)
|
705
|
-
subject
|
706
|
-
end
|
707
|
-
end
|
708
|
-
end
|
709
|
-
|
710
|
-
describe "find_latest_triggered_webhooks" do
|
711
|
-
before do
|
712
|
-
td
|
713
|
-
.create_pact_with_hierarchy("Foo", "1.0.0", "Bar")
|
714
|
-
.create_webhook
|
715
|
-
.create_triggered_webhook
|
716
|
-
.create_webhook_execution
|
717
|
-
.create_pact_with_hierarchy
|
718
|
-
.create_webhook(uuid: "123")
|
719
|
-
.create_triggered_webhook(uuid: "256", created_at: DateTime.new(2016))
|
720
|
-
.create_webhook_execution
|
721
|
-
.create_triggered_webhook(uuid: "332", created_at: DateTime.new(2017))
|
722
|
-
.create_webhook_execution
|
723
|
-
.create_webhook(uuid: "987")
|
724
|
-
.create_triggered_webhook(uuid: "876", created_at: DateTime.new(2017))
|
725
|
-
.create_webhook_execution
|
726
|
-
.create_triggered_webhook(uuid: "638", created_at: DateTime.new(2018))
|
727
|
-
.create_webhook_execution
|
728
|
-
end
|
729
|
-
|
730
|
-
subject { Repository.new.find_latest_triggered_webhooks(td.consumer, td.provider) }
|
731
|
-
|
732
|
-
it "finds the latest triggered webhooks" do
|
733
|
-
expect(subject.collect(&:uuid).sort).to eq ["332", "638"]
|
734
|
-
end
|
735
|
-
|
736
|
-
context "when a webhook has been triggered by different events" do
|
737
|
-
before do
|
738
|
-
td.create_pact_with_hierarchy("Foo2", "1.0.0", "Bar2")
|
739
|
-
.create_webhook
|
740
|
-
.create_triggered_webhook(uuid: "333", event_name: "foo")
|
741
|
-
.create_triggered_webhook(uuid: "555", event_name: "foo")
|
742
|
-
.create_webhook_execution
|
743
|
-
.create_triggered_webhook(uuid: "444", event_name: "bar")
|
744
|
-
.create_triggered_webhook(uuid: "777", event_name: "bar")
|
745
|
-
.create_webhook_execution
|
746
|
-
.create_triggered_webhook(uuid: "111", event_name: nil)
|
747
|
-
.create_triggered_webhook(uuid: "888", event_name: nil)
|
748
|
-
.create_webhook_execution
|
749
|
-
end
|
750
|
-
|
751
|
-
it "returns one for each event" do
|
752
|
-
# ignoring the ones with nil event_names because they're old data, and shouldn't be
|
753
|
-
# considered as a separate "group"
|
754
|
-
expect(subject.collect(&:uuid).sort).to eq ["555", "777"]
|
755
|
-
end
|
756
|
-
end
|
757
|
-
|
758
|
-
context "when there are two 'latest' triggered webhooks at the same time" do
|
759
|
-
before do
|
760
|
-
td.create_triggered_webhook(uuid: "888", created_at: DateTime.new(2018))
|
761
|
-
.create_webhook_execution
|
762
|
-
end
|
763
|
-
|
764
|
-
it "returns the one with the bigger ID" do
|
765
|
-
expect(subject.collect(&:uuid).sort).to eq ["332", "888"]
|
766
|
-
end
|
767
|
-
end
|
768
|
-
|
769
|
-
context "when there are no triggered webhooks for the given consumer and provider" do
|
770
|
-
before do
|
771
|
-
td.create_consumer
|
772
|
-
.create_provider
|
773
|
-
end
|
774
|
-
|
775
|
-
it "returns an empty list" do
|
776
|
-
expect(subject).to be_empty
|
777
|
-
end
|
778
|
-
end
|
779
|
-
end
|
780
|
-
|
781
|
-
describe "find_latest_triggered_webhooks_for_pact" do
|
782
|
-
before do
|
783
|
-
td
|
784
|
-
.create_pact_with_hierarchy("Foo", "1.0.0", "Bar")
|
785
|
-
.create_webhook
|
786
|
-
.create_triggered_webhook
|
787
|
-
.create_webhook_execution
|
788
|
-
.create_pact_with_hierarchy
|
789
|
-
.create_webhook
|
790
|
-
.create_triggered_webhook(uuid: "256", created_at: DateTime.new(2016))
|
791
|
-
.create_webhook_execution
|
792
|
-
.create_triggered_webhook(uuid: "332", created_at: DateTime.new(2017))
|
793
|
-
.create_webhook_execution
|
794
|
-
.create_provider_webhook(uuidd: "987")
|
795
|
-
.create_triggered_webhook(uuid: "876", created_at: DateTime.new(2017))
|
796
|
-
.create_webhook_execution
|
797
|
-
.create_triggered_webhook(uuid: "638", created_at: DateTime.new(2018))
|
798
|
-
.create_webhook_execution
|
799
|
-
.create_consumer_webhook
|
800
|
-
.create_triggered_webhook(uuid: "555", created_at: DateTime.new(2017))
|
801
|
-
.create_webhook_execution
|
802
|
-
.create_triggered_webhook(uuid: "777", created_at: DateTime.new(2018))
|
803
|
-
.create_webhook_execution
|
804
|
-
end
|
805
|
-
|
806
|
-
subject { Repository.new.find_latest_triggered_webhooks_for_pact(td.pact) }
|
807
|
-
|
808
|
-
it "finds the latest triggered webhooks" do
|
809
|
-
expect(subject.collect(&:uuid).sort).to eq ["332", "638", "777"]
|
810
|
-
end
|
811
|
-
end
|
812
|
-
|
813
|
-
describe "find_triggered_webhooks_for_pact" do
|
814
|
-
before do
|
815
|
-
td
|
816
|
-
.create_pact_with_hierarchy("Foo", "1", "Bar")
|
817
|
-
.create_webhook
|
818
|
-
.create_triggered_webhook(uuid: "1")
|
819
|
-
.create_webhook_execution
|
820
|
-
.create_consumer_version("2")
|
821
|
-
.create_pact
|
822
|
-
.create_triggered_webhook(uuid: "2")
|
823
|
-
.create_webhook_execution
|
824
|
-
end
|
825
|
-
|
826
|
-
subject { Repository.new.find_triggered_webhooks_for_pact(td.pact) }
|
827
|
-
|
828
|
-
it "finds the triggered webhooks" do
|
829
|
-
expect(subject.collect(&:uuid).sort).to eq ["2"]
|
830
|
-
end
|
831
|
-
end
|
832
|
-
|
833
|
-
describe "find_triggered_webhooks_for_verification" do
|
834
|
-
before do
|
835
|
-
td
|
836
|
-
.create_pact_with_hierarchy("Foo", "1", "Bar")
|
837
|
-
.create_verification_webhook
|
838
|
-
.create_verification(provider_version: "1")
|
839
|
-
.create_triggered_webhook(uuid: "1")
|
840
|
-
.create_verification(provider_version: "2", number: 2)
|
841
|
-
.create_triggered_webhook(uuid: "2")
|
842
|
-
end
|
843
|
-
|
844
|
-
subject { Repository.new.find_triggered_webhooks_for_verification(td.verification) }
|
845
|
-
|
846
|
-
it "finds the triggered webhooks" do
|
847
|
-
expect(subject.collect(&:uuid).sort).to eq ["2"]
|
848
|
-
end
|
849
|
-
end
|
850
|
-
|
851
|
-
describe "fail_retrying_triggered_webhooks" do
|
852
|
-
before do
|
853
|
-
td.create_pact_with_hierarchy
|
854
|
-
.create_webhook
|
855
|
-
.create_triggered_webhook(status: TriggeredWebhook::STATUS_RETRYING)
|
856
|
-
.create_triggered_webhook(status: TriggeredWebhook::STATUS_SUCCESS)
|
857
|
-
.create_triggered_webhook(status: TriggeredWebhook::STATUS_NOT_RUN)
|
858
|
-
.create_triggered_webhook(status: TriggeredWebhook::STATUS_FAILURE)
|
859
|
-
end
|
860
|
-
|
861
|
-
it "sets the triggered_webhooks with retrying status to failed" do
|
862
|
-
Repository.new.fail_retrying_triggered_webhooks
|
863
|
-
expect(TriggeredWebhook.failed.count).to eq 2
|
864
|
-
expect(TriggeredWebhook.retrying.count).to eq 0
|
865
|
-
expect(TriggeredWebhook.successful.count).to eq 1
|
866
|
-
expect(TriggeredWebhook.not_run.count).to eq 1
|
867
|
-
end
|
868
|
-
end
|
869
|
-
|
870
|
-
describe "delete_triggered_webhooks_by_pact_publication_id" do
|
871
|
-
before do
|
872
|
-
td.create_pact_with_hierarchy
|
873
|
-
.create_webhook
|
874
|
-
.create_triggered_webhook
|
875
|
-
.create_webhook_execution
|
876
|
-
.create_pact_with_hierarchy("A Consumer", "1.2.3", "A Provider")
|
877
|
-
.create_webhook
|
878
|
-
.create_triggered_webhook
|
879
|
-
.create_webhook_execution
|
880
|
-
end
|
881
|
-
|
882
|
-
subject { Repository.new.delete_triggered_webhooks_by_pact_publication_ids [td.pact.id] }
|
883
|
-
|
884
|
-
it "deletes the triggered webhook" do
|
885
|
-
expect { subject }.to change {
|
886
|
-
TriggeredWebhook.count
|
887
|
-
}.by(-1)
|
888
|
-
end
|
889
|
-
|
890
|
-
it "deletes the webhook_execution" do
|
891
|
-
expect { subject }.to change {
|
892
|
-
Execution.exclude(triggered_webhook_id: nil).count
|
893
|
-
}.by(-1)
|
894
|
-
end
|
895
|
-
end
|
896
|
-
|
897
|
-
describe "delete_triggered_webhooks_by_version_id" do
|
898
|
-
subject { Repository.new.delete_triggered_webhooks_by_version_id(version.id) }
|
899
|
-
|
900
|
-
context "when deleting a triggered webhook by consumer version" do
|
901
|
-
let!(:version) do
|
902
|
-
td
|
903
|
-
.create_pact_with_hierarchy
|
904
|
-
.create_webhook
|
905
|
-
.create_triggered_webhook
|
906
|
-
.create_webhook_execution
|
907
|
-
.and_return(:consumer_version)
|
908
|
-
end
|
909
|
-
|
910
|
-
it "deletes the webhooks belonging to the consumer version" do
|
911
|
-
expect { subject }.to change{ TriggeredWebhook.count }.by(-1)
|
912
|
-
end
|
913
|
-
end
|
914
|
-
|
915
|
-
context "when deleting a triggered webhook by provider version" do
|
916
|
-
let!(:version) do
|
917
|
-
td
|
918
|
-
.create_pact_with_hierarchy
|
919
|
-
.create_verification(provider_version: "1")
|
920
|
-
.create_provider_webhook(event_names: ["provider_verification_published"])
|
921
|
-
.create_triggered_webhook
|
922
|
-
.create_webhook_execution
|
923
|
-
.and_return(:provider_version)
|
924
|
-
end
|
925
|
-
|
926
|
-
it "deletes the webhooks belonging to the consumer version" do
|
927
|
-
expect { subject }.to change{ TriggeredWebhook.count }.by(-1)
|
928
|
-
end
|
929
|
-
end
|
930
|
-
end
|
931
|
-
end
|
932
|
-
end
|
933
|
-
end
|