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,141 +0,0 @@
|
|
1
|
-
require "spec_helper"
|
2
|
-
require "pact_broker/api/renderers/html_pact_renderer"
|
3
|
-
require "timecop"
|
4
|
-
|
5
|
-
module PactBroker
|
6
|
-
module Api
|
7
|
-
module Renderers
|
8
|
-
describe HtmlPactRenderer do
|
9
|
-
|
10
|
-
before do
|
11
|
-
ENV["BACKUP_TZ"] = ENV["TZ"]
|
12
|
-
ENV["TZ"] = "Australia/Melbourne"
|
13
|
-
PactBroker.configuration.enable_public_badge_access = true
|
14
|
-
allow(PactBroker::Api::PactBrokerUrls).to receive(:pact_url).with("http://base", pact).and_return(pact_url)
|
15
|
-
allow(PactBroker::Api::PactBrokerUrls).to receive(:matrix_for_pact_url).with(pact, "http://base").and_return(matrix_url)
|
16
|
-
allow_any_instance_of(HtmlPactRenderer).to receive(:logger).and_return(logger)
|
17
|
-
|
18
|
-
Timecop.freeze(created_at + 3)
|
19
|
-
end
|
20
|
-
|
21
|
-
after do
|
22
|
-
ENV["TZ"] = ENV["BACKUP_TZ"]
|
23
|
-
Timecop.return
|
24
|
-
end
|
25
|
-
|
26
|
-
let(:consumer_name) { "Consumer" }
|
27
|
-
let(:provider_name) { "Provider" }
|
28
|
-
let(:consumer_version_number) { "1.2.3" }
|
29
|
-
let(:consumer) { double("consumer", name: consumer_name) }
|
30
|
-
let(:provider) { double("provider", name: provider_name) }
|
31
|
-
let(:consumer_version) { double("consumer version") }
|
32
|
-
let(:created_at) { DateTime.new(2014, 02, 27) }
|
33
|
-
let(:json_content) { load_fixture("renderer_pact.json") }
|
34
|
-
let(:pact) do
|
35
|
-
double("pact",
|
36
|
-
json_content: json_content,
|
37
|
-
consumer_version_number: consumer_version_number,
|
38
|
-
consumer: consumer,
|
39
|
-
provider: provider,
|
40
|
-
consumer_version_tag_names: consumer_version_tag_names,
|
41
|
-
created_at: created_at,
|
42
|
-
consumer_version: consumer_version
|
43
|
-
)
|
44
|
-
end
|
45
|
-
let(:consumer_version_tag_names) { ["prod", "master"] }
|
46
|
-
let(:pact_url) { "/pact/url" }
|
47
|
-
let(:matrix_url) { "/matrix/url" }
|
48
|
-
let(:options) do
|
49
|
-
{
|
50
|
-
base_url: "http://base",
|
51
|
-
badge_url: "http://badge"
|
52
|
-
}
|
53
|
-
end
|
54
|
-
let(:logger) { double("logger").as_null_object }
|
55
|
-
|
56
|
-
subject { HtmlPactRenderer.call(pact, options) }
|
57
|
-
|
58
|
-
describe ".call" do
|
59
|
-
it "renders the pact as HTML" do
|
60
|
-
expect(subject).to include("<html>")
|
61
|
-
expect(subject).to include("</html>")
|
62
|
-
expect(subject).to include("<link rel='stylesheet'")
|
63
|
-
expect(subject).to include("href='http://base/stylesheets/github.css'")
|
64
|
-
expect(subject).to include("<pre><code")
|
65
|
-
expect(subject).to include(""method":")
|
66
|
-
expect(subject).to match(/<h\d>.*Some Consumer/)
|
67
|
-
expect(subject).to match(/<h\d>.*Some Provider/)
|
68
|
-
expect(subject).to include("Date published:")
|
69
|
-
expect(subject).to include("Thu 27 Feb 2014, 11:00am +11:00")
|
70
|
-
expect(subject).to include("3 days ago")
|
71
|
-
expect(subject).to match(/title.*Pact between Consumer and Provider/)
|
72
|
-
expect(subject).to match(/prod, master/)
|
73
|
-
end
|
74
|
-
|
75
|
-
it "renders the badge image" do
|
76
|
-
expect(subject).to include "<img src=\"http://badge\"/>"
|
77
|
-
end
|
78
|
-
|
79
|
-
it "renders a text area with the badge markdown" do
|
80
|
-
expect(subject).to include "<textarea"
|
81
|
-
expect(subject).to include "[![Consumer/Provider Pact Status](http://badge)](http://base)"
|
82
|
-
end
|
83
|
-
|
84
|
-
it "includes the matrix URL" do
|
85
|
-
expect(subject).to include matrix_url
|
86
|
-
end
|
87
|
-
|
88
|
-
context "with dodgey data" do
|
89
|
-
let(:consumer_name) { '<script>alert("consumer");</script>' }
|
90
|
-
let(:provider_name) { '<script>alert("provider");</script>' }
|
91
|
-
let(:consumer_version_number) { '<script>alert("version");</script>' }
|
92
|
-
let(:consumer_version_tag_names) { ['<script>alert("tag");</script>'] }
|
93
|
-
|
94
|
-
it "does not contain the literal <script> anywhere except the badge markdown" do
|
95
|
-
expect(subject).to_not include consumer_version_number
|
96
|
-
expect(subject.scan(consumer_name).count).to eq 1
|
97
|
-
expect(subject.scan(provider_name).count).to eq 1
|
98
|
-
expect(subject).to include '[![<script>alert("consumer");</script>/<script>alert("provider");</script> Pact Status](http://badge)]'
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
|
-
context "when enable_public_badge_access is false" do
|
103
|
-
before do
|
104
|
-
PactBroker.configuration.enable_public_badge_access = false
|
105
|
-
end
|
106
|
-
|
107
|
-
it "renders a message instructing the user to turn public access on" do
|
108
|
-
expect(subject).to include "set `enable_public_badge_access` to true in the configuration"
|
109
|
-
end
|
110
|
-
end
|
111
|
-
|
112
|
-
context "when the content is not a valid pact, but is still JSON" do
|
113
|
-
before do
|
114
|
-
allow(pact).to receive(:content_hash).and_return(content_hash)
|
115
|
-
end
|
116
|
-
|
117
|
-
let(:json_content) { "[1]" }
|
118
|
-
let(:content_hash) { [1] }
|
119
|
-
|
120
|
-
it "includes a dismissive title" do
|
121
|
-
expect(subject).to include "A contract between Consumer and Provider"
|
122
|
-
end
|
123
|
-
|
124
|
-
it "includes a warning" do
|
125
|
-
expect(subject).to include "Note:"
|
126
|
-
end
|
127
|
-
|
128
|
-
it "renders the JSON in HTML" do
|
129
|
-
expect(subject).to match(/\[\s+1\s+\]/m)
|
130
|
-
end
|
131
|
-
|
132
|
-
it "logs a warning" do
|
133
|
-
expect(logger).to receive(:info).with(/Could not parse.*Error/)
|
134
|
-
subject
|
135
|
-
end
|
136
|
-
end
|
137
|
-
end
|
138
|
-
end
|
139
|
-
end
|
140
|
-
end
|
141
|
-
end
|
@@ -1,29 +0,0 @@
|
|
1
|
-
require "pact_broker/api/renderers/integrations_dot_renderer"
|
2
|
-
|
3
|
-
module PactBroker
|
4
|
-
module Api
|
5
|
-
module Renderers
|
6
|
-
describe IntegrationsDotRenderer do
|
7
|
-
|
8
|
-
# TODO work out how to handle apostrophes etc
|
9
|
-
|
10
|
-
let(:integrations) do
|
11
|
-
[
|
12
|
-
double("integration", consumer_name: "Foo", provider_name: "Bar"),
|
13
|
-
double("integration", consumer_name: "Wiffle", provider_name: "Foo Thing")
|
14
|
-
]
|
15
|
-
end
|
16
|
-
|
17
|
-
let(:expected_content) { load_fixture("expected.gv") }
|
18
|
-
|
19
|
-
describe "#call" do
|
20
|
-
subject { IntegrationsDotRenderer.call(integrations) }
|
21
|
-
|
22
|
-
it "renders a dot file" do
|
23
|
-
expect(subject).to eq expected_content
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
@@ -1,145 +0,0 @@
|
|
1
|
-
require "spec_helper"
|
2
|
-
require "pact_broker/api/resources/all_webhooks"
|
3
|
-
|
4
|
-
module PactBroker::Api
|
5
|
-
module Resources
|
6
|
-
describe AllWebhooks do
|
7
|
-
before do
|
8
|
-
allow(PactBroker::Pacticipants::Service).to receive(:find_pacticipant_by_name).with("Some Provider").and_return(provider)
|
9
|
-
allow(PactBroker::Pacticipants::Service).to receive(:find_pacticipant_by_name).with("Some Consumer").and_return(consumer)
|
10
|
-
allow(Decorators::WebhookDecorator).to receive(:new).and_return(webhook_decorator)
|
11
|
-
end
|
12
|
-
|
13
|
-
let(:webhook_service) { PactBroker::Webhooks::Service }
|
14
|
-
let(:uuid) { "1483234k24DKFGJ45K" }
|
15
|
-
let(:path) { "/webhooks" }
|
16
|
-
let(:headers) { {"CONTENT_TYPE" => "application/json"} }
|
17
|
-
let(:webhook) { double("webhook", consumer: parsed_consumer, provider: parsed_provider) }
|
18
|
-
let(:parsed_provider) { instance_double(PactBroker::Domain::Pacticipant, name: "Some Provider") }
|
19
|
-
let(:parsed_consumer) { instance_double(PactBroker::Domain::Pacticipant, name: "Some Consumer") }
|
20
|
-
let(:consumer) { double("consumer", name: "Some Consumer") }
|
21
|
-
let(:provider) { double("provider", name: "Some Provider") }
|
22
|
-
let(:saved_webhook) { double("saved_webhook")}
|
23
|
-
let(:webhook_decorator) { instance_double(Decorators::WebhookDecorator, from_json: webhook) }
|
24
|
-
|
25
|
-
describe "POST" do
|
26
|
-
before do
|
27
|
-
allow(webhook_service).to receive(:create).and_return(saved_webhook)
|
28
|
-
allow(webhook_service).to receive(:next_uuid).and_return(next_uuid)
|
29
|
-
allow(webhook_service).to receive(:errors).and_return(errors)
|
30
|
-
allow(PactBroker::Domain::Webhook).to receive(:new).and_return(webhook)
|
31
|
-
end
|
32
|
-
|
33
|
-
let(:webhook_json) do
|
34
|
-
{
|
35
|
-
some: "json"
|
36
|
-
}.to_json
|
37
|
-
end
|
38
|
-
|
39
|
-
let(:next_uuid) { "123k2nvkkwjrwk34" }
|
40
|
-
let(:valid) { true }
|
41
|
-
let(:errors) { double("errors", empty?: valid, messages: ["messages"]) }
|
42
|
-
|
43
|
-
subject { post path, webhook_json, headers }
|
44
|
-
|
45
|
-
context "with malformed JSON" do
|
46
|
-
let(:webhook_json) { "{" }
|
47
|
-
|
48
|
-
it "returns a 400 error" do
|
49
|
-
subject
|
50
|
-
expect(last_response.status).to eq 400
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
context "with invalid attributes" do
|
55
|
-
let(:valid) { false }
|
56
|
-
|
57
|
-
it "returns a 400" do
|
58
|
-
subject
|
59
|
-
expect(last_response.status).to be 400
|
60
|
-
end
|
61
|
-
|
62
|
-
it "returns a HAL JSON content type" do
|
63
|
-
subject
|
64
|
-
expect(last_response.headers["Content-Type"]).to eq "application/hal+json;charset=utf-8"
|
65
|
-
end
|
66
|
-
|
67
|
-
it "returns the validation errors" do
|
68
|
-
subject
|
69
|
-
expect(JSON.parse(last_response.body, symbolize_names: true)).to eq errors: ["messages"]
|
70
|
-
end
|
71
|
-
|
72
|
-
end
|
73
|
-
|
74
|
-
context "with valid attributes" do
|
75
|
-
before do
|
76
|
-
allow_any_instance_of(Decorators::WebhookDecorator).to receive(:to_json).and_return(webhook_response_json)
|
77
|
-
allow(webhook_decorator).to receive(:to_json).and_return(webhook_response_json)
|
78
|
-
end
|
79
|
-
|
80
|
-
let(:webhook_response_json) { { some: "webhook" }.to_json }
|
81
|
-
|
82
|
-
it "saves the webhook" do
|
83
|
-
expect(webhook_service).to receive(:create).with(next_uuid, webhook, consumer, provider)
|
84
|
-
subject
|
85
|
-
end
|
86
|
-
|
87
|
-
it "returns a 201 response" do
|
88
|
-
subject
|
89
|
-
expect(last_response.status).to be 201
|
90
|
-
end
|
91
|
-
|
92
|
-
it "returns the Location header" do
|
93
|
-
subject
|
94
|
-
expect(last_response.headers["Location"]).to include(next_uuid)
|
95
|
-
end
|
96
|
-
|
97
|
-
it "returns a HAL JSON content type" do
|
98
|
-
subject
|
99
|
-
expect(last_response.headers["Content-Type"]).to eq "application/hal+json;charset=utf-8"
|
100
|
-
end
|
101
|
-
|
102
|
-
it "generates the JSON response body" do
|
103
|
-
expect(Decorators::WebhookDecorator).to receive(:new).with(saved_webhook).and_return(webhook_decorator)
|
104
|
-
expect(webhook_decorator).to receive(:to_json).with(user_options: hash_including({ base_url: "http://example.org" }))
|
105
|
-
subject
|
106
|
-
end
|
107
|
-
|
108
|
-
it "returns the JSON representation of the webhook" do
|
109
|
-
subject
|
110
|
-
expect(last_response.body).to eq webhook_response_json
|
111
|
-
end
|
112
|
-
end
|
113
|
-
end
|
114
|
-
|
115
|
-
describe "GET" do
|
116
|
-
subject { get "/webhooks" }
|
117
|
-
|
118
|
-
let(:webhooks) { [double("webhook")]}
|
119
|
-
let(:decorator) { double(Decorators::WebhooksDecorator, to_json: json)}
|
120
|
-
let(:json) { {some: "json"}.to_json }
|
121
|
-
|
122
|
-
before do
|
123
|
-
allow(Decorators::WebhooksDecorator).to receive(:new).and_return(decorator)
|
124
|
-
allow(PactBroker::Webhooks::Service).to receive(:find_all).and_return(webhooks)
|
125
|
-
end
|
126
|
-
|
127
|
-
it "returns a 200 HAL JSON response" do
|
128
|
-
subject
|
129
|
-
expect(last_response).to be_a_hal_json_success_response
|
130
|
-
end
|
131
|
-
|
132
|
-
it "generates a JSON representation of the webhook" do
|
133
|
-
expect(Decorators::WebhooksDecorator).to receive(:new).with(webhooks)
|
134
|
-
expect(decorator).to receive(:to_json).with(user_options: instance_of(Decorators::DecoratorContext))
|
135
|
-
subject
|
136
|
-
end
|
137
|
-
|
138
|
-
it "includes the JSON representation in the response body" do
|
139
|
-
subject
|
140
|
-
expect(last_response.body).to eq json
|
141
|
-
end
|
142
|
-
end
|
143
|
-
end
|
144
|
-
end
|
145
|
-
end
|
@@ -1,212 +0,0 @@
|
|
1
|
-
require "pact_broker/api/resources/badge"
|
2
|
-
require "pact_broker/badges/service"
|
3
|
-
require "pact_broker/matrix/service"
|
4
|
-
|
5
|
-
module PactBroker
|
6
|
-
module Api
|
7
|
-
module Resources
|
8
|
-
describe Badge do
|
9
|
-
let(:path) { "/pacts/provider/provider/consumer/consumer/latest/badge" }
|
10
|
-
let(:params) { {} }
|
11
|
-
|
12
|
-
before do
|
13
|
-
allow(PactBroker::Pacts::Service).to receive(:find_latest_pact).and_return(pact)
|
14
|
-
allow(PactBroker::Verifications::Service).to receive(:find_latest_verification_for).and_return(verification)
|
15
|
-
allow(PactBroker::Badges::Service).to receive(:pact_verification_badge).and_return("badge")
|
16
|
-
allow(PactBroker::Badges::Service).to receive(:pact_verification_badge_url).and_return("http://badge")
|
17
|
-
allow(PactBroker::Verifications::PseudoBranchStatus).to receive(:new).and_return(pseudo_branch_verification_status)
|
18
|
-
allow(PactBroker::Badges::Service).to receive(:can_provide_badge_using_redirect?).and_return(false)
|
19
|
-
end
|
20
|
-
|
21
|
-
let(:pact) { instance_double("PactBroker::Domain::Pact", consumer: consumer, provider: provider, consumer_version_number: "2", revision_number: "1") }
|
22
|
-
let(:consumer) { double("consumer") }
|
23
|
-
let(:provider) { double("provider") }
|
24
|
-
let(:verification) { double("verification", provider_version_number: "3", number: "7") }
|
25
|
-
let(:pseudo_branch_verification_status) { instance_double("PactBroker::Verifications::PseudoBranchStatus", to_sym: :verified) }
|
26
|
-
|
27
|
-
subject { get path, params, {"HTTP_ACCEPT" => "image/svg+xml"}; last_response }
|
28
|
-
|
29
|
-
context "when enable_public_badge_access is false and the request is not authenticated" do
|
30
|
-
before do
|
31
|
-
PactBroker.configuration.enable_public_badge_access = false
|
32
|
-
allow_any_instance_of(Badge).to receive(:authenticated?).and_return(false)
|
33
|
-
end
|
34
|
-
|
35
|
-
it "returns a 401" do
|
36
|
-
expect(subject.status).to eq 401
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
context "when enable_public_badge_access is false but the request is authenticated" do
|
41
|
-
before do
|
42
|
-
PactBroker.configuration.enable_public_badge_access = false
|
43
|
-
allow_any_instance_of(Badge).to receive(:authenticated?).and_return(true)
|
44
|
-
end
|
45
|
-
|
46
|
-
it "returns a 200" do
|
47
|
-
expect(subject.status).to eq 200
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
context "when enable_public_badge_access is true" do
|
52
|
-
before do
|
53
|
-
PactBroker.configuration.enable_public_badge_access = true
|
54
|
-
end
|
55
|
-
|
56
|
-
it "retrieves the latest pact" do
|
57
|
-
expect(PactBroker::Pacts::Service).to receive(:find_latest_pact)
|
58
|
-
subject
|
59
|
-
end
|
60
|
-
|
61
|
-
it "retrieves the latest verification for the pact's consumer and provider" do
|
62
|
-
expect(PactBroker::Verifications::Service).to receive(:find_latest_verification_for).with(consumer, provider, nil)
|
63
|
-
subject
|
64
|
-
end
|
65
|
-
|
66
|
-
context "when the pact is not found" do
|
67
|
-
let(:pact) { nil }
|
68
|
-
|
69
|
-
it "does not retrieve the latest verification" do
|
70
|
-
expect(PactBroker::Verifications::Service).to_not receive(:find_latest_verification_for)
|
71
|
-
subject
|
72
|
-
end
|
73
|
-
end
|
74
|
-
|
75
|
-
it "determines the pact's verification status based on the latest pact and latest verification" do
|
76
|
-
expect(PactBroker::Verifications::PseudoBranchStatus).to receive(:new).with(pact, verification)
|
77
|
-
subject
|
78
|
-
end
|
79
|
-
|
80
|
-
context "when can_provide_badge_using_redirect? is false" do
|
81
|
-
before do
|
82
|
-
allow(PactBroker::Badges::Service).to receive(:can_provide_badge_using_redirect?).and_return(false)
|
83
|
-
end
|
84
|
-
|
85
|
-
it "creates a badge" do
|
86
|
-
expect(PactBroker::Badges::Service).to receive(:pact_verification_badge).with(pact, nil, false, :verified, {})
|
87
|
-
subject
|
88
|
-
end
|
89
|
-
|
90
|
-
it "returns a 200 status" do
|
91
|
-
expect(subject.status).to eq 200
|
92
|
-
end
|
93
|
-
|
94
|
-
it "does not allow caching" do
|
95
|
-
expect(subject.headers["Cache-Control"]).to eq "no-cache"
|
96
|
-
end
|
97
|
-
|
98
|
-
it "returns the badge" do
|
99
|
-
expect(subject.body).to end_with "badge"
|
100
|
-
end
|
101
|
-
|
102
|
-
it "returns a comment with the consumer and provider numbers" do
|
103
|
-
expect(subject.body).to include "<!-- consumer version 2 revision 1 provider version 3 number 7 -->"
|
104
|
-
end
|
105
|
-
end
|
106
|
-
|
107
|
-
context "when can_provide_badge_using_redirect? is true" do
|
108
|
-
before do
|
109
|
-
allow(PactBroker::Badges::Service).to receive(:can_provide_badge_using_redirect?).and_return(true)
|
110
|
-
end
|
111
|
-
|
112
|
-
it "determines the URL of the badge to redirect to" do
|
113
|
-
expect(PactBroker::Badges::Service).to receive(:pact_verification_badge_url).with(pact, nil, false, :verified, {})
|
114
|
-
subject
|
115
|
-
end
|
116
|
-
|
117
|
-
it "returns a 301 redirect to the badge URL" do
|
118
|
-
expect(subject.status).to eq 307
|
119
|
-
expect(subject.headers["Location"]).to eq "http://badge"
|
120
|
-
expect(subject.headers["Cache-Control"]).to eq "no-cache"
|
121
|
-
end
|
122
|
-
end
|
123
|
-
|
124
|
-
context "when the label param is specified" do
|
125
|
-
let(:params) { {label: "consumer"} }
|
126
|
-
|
127
|
-
it "creates a badge with the specified label" do
|
128
|
-
expect(PactBroker::Badges::Service).to receive(:pact_verification_badge).with(anything, "consumer", anything, anything, {})
|
129
|
-
subject
|
130
|
-
end
|
131
|
-
end
|
132
|
-
|
133
|
-
context "when the initials param is true" do
|
134
|
-
let(:params) { {initials: "true"} }
|
135
|
-
|
136
|
-
it "creates a badge with initials" do
|
137
|
-
expect(PactBroker::Badges::Service).to receive(:pact_verification_badge).with(anything, anything, true, anything, {})
|
138
|
-
subject
|
139
|
-
end
|
140
|
-
end
|
141
|
-
|
142
|
-
context "when the pact is not found" do
|
143
|
-
let(:pact) { nil }
|
144
|
-
|
145
|
-
it "returns a 200 status" do
|
146
|
-
expect(subject.status).to eq 200
|
147
|
-
end
|
148
|
-
end
|
149
|
-
|
150
|
-
context "when retrieving the badge for the latest pact with a tag" do
|
151
|
-
let(:path) { "/pacts/provider/provider/consumer/consumer/latest/prod/badge" }
|
152
|
-
|
153
|
-
it "retrieves the latest verification for the pact's consumer and provider and specified tag" do
|
154
|
-
expect(PactBroker::Verifications::Service).to receive(:find_latest_verification_for).with(anything, anything, "prod")
|
155
|
-
subject
|
156
|
-
end
|
157
|
-
end
|
158
|
-
|
159
|
-
context "when retrieving the badge for a matrix row by tag" do
|
160
|
-
before do
|
161
|
-
allow(PactBroker::Matrix::Service).to receive(:find_for_consumer_and_provider_with_tags).and_return(row)
|
162
|
-
allow(PactBroker::Verifications::Service).to receive(:find_by_id).and_return(verification)
|
163
|
-
end
|
164
|
-
|
165
|
-
let(:path) { "/matrix/provider/provider/latest/master/consumer/consumer/latest/prod/badge" }
|
166
|
-
let(:row) { { consumer_name: "consumer", provider_name: "provider" } }
|
167
|
-
|
168
|
-
context "when a pact is found" do
|
169
|
-
it "looks up the verification" do
|
170
|
-
expect(PactBroker::Verifications::Service).to receive(:find_latest_verification_for_tags) do | consumer, provider, tag|
|
171
|
-
expect(consumer.name).to eq "consumer"
|
172
|
-
expect(provider.name).to eq "provider"
|
173
|
-
expect(tag).to eq "prod"
|
174
|
-
end
|
175
|
-
subject
|
176
|
-
end
|
177
|
-
|
178
|
-
context "when a verification is found" do
|
179
|
-
before do
|
180
|
-
allow(PactBroker::Verifications::Service).to receive(:find_latest_verification_for_tags).and_return(verification)
|
181
|
-
end
|
182
|
-
|
183
|
-
it "returns the badge" do
|
184
|
-
expect(subject.body).to end_with "badge"
|
185
|
-
end
|
186
|
-
end
|
187
|
-
|
188
|
-
context "when a verification is not found" do
|
189
|
-
before do
|
190
|
-
allow(PactBroker::Verifications::Service).to receive(:find_latest_verification_for_tags).and_return(nil)
|
191
|
-
end
|
192
|
-
|
193
|
-
it "returns the badge" do
|
194
|
-
expect(subject.body).to end_with "badge"
|
195
|
-
end
|
196
|
-
end
|
197
|
-
end
|
198
|
-
|
199
|
-
context "when a pact is not found" do
|
200
|
-
let(:pact) { nil }
|
201
|
-
|
202
|
-
it "does not look up the verification" do
|
203
|
-
expect(PactBroker::Verifications::Service).to_not receive(:find_latest_verification_for_tags)
|
204
|
-
subject
|
205
|
-
end
|
206
|
-
end
|
207
|
-
end
|
208
|
-
end
|
209
|
-
end
|
210
|
-
end
|
211
|
-
end
|
212
|
-
end
|
@@ -1,80 +0,0 @@
|
|
1
|
-
require "pact_broker/api/resources/can_i_deploy_badge"
|
2
|
-
|
3
|
-
module PactBroker
|
4
|
-
module Api
|
5
|
-
module Resources
|
6
|
-
describe CanIDeployBadge do
|
7
|
-
before do
|
8
|
-
allow_any_instance_of(described_class).to receive(:badge_service).and_return(badge_service)
|
9
|
-
allow_any_instance_of(described_class).to receive(:matrix_service).and_return(matrix_service)
|
10
|
-
allow_any_instance_of(described_class).to receive(:pacticipant_service).and_return(pacticipant_service)
|
11
|
-
allow_any_instance_of(described_class).to receive(:version_service).and_return(version_service)
|
12
|
-
allow(badge_service).to receive(:can_i_deploy_badge_url).and_return("http://badge")
|
13
|
-
allow(badge_service).to receive(:error_badge_url).and_return("http://error")
|
14
|
-
allow(matrix_service).to receive(:can_i_deploy).and_return(results)
|
15
|
-
allow(pacticipant_service).to receive(:find_pacticipant_by_name).and_return(pacticipant)
|
16
|
-
allow(version_service).to receive(:find_by_pacticipant_name_and_latest_tag).and_return(version)
|
17
|
-
allow(PactBroker.configuration).to receive(:show_backtrace_in_error_response?).and_return(false)
|
18
|
-
allow(PactBroker::Errors).to receive(:generate_error_reference).and_return("abcd")
|
19
|
-
end
|
20
|
-
|
21
|
-
let(:pacticipant_service) { class_double("PactBroker::Pacticipant::Service").as_stubbed_const }
|
22
|
-
let(:badge_service) { class_double("PactBroker::Badges::Service").as_stubbed_const }
|
23
|
-
let(:matrix_service) { class_double("PactBroker::Matrix::Service").as_stubbed_const }
|
24
|
-
let(:version_service) { class_double("PactBroker::Version::Service").as_stubbed_const }
|
25
|
-
let(:results) { double("results", deployable?: true) }
|
26
|
-
let(:pacticipant) { double("pacticipant") }
|
27
|
-
let(:version) { double("version") }
|
28
|
-
|
29
|
-
let(:path) { "/pacticipants/Foo/latest-version/main/can-i-deploy/to/prod/badge"}
|
30
|
-
|
31
|
-
subject { get(path) }
|
32
|
-
|
33
|
-
context "when the pacticipant exists" do
|
34
|
-
it "returns a redirect to the badge" do
|
35
|
-
expect(badge_service).to receive(:can_i_deploy_badge_url).with("main", "prod", nil, true)
|
36
|
-
expect(subject.status).to eq 307
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
context "when the pacticipant does not exist" do
|
41
|
-
let(:pacticipant) { nil }
|
42
|
-
|
43
|
-
it "returns a redirect to a 'not found' badge" do
|
44
|
-
expect(badge_service).to receive(:error_badge_url).with("Foo", "not found")
|
45
|
-
expect(subject.status).to eq 307
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
context "when the version does not exist" do
|
50
|
-
let(:version) { nil }
|
51
|
-
|
52
|
-
it "returns a redirect to a 'not found' badge" do
|
53
|
-
expect(badge_service).to receive(:error_badge_url).with("version", "not found")
|
54
|
-
expect(subject.status).to eq 307
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
context "with a custom label" do
|
59
|
-
subject { get(path, label: "some custom label") }
|
60
|
-
|
61
|
-
it "returns a redirect to a badge with a custom label" do
|
62
|
-
expect(badge_service).to receive(:can_i_deploy_badge_url).with("main", "prod", "some custom label", true)
|
63
|
-
subject
|
64
|
-
end
|
65
|
-
end
|
66
|
-
|
67
|
-
context "when there is an error" do
|
68
|
-
before do
|
69
|
-
allow(matrix_service).to receive(:can_i_deploy).and_raise("foo error")
|
70
|
-
end
|
71
|
-
|
72
|
-
it "returns a redirect to a badge with an error message" do
|
73
|
-
expect(badge_service).to receive(:error_badge_url).with("error", "reference: abcd")
|
74
|
-
expect(subject.status).to eq 307
|
75
|
-
end
|
76
|
-
end
|
77
|
-
end
|
78
|
-
end
|
79
|
-
end
|
80
|
-
end
|
@@ -1,31 +0,0 @@
|
|
1
|
-
require "pact_broker/api/resources/can_i_deploy_pacticipant_version"
|
2
|
-
require "pact_broker/matrix/service"
|
3
|
-
|
4
|
-
module PactBroker
|
5
|
-
module Api
|
6
|
-
module Resources
|
7
|
-
describe CanIDeployPacticipantVersion do
|
8
|
-
include_context "stubbed services"
|
9
|
-
|
10
|
-
before do
|
11
|
-
allow(PactBroker::Matrix::Service).to receive(:can_i_deploy).and_return([])
|
12
|
-
allow(pacticipant_service).to receive(:find_pacticipant_by_name).and_return(pacticipant)
|
13
|
-
allow(version_service).to receive(:find_by_pacticipant_name_and_latest_tag).and_return(version)
|
14
|
-
allow(PactBroker::Api::Decorators::MatrixDecorator).to receive(:new).and_return(decorator)
|
15
|
-
end
|
16
|
-
|
17
|
-
let(:pacticipant) { double("pacticipant") }
|
18
|
-
let(:version) { double("version") }
|
19
|
-
let(:path) { "/pacticipants/Foo/latest-version/main/can-i-deploy/to/prod" }
|
20
|
-
let(:json_response_body) { JSON.parse(subject.body, symbolize_names: true) }
|
21
|
-
let(:decorator) { double("decorator", to_json: "response_body") }
|
22
|
-
let(:selectors) { double("selectors") }
|
23
|
-
let(:options) { double("options") }
|
24
|
-
|
25
|
-
subject { get(path, nil, "Content-Type" => "application/hal+json") }
|
26
|
-
|
27
|
-
it { is_expected.to be_a_hal_json_success_response }
|
28
|
-
end
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|