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,1079 +0,0 @@
|
|
1
|
-
# Yes, I know this file is too bug, but cmd+shift+t is too useful!
|
2
|
-
|
3
|
-
require "pact_broker/pacts/repository"
|
4
|
-
require "pact_broker/pacts/pact_params"
|
5
|
-
require "pact_broker/versions/repository"
|
6
|
-
require "pact_broker/pacticipants/repository"
|
7
|
-
|
8
|
-
module PactBroker
|
9
|
-
module Pacts
|
10
|
-
describe Repository do
|
11
|
-
|
12
|
-
let(:consumer_name) { "Consumer" }
|
13
|
-
let(:provider_name) { "Provider" }
|
14
|
-
|
15
|
-
describe "create" do
|
16
|
-
let(:consumer) { Pacticipants::Repository.new.create name: "Consumer" }
|
17
|
-
let(:provider) { Pacticipants::Repository.new.create name: "Provider" }
|
18
|
-
let(:version) { PactBroker::Versions::Repository.new.create number: "1.2.3", pacticipant_id: consumer.id }
|
19
|
-
let(:pact_version_sha) { "123" }
|
20
|
-
let(:json_content) { { interactions: ["json"] }.to_json }
|
21
|
-
|
22
|
-
let(:params) do
|
23
|
-
{
|
24
|
-
version_id: version.id,
|
25
|
-
consumer_id: consumer.id,
|
26
|
-
provider_id: provider.id,
|
27
|
-
json_content: json_content,
|
28
|
-
pact_version_sha: pact_version_sha,
|
29
|
-
version: version
|
30
|
-
}
|
31
|
-
end
|
32
|
-
|
33
|
-
subject { Repository.new.create(params) }
|
34
|
-
|
35
|
-
it "saves the pact" do
|
36
|
-
expect{ subject }.to change{ PactPublication.count }.by(1)
|
37
|
-
end
|
38
|
-
|
39
|
-
it "sets the consumer_id" do
|
40
|
-
subject
|
41
|
-
expect(PactPublication.first.consumer_id).to eq consumer.id
|
42
|
-
end
|
43
|
-
|
44
|
-
it "returns a Pact::Model" do
|
45
|
-
expect(subject).to be_instance_of(PactBroker::Domain::Pact)
|
46
|
-
end
|
47
|
-
|
48
|
-
it "sets all the Pact::Model attributes" do
|
49
|
-
expect(subject.consumer).to eq consumer
|
50
|
-
expect(subject.provider).to eq provider
|
51
|
-
expect(subject.consumer_version_number).to eq "1.2.3"
|
52
|
-
expect(subject.consumer_version.number).to eq "1.2.3"
|
53
|
-
expect(subject.json_content).to eq json_content
|
54
|
-
expect(subject.created_at).to be_datey
|
55
|
-
end
|
56
|
-
|
57
|
-
it "creates a LatestPactPublicationIdForConsumerVersion" do
|
58
|
-
expect{ subject }.to change { LatestPactPublicationIdForConsumerVersion.count }.by(1)
|
59
|
-
end
|
60
|
-
|
61
|
-
it "sets the created_at of the LatestPactPublicationIdForConsumerVersion to the same as the consumer version, because that's how pacts are ordered" do
|
62
|
-
subject
|
63
|
-
expect(LatestPactPublicationIdForConsumerVersion.first.created_at).to eq PactBroker::Domain::Version.find(number: subject.consumer_version_number).created_at
|
64
|
-
end
|
65
|
-
|
66
|
-
it "sets the interactions count" do
|
67
|
-
subject
|
68
|
-
expect(PactVersion.order(:id).last.interactions_count).to eq 1
|
69
|
-
end
|
70
|
-
|
71
|
-
it "sets the messages count" do
|
72
|
-
subject
|
73
|
-
expect(PactVersion.order(:id).last.messages_count).to eq 0
|
74
|
-
end
|
75
|
-
|
76
|
-
context "when a pact already exists with exactly the same content" do
|
77
|
-
let(:another_version) { Versions::Repository.new.create number: "2.0.0", pacticipant_id: consumer.id }
|
78
|
-
|
79
|
-
before do
|
80
|
-
Repository.new.create(
|
81
|
-
version_id: version.id,
|
82
|
-
consumer_id: consumer.id,
|
83
|
-
provider_id: provider.id,
|
84
|
-
json_content: json_content,
|
85
|
-
pact_version_sha: pact_version_sha,
|
86
|
-
version: version
|
87
|
-
)
|
88
|
-
end
|
89
|
-
|
90
|
-
subject do
|
91
|
-
Repository.new.create(
|
92
|
-
version_id: another_version.id,
|
93
|
-
consumer_id: consumer.id,
|
94
|
-
provider_id: provider.id,
|
95
|
-
json_content: json_content,
|
96
|
-
pact_version_sha: pact_version_sha,
|
97
|
-
version: another_version
|
98
|
-
)
|
99
|
-
end
|
100
|
-
|
101
|
-
it "does not the content" do
|
102
|
-
expect_any_instance_of(Content).to_not receive(:sort)
|
103
|
-
subject
|
104
|
-
end
|
105
|
-
|
106
|
-
it "creates a new PactPublication" do
|
107
|
-
expect { subject }.to change{ PactPublication.count }.by(1)
|
108
|
-
end
|
109
|
-
|
110
|
-
it "reuses the same PactVersion to save room" do
|
111
|
-
expect { subject }.to_not change{ PactVersion.count }
|
112
|
-
end
|
113
|
-
|
114
|
-
context "when there is a race condition and the pact version gets created by another request in between attempting to find and create" do
|
115
|
-
before do
|
116
|
-
allow(PactVersion).to receive(:find).and_return(nil)
|
117
|
-
end
|
118
|
-
|
119
|
-
it "doesn't blow up" do
|
120
|
-
expect(PactVersion).to receive(:find)
|
121
|
-
subject
|
122
|
-
end
|
123
|
-
end
|
124
|
-
end
|
125
|
-
|
126
|
-
context "when base_equality_only_on_content_that_affects_verification_results is true" do
|
127
|
-
let(:another_version) { Versions::Repository.new.create number: "2.0.0", pacticipant_id: consumer.id }
|
128
|
-
let(:sha_1) { "1" }
|
129
|
-
let(:sha_2) { "1" }
|
130
|
-
|
131
|
-
before do
|
132
|
-
# PactBroker.configuration.base_equality_only_on_content_that_affects_verification_results = true
|
133
|
-
# allow(PactBroker.configuration.sha_generator).to receive(:call).and_return(sha_1, sha_2)
|
134
|
-
Repository.new.create(
|
135
|
-
version_id: version.id,
|
136
|
-
consumer_id: consumer.id,
|
137
|
-
provider_id: provider.id,
|
138
|
-
json_content: json_content,
|
139
|
-
pact_version_sha: sha_1,
|
140
|
-
version: version
|
141
|
-
)
|
142
|
-
end
|
143
|
-
|
144
|
-
subject do
|
145
|
-
Repository.new.create(
|
146
|
-
version_id: another_version.id,
|
147
|
-
consumer_id: consumer.id,
|
148
|
-
provider_id: provider.id,
|
149
|
-
json_content: json_content,
|
150
|
-
pact_version_sha: sha_2,
|
151
|
-
version: another_version
|
152
|
-
)
|
153
|
-
end
|
154
|
-
|
155
|
-
context "when the sha is the same" do
|
156
|
-
it "reuses the same PactVersion to save room" do
|
157
|
-
expect { subject }.to_not change{ PactVersion.count }
|
158
|
-
end
|
159
|
-
end
|
160
|
-
|
161
|
-
context "when the sha is not the same" do
|
162
|
-
let(:sha_2) { "2" }
|
163
|
-
|
164
|
-
it "creates a new PactVersion" do
|
165
|
-
expect { subject }.to change{ PactVersion.count }.by(1)
|
166
|
-
end
|
167
|
-
end
|
168
|
-
end
|
169
|
-
|
170
|
-
context "when a pact already exists with the same content but with a different consumer/provider" do
|
171
|
-
let(:another_version) { Versions::Repository.new.create number: "2.0.0", pacticipant_id: consumer.id }
|
172
|
-
let(:another_provider) { Pacticipants::Repository.new.create name: "Provider2" }
|
173
|
-
before do
|
174
|
-
Repository.new.create(
|
175
|
-
version_id: version.id,
|
176
|
-
consumer_id: consumer.id,
|
177
|
-
provider_id: another_provider.id,
|
178
|
-
json_content: json_content,
|
179
|
-
pact_version_sha: pact_version_sha,
|
180
|
-
version: version
|
181
|
-
)
|
182
|
-
end
|
183
|
-
|
184
|
-
subject do
|
185
|
-
Repository.new.create(
|
186
|
-
version_id: another_version.id,
|
187
|
-
consumer_id: consumer.id,
|
188
|
-
provider_id: provider.id,
|
189
|
-
json_content: json_content,
|
190
|
-
pact_version_sha: pact_version_sha,
|
191
|
-
version: another_version
|
192
|
-
)
|
193
|
-
end
|
194
|
-
|
195
|
-
it "does not reuse the same PactVersion" do
|
196
|
-
expect { subject }.to change{ PactVersion.count }.by(1)
|
197
|
-
end
|
198
|
-
end
|
199
|
-
|
200
|
-
context "when a pact already exists with different content" do
|
201
|
-
let(:another_version) { Versions::Repository.new.create number: "2.0.0", pacticipant_id: consumer.id }
|
202
|
-
|
203
|
-
before do
|
204
|
-
Repository.new.create(
|
205
|
-
version_id: version.id,
|
206
|
-
consumer_id: consumer.id,
|
207
|
-
provider_id: provider.id,
|
208
|
-
json_content: {some_other: "json_content"}.to_json,
|
209
|
-
pact_version_sha: pact_version_sha,
|
210
|
-
version: version
|
211
|
-
)
|
212
|
-
end
|
213
|
-
|
214
|
-
subject do
|
215
|
-
Repository.new.create(
|
216
|
-
version_id: another_version.id,
|
217
|
-
consumer_id: consumer.id,
|
218
|
-
provider_id: provider.id,
|
219
|
-
json_content: json_content,
|
220
|
-
pact_version_sha: "#{pact_version_sha}111",
|
221
|
-
version: another_version
|
222
|
-
)
|
223
|
-
end
|
224
|
-
|
225
|
-
it "creates a new PactVersion" do
|
226
|
-
expect { subject }.to change{ PactVersion.count }.by(1)
|
227
|
-
end
|
228
|
-
end
|
229
|
-
end
|
230
|
-
|
231
|
-
describe "update" do
|
232
|
-
|
233
|
-
let(:existing_pact) do
|
234
|
-
td.create_consumer("A Consumer")
|
235
|
-
.create_provider("A Provider")
|
236
|
-
.create_consumer_version("1.2.3")
|
237
|
-
.create_pact(pact_version_sha: pact_version_sha, json_content: original_json_content)
|
238
|
-
.and_return(:pact)
|
239
|
-
end
|
240
|
-
let(:repository) { Repository.new }
|
241
|
-
|
242
|
-
before do
|
243
|
-
PactPublication
|
244
|
-
.dataset
|
245
|
-
.where(id: existing_pact.id)
|
246
|
-
.update(created_at: created_at)
|
247
|
-
PactVersion
|
248
|
-
.dataset
|
249
|
-
.update(created_at: created_at)
|
250
|
-
end
|
251
|
-
|
252
|
-
let(:created_at) { DateTime.new(2014, 3, 2) }
|
253
|
-
|
254
|
-
let(:original_json_content) { {some: "json"}.to_json }
|
255
|
-
let(:json_content) { {some_other: "json"}.to_json }
|
256
|
-
let(:pact_version_sha) { "123" }
|
257
|
-
let(:new_pact_version_sha) { "567" }
|
258
|
-
|
259
|
-
context "when the pact_version_sha has changed" do
|
260
|
-
subject { repository.update(existing_pact.id, json_content: json_content, pact_version_sha: new_pact_version_sha) }
|
261
|
-
|
262
|
-
it "creates a new PactVersion" do
|
263
|
-
expect { subject }.to change{ PactBroker::Pacts::PactPublication.count }.by(1)
|
264
|
-
end
|
265
|
-
|
266
|
-
it "creates a new PactVersion" do
|
267
|
-
expect { subject }.to change{ PactBroker::Pacts::PactVersion.count }.by(1)
|
268
|
-
end
|
269
|
-
|
270
|
-
it "does not change the existing PactVersion" do
|
271
|
-
existing_pvc = PactBroker::Pacts::PactVersion.order(:id).last
|
272
|
-
subject
|
273
|
-
existing_pvc_reloaded = PactBroker::Pacts::PactVersion.find(id: existing_pvc[:id])
|
274
|
-
expect(existing_pvc_reloaded).to eq(existing_pvc)
|
275
|
-
end
|
276
|
-
|
277
|
-
it "updates the existing content on the returned model" do
|
278
|
-
expect(subject.json_content).to eq json_content
|
279
|
-
end
|
280
|
-
|
281
|
-
it "sets the created_at timestamp" do
|
282
|
-
expect(subject.created_at).to_not eq created_at
|
283
|
-
end
|
284
|
-
|
285
|
-
it "increments the revision_number by 1" do
|
286
|
-
expect(subject.revision_number).to eq 2
|
287
|
-
end
|
288
|
-
|
289
|
-
context "when there is a race condition" do
|
290
|
-
before do
|
291
|
-
allow(repository).to receive(:next_revision_number) { | existing_pact | existing_pact.revision_number }
|
292
|
-
end
|
293
|
-
|
294
|
-
it "updates the existing row - yes this is destructive, by MySQL not supporting inner queries stops us doing a SELECT revision_number + 1" do
|
295
|
-
# And if we're conflicting the time between the two publications is so small that nobody
|
296
|
-
# can have depended on the content of the first pact
|
297
|
-
expect { subject }.to_not change{ PactBroker::Pacts::PactPublication.count }
|
298
|
-
end
|
299
|
-
|
300
|
-
it "sets the content to the new content" do
|
301
|
-
expect(subject.json_content).to eq json_content
|
302
|
-
end
|
303
|
-
end
|
304
|
-
end
|
305
|
-
|
306
|
-
context "when the pact_version_sha has not changed" do
|
307
|
-
subject do
|
308
|
-
repository.update(existing_pact.id,
|
309
|
-
json_content: original_json_content,
|
310
|
-
pact_version_sha: pact_version_sha
|
311
|
-
)
|
312
|
-
end
|
313
|
-
|
314
|
-
it "does not create a new PactVersion" do
|
315
|
-
expect { subject }.to_not change{ PactBroker::Pacts::PactPublication.count }
|
316
|
-
end
|
317
|
-
|
318
|
-
it "does not create a new PactVersion" do
|
319
|
-
expect { subject }.to_not change{ PactBroker::Pacts::PactVersion.count }
|
320
|
-
end
|
321
|
-
|
322
|
-
it "the json_content is the same" do
|
323
|
-
expect(subject.json_content).to eq original_json_content
|
324
|
-
end
|
325
|
-
|
326
|
-
it "does not update the created_at timestamp" do
|
327
|
-
expect(subject.created_at.to_datetime).to eq created_at
|
328
|
-
end
|
329
|
-
end
|
330
|
-
end
|
331
|
-
|
332
|
-
describe "delete" do
|
333
|
-
before do
|
334
|
-
td.create_consumer(consumer_name)
|
335
|
-
.create_consumer_version("1.2.3")
|
336
|
-
.create_provider(provider_name)
|
337
|
-
.create_pact
|
338
|
-
.create_webhook
|
339
|
-
.revise_pact
|
340
|
-
.create_consumer_version("2.3.4")
|
341
|
-
.create_pact
|
342
|
-
.create_provider("Another Provider")
|
343
|
-
.create_pact
|
344
|
-
end
|
345
|
-
|
346
|
-
let(:pact_params) { PactBroker::Pacts::PactParams.new(consumer_name: consumer_name, provider_name: provider_name, consumer_version_number: "1.2.3") }
|
347
|
-
|
348
|
-
subject { Repository.new.delete pact_params }
|
349
|
-
|
350
|
-
it "deletes all PactPublication for the specified consumer version" do
|
351
|
-
expect { subject }.to change { PactPublication.count }.by(-2)
|
352
|
-
end
|
353
|
-
|
354
|
-
it "does not delete the content because it may be used by another pact" do
|
355
|
-
expect { subject }.to change { PactVersion.count }.by(0)
|
356
|
-
end
|
357
|
-
|
358
|
-
end
|
359
|
-
|
360
|
-
describe "delete_by_version_id" do
|
361
|
-
let!(:version) do
|
362
|
-
td.create_consumer
|
363
|
-
.create_provider
|
364
|
-
.create_consumer_version("4.5.6")
|
365
|
-
.create_pact
|
366
|
-
.create_consumer_version("1.2.3")
|
367
|
-
.create_pact
|
368
|
-
.and_return(:consumer_version)
|
369
|
-
end
|
370
|
-
|
371
|
-
subject { Repository.new.delete_by_version_id(version.id) }
|
372
|
-
|
373
|
-
it "deletes the pact publication" do
|
374
|
-
expect{ subject }.to change { PactPublication.count }.by(-1)
|
375
|
-
end
|
376
|
-
|
377
|
-
it "does not delete the content because it may be used by another pact" do
|
378
|
-
expect { subject }.to change { PactVersion.count }.by(0)
|
379
|
-
end
|
380
|
-
end
|
381
|
-
|
382
|
-
describe "#find_all_pact_versions_between" do
|
383
|
-
|
384
|
-
before do
|
385
|
-
td.create_consumer(consumer_name)
|
386
|
-
.create_consumer_version("1.2.3")
|
387
|
-
.create_provider(provider_name)
|
388
|
-
.create_pact
|
389
|
-
.create_consumer_version("2.3.4")
|
390
|
-
.create_consumer_version_tag("prod")
|
391
|
-
.create_consumer_version_tag("branch")
|
392
|
-
.create_pact
|
393
|
-
.create_provider("Another Provider")
|
394
|
-
.create_pact
|
395
|
-
end
|
396
|
-
|
397
|
-
subject { Repository.new.find_all_pact_versions_between(consumer_name, :and => provider_name) }
|
398
|
-
|
399
|
-
it "returns the pacts between the specified consumer and provider" do
|
400
|
-
expect(subject.size).to eq 2
|
401
|
-
expect(subject.first.consumer.name).to eq consumer_name
|
402
|
-
expect(subject.first.provider.name).to eq provider_name
|
403
|
-
expect(subject.first.consumer_version.number).to eq "2.3.4"
|
404
|
-
expect(subject.first.consumer_version.tags.count).to eq 2
|
405
|
-
end
|
406
|
-
|
407
|
-
context "with a tag" do
|
408
|
-
subject { Repository.new.find_all_pact_versions_between(consumer_name, :and => provider_name, tag: "prod") }
|
409
|
-
|
410
|
-
it "returns the pacts between the specified consumer and provider with the given tag" do
|
411
|
-
expect(subject.size).to eq 1
|
412
|
-
expect(subject.first.consumer_version.number).to eq "2.3.4"
|
413
|
-
end
|
414
|
-
end
|
415
|
-
end
|
416
|
-
|
417
|
-
describe "#delete_all_pact_publications_between" do
|
418
|
-
before do
|
419
|
-
td.create_consumer(consumer_name)
|
420
|
-
.create_consumer_version("1.2.3")
|
421
|
-
.create_provider(provider_name)
|
422
|
-
.create_pact
|
423
|
-
.revise_pact
|
424
|
-
.comment("The overwritten pact needs to be deleted too")
|
425
|
-
.create_webhook
|
426
|
-
.create_triggered_webhook
|
427
|
-
.create_webhook_execution
|
428
|
-
.create_consumer_version("2.3.4", branch: "main")
|
429
|
-
.create_consumer_version_tag("prod")
|
430
|
-
.create_consumer_version_tag("branch")
|
431
|
-
.create_pact
|
432
|
-
.create_provider("Another Provider")
|
433
|
-
.create_pact
|
434
|
-
.comment("This one won't be deleted")
|
435
|
-
end
|
436
|
-
|
437
|
-
subject { Repository.new.delete_all_pact_publications_between(consumer_name, :and => provider_name) }
|
438
|
-
|
439
|
-
it "deletes the pacts between the specified consumer and provider" do
|
440
|
-
expect { subject }.to change { PactPublication.count }.by(-3)
|
441
|
-
end
|
442
|
-
|
443
|
-
context "with a tag" do
|
444
|
-
subject { Repository.new.delete_all_pact_publications_between(consumer_name, :and => provider_name, tag: "prod") }
|
445
|
-
|
446
|
-
it "deletes the pacts between the specified consumer and provider with the given tag" do
|
447
|
-
expect { subject }.to change { PactPublication.count }.by(-1)
|
448
|
-
end
|
449
|
-
end
|
450
|
-
|
451
|
-
context "with a branch" do
|
452
|
-
subject { Repository.new.delete_all_pact_publications_between(consumer_name, :and => provider_name, branch_name: "main") }
|
453
|
-
|
454
|
-
it "deletes the pacts between the specified consumer and provider with the given branch" do
|
455
|
-
expect { subject }.to change {
|
456
|
-
PactPublication
|
457
|
-
.for_consumer_name(consumer_name)
|
458
|
-
.for_provider_name(provider_name)
|
459
|
-
.for_branch_name("main")
|
460
|
-
.count
|
461
|
-
}.by(-1)
|
462
|
-
end
|
463
|
-
end
|
464
|
-
end
|
465
|
-
|
466
|
-
describe "#find_latest_pacts_for_provider" do
|
467
|
-
context "with no tag specified" do
|
468
|
-
before do
|
469
|
-
td.create_consumer(consumer_name)
|
470
|
-
.create_consumer_version("1.0.0")
|
471
|
-
.create_provider(provider_name)
|
472
|
-
.create_pact
|
473
|
-
.create_consumer_version("1.2.3")
|
474
|
-
.create_pact
|
475
|
-
.create_consumer("wiffle consumer")
|
476
|
-
.create_consumer_version("4.0.0")
|
477
|
-
.create_pact
|
478
|
-
.create_consumer_version("4.5.6")
|
479
|
-
.create_pact
|
480
|
-
.create_provider("not the provider")
|
481
|
-
.create_pact
|
482
|
-
end
|
483
|
-
|
484
|
-
subject { Repository.new.find_latest_pacts_for_provider provider_name }
|
485
|
-
|
486
|
-
it "returns the pacts between the specified consumer and provider" do
|
487
|
-
expect(subject.size).to eq 2
|
488
|
-
expect(subject.first.consumer.name).to eq consumer_name
|
489
|
-
expect(subject.first.provider.name).to eq provider_name
|
490
|
-
expect(subject.first.consumer_version.number).to eq "1.2.3"
|
491
|
-
expect(subject.first.json_content).to_not be nil
|
492
|
-
expect(subject.last.consumer.name).to eq "wiffle consumer"
|
493
|
-
expect(subject.last.tag).to eq nil
|
494
|
-
expect(subject.last.overall_latest?).to be true
|
495
|
-
end
|
496
|
-
end
|
497
|
-
|
498
|
-
context "with a tag specified" do
|
499
|
-
before do
|
500
|
-
td.create_consumer(consumer_name)
|
501
|
-
.create_consumer_version("1.2.3")
|
502
|
-
.create_consumer_version_tag("prod")
|
503
|
-
.create_provider(provider_name)
|
504
|
-
.create_pact
|
505
|
-
.create_consumer_version("2.0.0")
|
506
|
-
.create_pact
|
507
|
-
.create_consumer("wiffle consumer")
|
508
|
-
.create_consumer_version("4.5.6")
|
509
|
-
.create_pact
|
510
|
-
.create_consumer_version("5.0.0")
|
511
|
-
.create_consumer_version_tag("prod")
|
512
|
-
.create_consumer_version_tag("test")
|
513
|
-
.create_pact
|
514
|
-
.create_provider("not the provider")
|
515
|
-
.create_pact
|
516
|
-
end
|
517
|
-
|
518
|
-
subject { Repository.new.find_latest_pacts_for_provider provider_name, "prod" }
|
519
|
-
|
520
|
-
it "returns the pacts between the specified consumer and provider with the given consumer version tag" do
|
521
|
-
expect(subject.size).to eq 2
|
522
|
-
expect(subject.first.provider.name).to eq provider_name
|
523
|
-
expect(subject.first.consumer.name).to eq consumer_name
|
524
|
-
expect(subject.first.consumer_version.number).to eq "1.2.3"
|
525
|
-
expect(subject.first.json_content).to_not be nil
|
526
|
-
expect(subject.first.tag).to eq "prod"
|
527
|
-
expect(subject.last.consumer.name).to eq "wiffle consumer"
|
528
|
-
expect(subject.last.consumer_version.number).to eq "5.0.0"
|
529
|
-
expect(subject.last.tag).to eq "prod"
|
530
|
-
expect(subject.last.overall_latest?).to be false
|
531
|
-
end
|
532
|
-
end
|
533
|
-
end
|
534
|
-
|
535
|
-
describe "#find_pact_versions_for_provider" do
|
536
|
-
context "with no tag specified" do
|
537
|
-
before do
|
538
|
-
td.create_consumer(consumer_name)
|
539
|
-
.create_consumer_version("1.0.0")
|
540
|
-
.create_provider(provider_name)
|
541
|
-
.create_pact
|
542
|
-
.create_consumer_version("1.2.3")
|
543
|
-
.create_pact
|
544
|
-
.create_consumer("wiffle consumer")
|
545
|
-
.create_consumer_version("4.0.0")
|
546
|
-
.create_pact
|
547
|
-
.create_consumer_version("4.5.6")
|
548
|
-
.create_pact
|
549
|
-
.create_provider("not the provider")
|
550
|
-
.create_pact
|
551
|
-
end
|
552
|
-
|
553
|
-
subject { Repository.new.find_pact_versions_for_provider provider_name }
|
554
|
-
|
555
|
-
it "returns all the pact versions for the specified provider" do
|
556
|
-
expect(subject.size).to eq 4
|
557
|
-
expect(subject.first.provider.name).to eq provider_name
|
558
|
-
end
|
559
|
-
end
|
560
|
-
|
561
|
-
context "with a tag specified" do
|
562
|
-
before do
|
563
|
-
td.create_consumer(consumer_name)
|
564
|
-
.create_consumer_version("1")
|
565
|
-
.create_consumer_version_tag("prod")
|
566
|
-
.create_provider(provider_name)
|
567
|
-
.create_pact
|
568
|
-
.create_consumer_version("2")
|
569
|
-
.create_consumer_version_tag("prod")
|
570
|
-
.create_pact
|
571
|
-
.create_consumer_version("3")
|
572
|
-
.create_pact
|
573
|
-
.create_consumer("wiffle consumer")
|
574
|
-
.create_consumer_version("10")
|
575
|
-
.create_pact
|
576
|
-
.create_consumer_version("11")
|
577
|
-
.create_consumer_version_tag("prod")
|
578
|
-
.create_consumer_version_tag("test")
|
579
|
-
.create_pact
|
580
|
-
.create_provider("not the provider")
|
581
|
-
.create_pact
|
582
|
-
end
|
583
|
-
|
584
|
-
subject { Repository.new.find_pact_versions_for_provider provider_name, "prod" }
|
585
|
-
|
586
|
-
it "returns the pacts between the specified provider with the given consumer tag" do
|
587
|
-
expect(subject.size).to eq 3
|
588
|
-
expect(subject.first.provider.name).to eq provider_name
|
589
|
-
expect(subject.first.consumer.name).to eq consumer_name
|
590
|
-
expect(subject.first.consumer_version.number).to eq "1"
|
591
|
-
expect(subject[1].consumer_version.number).to eq "2"
|
592
|
-
expect(subject.first.json_content).to_not be nil
|
593
|
-
expect(subject.last.consumer.name).to eq "wiffle consumer"
|
594
|
-
expect(subject.last.consumer_version.number).to eq "11"
|
595
|
-
end
|
596
|
-
end
|
597
|
-
end
|
598
|
-
|
599
|
-
describe "find_pact" do
|
600
|
-
let!(:pact) do
|
601
|
-
pact = td
|
602
|
-
.create_consumer("Consumer")
|
603
|
-
.create_consumer_version("1.2.2")
|
604
|
-
.create_provider("Provider")
|
605
|
-
.create_pact
|
606
|
-
.create_consumer_version("1.2.4")
|
607
|
-
.create_consumer_version_tag("prod")
|
608
|
-
.create_pact
|
609
|
-
.revise_pact
|
610
|
-
.and_return(:pact)
|
611
|
-
td
|
612
|
-
.create_consumer_version("1.2.6")
|
613
|
-
.create_pact
|
614
|
-
.create_provider("Another Provider")
|
615
|
-
.create_consumer_version("1.2.5")
|
616
|
-
.create_pact
|
617
|
-
pact
|
618
|
-
end
|
619
|
-
|
620
|
-
subject { Repository.new.find_pact "Consumer", "1.2.4", "Provider" }
|
621
|
-
|
622
|
-
it "finds the pact with the given version" do
|
623
|
-
expect(subject.consumer.name).to eq "Consumer"
|
624
|
-
expect(subject.provider.name).to eq "Provider"
|
625
|
-
expect(subject.consumer_version_number).to eq "1.2.4"
|
626
|
-
expect(subject.consumer_version.number).to eq "1.2.4"
|
627
|
-
expect(subject.consumer_version.tags.first.name).to eq "prod"
|
628
|
-
expect(subject.json_content).to_not be_nil
|
629
|
-
end
|
630
|
-
|
631
|
-
context "with no version" do
|
632
|
-
subject { Repository.new.find_pact("Consumer", nil, "Provider") }
|
633
|
-
|
634
|
-
it "returns the latest pact" do
|
635
|
-
expect(subject.consumer_version_number).to eq "1.2.6"
|
636
|
-
end
|
637
|
-
end
|
638
|
-
|
639
|
-
context "with a pact_version_sha" do
|
640
|
-
subject { Repository.new.find_pact "Consumer", nil, "Provider", pact.pact_version_sha }
|
641
|
-
|
642
|
-
it "finds the pact with the given pact_version_sha" do
|
643
|
-
expect(subject.pact_version_sha).to eq pact.pact_version_sha
|
644
|
-
expect(subject.consumer.name).to eq "Consumer"
|
645
|
-
expect(subject.provider.name).to eq "Provider"
|
646
|
-
expect(subject.consumer_version_number).to eq "1.2.4"
|
647
|
-
expect(subject.revision_number).to eq 2
|
648
|
-
end
|
649
|
-
|
650
|
-
context "when there are multiple pact publications for the pact version" do
|
651
|
-
before do
|
652
|
-
# Double check the data is set up correctly...
|
653
|
-
expect(pact_1.pact_version_sha).to eq(pact_2.pact_version_sha)
|
654
|
-
end
|
655
|
-
|
656
|
-
let!(:pact_1) { td.create_pact_with_hierarchy("Foo", "1", "Bar").and_return(:pact) }
|
657
|
-
let!(:pact_2) { td.create_consumer_version("2").create_pact(json_content: pact_1.json_content).and_return(:pact) }
|
658
|
-
|
659
|
-
let(:consumer_version_number) { nil }
|
660
|
-
|
661
|
-
subject { Repository.new.find_pact "Foo", consumer_version_number, "Bar", pact_1.pact_version_sha }
|
662
|
-
|
663
|
-
it "returns the latest pact, ordered by consumer version order" do
|
664
|
-
expect(subject.consumer_version_number).to eq "2"
|
665
|
-
end
|
666
|
-
|
667
|
-
context "when the consumer_version_number is specified too (from the URL metadata)" do
|
668
|
-
let(:consumer_version_number) { "1" }
|
669
|
-
|
670
|
-
it "returns the publication with the consumer version specified" do
|
671
|
-
expect(subject.consumer_version_number).to eq "1"
|
672
|
-
end
|
673
|
-
end
|
674
|
-
|
675
|
-
context "when the consumer_version_number is specified too (from the URL metadata) but it doesn't exist (anymore)" do
|
676
|
-
let(:consumer_version_number) { "9" }
|
677
|
-
|
678
|
-
it "returns the pact matching the sha with the latest consumer version" do
|
679
|
-
expect(subject.consumer_version_number).to eq "2"
|
680
|
-
end
|
681
|
-
end
|
682
|
-
|
683
|
-
# Not sure when this would happen
|
684
|
-
context "when the consumer_version_number is specified too (from the URL metadata) and it exists but it doesn't match the sha" do
|
685
|
-
before do
|
686
|
-
td.create_pact_with_hierarchy("Foo", "8", "Bar")
|
687
|
-
end
|
688
|
-
|
689
|
-
let(:consumer_version_number) { "8" }
|
690
|
-
|
691
|
-
it "returns the pact matching the sha with the latest consumer version" do
|
692
|
-
expect(subject.consumer_version_number).to eq "2"
|
693
|
-
end
|
694
|
-
end
|
695
|
-
|
696
|
-
context "when the pact has multiple revisions and goes back to a previous revision" do
|
697
|
-
before do
|
698
|
-
td.revise_pact
|
699
|
-
.revise_pact(pact_1.json_content)
|
700
|
-
end
|
701
|
-
|
702
|
-
it "returns the latest revision" do
|
703
|
-
expect(subject.revision_number).to eq 3
|
704
|
-
end
|
705
|
-
end
|
706
|
-
end
|
707
|
-
end
|
708
|
-
end
|
709
|
-
|
710
|
-
describe "find_all_revisions" do
|
711
|
-
before do
|
712
|
-
td.create_pact_with_hierarchy("foo", "3.0.0", "bar")
|
713
|
-
.revise_pact
|
714
|
-
.create_pact_with_hierarchy(consumer_name, "1.2.3", provider_name)
|
715
|
-
.revise_pact
|
716
|
-
.create_consumer_version("4.5.6")
|
717
|
-
.create_pact
|
718
|
-
end
|
719
|
-
|
720
|
-
subject { Repository.new.find_all_revisions consumer_name, "1.2.3", provider_name }
|
721
|
-
|
722
|
-
it "returns all the revisions for the given pact version" do
|
723
|
-
expect(subject.size).to eq 2
|
724
|
-
expect(subject.first.consumer_name).to eq consumer_name
|
725
|
-
expect(subject.first.revision_number).to eq 1
|
726
|
-
expect(subject.last.revision_number).to eq 2
|
727
|
-
end
|
728
|
-
end
|
729
|
-
|
730
|
-
describe "find_previous_pact" do
|
731
|
-
before do
|
732
|
-
td.create_consumer("Consumer")
|
733
|
-
.create_consumer_version("1.2.2")
|
734
|
-
.create_provider("Provider")
|
735
|
-
.create_consumer_version_tag("a_tag")
|
736
|
-
.create_pact
|
737
|
-
.create_consumer_version("1.2.3")
|
738
|
-
.create_pact
|
739
|
-
.create_consumer_version("1.2.4")
|
740
|
-
.create_consumer_version_tag("another_tag")
|
741
|
-
.create_pact
|
742
|
-
.create_consumer_version("1.2.5")
|
743
|
-
.create_consumer_version_tag("a_tag")
|
744
|
-
.create_pact
|
745
|
-
.create_consumer_version("1.2.7")
|
746
|
-
.create_consumer_version_tag("another_tag")
|
747
|
-
.create_pact
|
748
|
-
.create_provider("Another Provider")
|
749
|
-
.create_consumer_version("1.2.6")
|
750
|
-
.create_consumer_version_tag("a_tag")
|
751
|
-
.create_pact
|
752
|
-
end
|
753
|
-
|
754
|
-
context "regardless of tag" do
|
755
|
-
context "when a previous version with a pact exists" do
|
756
|
-
|
757
|
-
let(:pact) { Repository.new.find_latest_pact "Consumer", "Provider", "another_tag" }
|
758
|
-
|
759
|
-
subject { Repository.new.find_previous_pact pact }
|
760
|
-
|
761
|
-
it "finds the previous pact" do
|
762
|
-
expect(subject.consumer_version_number).to eq "1.2.5"
|
763
|
-
end
|
764
|
-
|
765
|
-
it "sets the json_content" do
|
766
|
-
expect(subject.json_content).to_not be nil
|
767
|
-
end
|
768
|
-
end
|
769
|
-
end
|
770
|
-
|
771
|
-
context "by tag" do
|
772
|
-
context "when a previous version with a pact with a specific tag exists" do
|
773
|
-
|
774
|
-
let(:pact) { Repository.new.find_latest_pact "Consumer", "Provider", "a_tag" }
|
775
|
-
|
776
|
-
subject { Repository.new.find_previous_pact pact, "a_tag" }
|
777
|
-
|
778
|
-
it "finds the previous pact" do
|
779
|
-
expect(subject.consumer_version_number).to eq "1.2.2"
|
780
|
-
end
|
781
|
-
|
782
|
-
it "sets the json_content" do
|
783
|
-
expect(subject.json_content).to_not be nil
|
784
|
-
end
|
785
|
-
end
|
786
|
-
end
|
787
|
-
|
788
|
-
context "that is untagged" do
|
789
|
-
context "when a previous version with a an untagged pact exists" do
|
790
|
-
|
791
|
-
let(:pact) { Repository.new.find_latest_pact "Consumer", "Provider" }
|
792
|
-
|
793
|
-
subject { Repository.new.find_previous_pact pact, :untagged }
|
794
|
-
|
795
|
-
it "finds the previous pact" do
|
796
|
-
expect(subject.consumer_version_number).to eq "1.2.3"
|
797
|
-
end
|
798
|
-
|
799
|
-
it "sets the json_content" do
|
800
|
-
expect(subject.json_content).to_not be nil
|
801
|
-
end
|
802
|
-
end
|
803
|
-
end
|
804
|
-
end
|
805
|
-
|
806
|
-
describe "find_next_pact" do
|
807
|
-
before do
|
808
|
-
td.create_consumer("Consumer")
|
809
|
-
.create_consumer_version("1.2.2")
|
810
|
-
.create_provider("Provider")
|
811
|
-
.create_pact
|
812
|
-
.create_consumer_version("1.2.4")
|
813
|
-
.create_pact
|
814
|
-
.create_consumer_version("1.2.6")
|
815
|
-
.create_pact
|
816
|
-
.create_provider("Another Provider")
|
817
|
-
.create_consumer_version("1.2.5")
|
818
|
-
.create_pact
|
819
|
-
end
|
820
|
-
|
821
|
-
let(:pact) { Repository.new.find_pact "Consumer", "1.2.4", "Provider" }
|
822
|
-
|
823
|
-
subject { Repository.new.find_next_pact pact }
|
824
|
-
|
825
|
-
it "finds the next pact" do
|
826
|
-
expect(subject.consumer_version_number).to eq "1.2.6"
|
827
|
-
end
|
828
|
-
|
829
|
-
it "sets the json_content" do
|
830
|
-
expect(subject.json_content).to_not be nil
|
831
|
-
end
|
832
|
-
end
|
833
|
-
|
834
|
-
describe "find_previous_distinct_pact" do
|
835
|
-
|
836
|
-
let(:pact_content_version_1) { load_fixture("consumer-provider.json") }
|
837
|
-
let(:pact_content_version_2) do
|
838
|
-
hash = load_json_fixture("consumer-provider.json")
|
839
|
-
hash["interactions"].first["foo"] = "bar" # Extra key in interactions will affect equality
|
840
|
-
hash.to_json
|
841
|
-
end
|
842
|
-
let(:pact_content_version_3) { load_fixture("consumer-provider.json") }
|
843
|
-
let(:pact_content_version_4) do
|
844
|
-
# Move description to end of hash, should not affect equality
|
845
|
-
hash = load_json_fixture("consumer-provider.json")
|
846
|
-
description = hash["interactions"].first.delete("description")
|
847
|
-
hash["interactions"].first["description"] = description
|
848
|
-
hash.to_json
|
849
|
-
end
|
850
|
-
|
851
|
-
before do
|
852
|
-
td.create_consumer("Consumer")
|
853
|
-
.create_provider("Provider")
|
854
|
-
.create_consumer_version("1")
|
855
|
-
.create_pact(json_content: pact_content_version_1)
|
856
|
-
.create_consumer_version("2")
|
857
|
-
.create_pact(json_content: pact_content_version_2)
|
858
|
-
.create_consumer_version("3")
|
859
|
-
.create_pact(json_content: pact_content_version_3)
|
860
|
-
.create_consumer_version("4")
|
861
|
-
.create_pact(json_content: pact_content_version_4)
|
862
|
-
expect(pact_content_version_3).to_not eq pact_content_version_4
|
863
|
-
end
|
864
|
-
|
865
|
-
let(:pact) { Repository.new.find_pact "Consumer", "4", "Provider" }
|
866
|
-
|
867
|
-
subject { Repository.new.find_previous_distinct_pact pact }
|
868
|
-
|
869
|
-
context "when there is a previous distinct version" do
|
870
|
-
it "returns the previous pact with different content" do
|
871
|
-
expect(subject.consumer_version_number).to eq("2")
|
872
|
-
end
|
873
|
-
it "returns json_content" do
|
874
|
-
expect(subject.json_content).to_not be nil
|
875
|
-
end
|
876
|
-
end
|
877
|
-
|
878
|
-
context "when there isn't a previous distinct version" do
|
879
|
-
let(:pact_content_version_2) { load_fixture("consumer-provider.json") }
|
880
|
-
|
881
|
-
it "returns nil" do
|
882
|
-
expect(subject).to be nil
|
883
|
-
end
|
884
|
-
end
|
885
|
-
|
886
|
-
end
|
887
|
-
|
888
|
-
describe "find_latest_pact" do
|
889
|
-
context "with a tag" do
|
890
|
-
context "when a version with a pact exists with the given tag" do
|
891
|
-
before do
|
892
|
-
td.create_consumer("Consumer")
|
893
|
-
.create_consumer_version("2.3.4")
|
894
|
-
.create_provider("Provider")
|
895
|
-
.create_pact
|
896
|
-
.create_consumer_version("1.2.3")
|
897
|
-
.create_consumer_version_tag("prod")
|
898
|
-
.create_pact
|
899
|
-
end
|
900
|
-
|
901
|
-
let(:latest_prod_pact) { Repository.new.find_latest_pact("Consumer", "Provider", "prod") }
|
902
|
-
|
903
|
-
it "returns the pact for the latest tagged version" do
|
904
|
-
expect(latest_prod_pact.consumer_version.number).to eq("1.2.3")
|
905
|
-
end
|
906
|
-
|
907
|
-
it "has JSON content" do
|
908
|
-
expect(latest_prod_pact.json_content).to_not be nil
|
909
|
-
end
|
910
|
-
|
911
|
-
it "has timestamps" do
|
912
|
-
expect(latest_prod_pact.created_at).to be_datey
|
913
|
-
end
|
914
|
-
end
|
915
|
-
|
916
|
-
end
|
917
|
-
|
918
|
-
context "without a tag" do
|
919
|
-
context "when one or more versions of a pact exist without any tags" do
|
920
|
-
before do
|
921
|
-
td.create_consumer("Consumer")
|
922
|
-
.create_provider("Provider")
|
923
|
-
.create_consumer_version("1.0.0")
|
924
|
-
.create_pact
|
925
|
-
.create_consumer_version("1.2.3")
|
926
|
-
.create_pact
|
927
|
-
.create_consumer_version("2.3.4")
|
928
|
-
.create_consumer_version_tag("prod")
|
929
|
-
.create_pact
|
930
|
-
end
|
931
|
-
|
932
|
-
let(:pact) { Repository.new.find_latest_pact("Consumer", "Provider", :untagged) }
|
933
|
-
|
934
|
-
it "returns the latest" do
|
935
|
-
expect(pact.consumer_version.number).to eq("1.2.3")
|
936
|
-
end
|
937
|
-
|
938
|
-
it "has JSON content" do
|
939
|
-
expect(pact.json_content).to_not be nil
|
940
|
-
end
|
941
|
-
|
942
|
-
it "has timestamps" do
|
943
|
-
expect(pact.created_at).to be_datey
|
944
|
-
end
|
945
|
-
end
|
946
|
-
|
947
|
-
context "when all versions have a tag" do
|
948
|
-
before do
|
949
|
-
td.create_consumer("Consumer")
|
950
|
-
.create_provider("Provider")
|
951
|
-
.create_consumer_version("2.3.4")
|
952
|
-
.create_consumer_version_tag("prod")
|
953
|
-
.create_pact
|
954
|
-
end
|
955
|
-
|
956
|
-
let(:pact) { Repository.new.find_latest_pact("Consumer", "Provider", :untagged) }
|
957
|
-
|
958
|
-
it "returns nil" do
|
959
|
-
expect(pact).to be nil
|
960
|
-
end
|
961
|
-
end
|
962
|
-
end
|
963
|
-
end
|
964
|
-
|
965
|
-
describe "search_for_latest_pact" do
|
966
|
-
context "when one or more versions of a pact exist without any tags" do
|
967
|
-
before do
|
968
|
-
td.create_consumer("Consumer")
|
969
|
-
.create_provider("Provider")
|
970
|
-
.create_consumer_version("0")
|
971
|
-
.create_consumer_version_tag("main")
|
972
|
-
.create_pact
|
973
|
-
.create_consumer_version("1")
|
974
|
-
.create_pact
|
975
|
-
.create_provider("Another Provider")
|
976
|
-
.create_consumer_version("2")
|
977
|
-
.create_pact
|
978
|
-
end
|
979
|
-
|
980
|
-
context "with both consumer and provider names" do
|
981
|
-
let(:pact) { Repository.new.search_for_latest_pact("Consumer", "Provider") }
|
982
|
-
|
983
|
-
it "returns the latest" do
|
984
|
-
expect(pact.consumer_version.number).to eq("1")
|
985
|
-
end
|
986
|
-
end
|
987
|
-
|
988
|
-
context "with only consumer name" do
|
989
|
-
let(:pact) { Repository.new.search_for_latest_pact("Consumer", nil) }
|
990
|
-
|
991
|
-
it "returns the latest" do
|
992
|
-
expect(pact.consumer_version.number).to eq("2")
|
993
|
-
end
|
994
|
-
end
|
995
|
-
|
996
|
-
context "with only provider name" do
|
997
|
-
let(:pact) { Repository.new.search_for_latest_pact(nil, "Another Provider") }
|
998
|
-
|
999
|
-
it "returns the latest" do
|
1000
|
-
expect(pact.consumer_version.number).to eq("2")
|
1001
|
-
end
|
1002
|
-
end
|
1003
|
-
|
1004
|
-
context "with a tag" do
|
1005
|
-
let(:pact) { Repository.new.search_for_latest_pact("Consumer", "Provider", "main") }
|
1006
|
-
|
1007
|
-
it "returns the latest" do
|
1008
|
-
expect(pact.consumer_version.number).to eq("0")
|
1009
|
-
end
|
1010
|
-
end
|
1011
|
-
|
1012
|
-
context "untagged" do
|
1013
|
-
before do
|
1014
|
-
td.create_consumer("Foo")
|
1015
|
-
.create_provider("Bar")
|
1016
|
-
.create_consumer_version("0")
|
1017
|
-
.create_consumer_version_tag("main")
|
1018
|
-
.create_pact
|
1019
|
-
.create_consumer_version("1")
|
1020
|
-
.create_pact
|
1021
|
-
.create_consumer_version("2")
|
1022
|
-
.create_consumer_version_tag("main")
|
1023
|
-
.create_pact
|
1024
|
-
|
1025
|
-
end
|
1026
|
-
|
1027
|
-
let(:pact) { Repository.new.search_for_latest_pact("Foo", "Bar", :untagged) }
|
1028
|
-
|
1029
|
-
it "returns the latest" do
|
1030
|
-
expect(pact.consumer_version.number).to eq("1")
|
1031
|
-
end
|
1032
|
-
end
|
1033
|
-
end
|
1034
|
-
end
|
1035
|
-
|
1036
|
-
describe "find_latest_pacts" do
|
1037
|
-
before do
|
1038
|
-
td.create_consumer("Condor")
|
1039
|
-
.create_consumer_version("1.3.0")
|
1040
|
-
.create_provider("Pricing Service")
|
1041
|
-
.create_pact
|
1042
|
-
.create_consumer_version("1.4.0")
|
1043
|
-
.create_consumer_version_tag("prod")
|
1044
|
-
.create_pact
|
1045
|
-
.create_consumer("Contract Email Service")
|
1046
|
-
.create_consumer_version("2.6.0")
|
1047
|
-
.create_provider("Contract Proposal Service")
|
1048
|
-
.create_pact
|
1049
|
-
.create_consumer_version("2.7.0")
|
1050
|
-
.create_pact
|
1051
|
-
.create_consumer_version("2.8.0") # Create a version without a pact, it shouldn't be used
|
1052
|
-
end
|
1053
|
-
|
1054
|
-
it "finds the latest pact for each consumer/provider pair" do
|
1055
|
-
pacts = Repository.new.find_latest_pacts
|
1056
|
-
|
1057
|
-
expect(pacts[0].consumer_version.pacticipant.name).to eq("Condor")
|
1058
|
-
expect(pacts[0].consumer.name).to eq("Condor")
|
1059
|
-
expect(pacts[0].consumer.id).to_not be nil
|
1060
|
-
expect(pacts[0].provider.name).to eq("Pricing Service")
|
1061
|
-
expect(pacts[0].provider.id).to_not be nil
|
1062
|
-
expect(pacts[0].consumer_version.number).to eq("1.4.0")
|
1063
|
-
expect(pacts[0].consumer_version.tags.collect(&:name)).to eq ["prod"]
|
1064
|
-
|
1065
|
-
expect(pacts[1].consumer_version.pacticipant.name).to eq("Contract Email Service")
|
1066
|
-
expect(pacts[1].consumer.name).to eq("Contract Email Service")
|
1067
|
-
expect(pacts[1].provider.name).to eq("Contract Proposal Service")
|
1068
|
-
expect(pacts[1].consumer_version.number).to eq("2.7.0")
|
1069
|
-
expect(pacts[1].consumer_version.tags.collect(&:name)).to eq []
|
1070
|
-
end
|
1071
|
-
|
1072
|
-
it "includes the timestamps - need to update view" do
|
1073
|
-
pacts = Repository.new.find_latest_pacts
|
1074
|
-
expect(pacts[0].created_at).to be_datey
|
1075
|
-
end
|
1076
|
-
end
|
1077
|
-
end
|
1078
|
-
end
|
1079
|
-
end
|