-
-
Notifications
You must be signed in to change notification settings - Fork 178
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: implement pending logic for provider branches
- Loading branch information
Showing
9 changed files
with
357 additions
and
24 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,137 @@ | ||
RSpec.describe "the pending lifecycle of a pact (with tags)" do | ||
let(:pact_content_1) { { some: "interactions" }.to_json } | ||
let(:pact_content_2) { { some: "other interactions" }.to_json } | ||
let(:request_headers) { { "CONTENT_TYPE" => "application/json", "HTTP_ACCEPT" => "application/hal+json"} } | ||
let(:failed_verification_results) do | ||
{ | ||
providerApplicationVersion: "2", | ||
success: false | ||
}.to_json | ||
end | ||
let(:successful_verification_results) do | ||
{ | ||
providerApplicationVersion: "2", | ||
success: true | ||
}.to_json | ||
end | ||
|
||
def publish_pact | ||
put("/pacts/provider/Bar/consumer/Foo/version/1", pact_content_1, request_headers) | ||
end | ||
|
||
def get_pacts_for_verification(provider_version_branch = "main") | ||
post("/pacts/provider/Bar/for-verification", { includePendingStatus: true, providerVersionBranch: provider_version_branch }.to_json, request_headers) | ||
end | ||
|
||
def pact_url_from(pacts_for_verification_response) | ||
JSON.parse(pacts_for_verification_response.body)["_embedded"]["pacts"][0]["_links"]["self"]["href"] | ||
end | ||
|
||
def get_pact(pact_url) | ||
get pact_url, nil, request_headers | ||
end | ||
|
||
def verification_results_url_from(pact_response) | ||
JSON.parse(pact_response.body)["_links"]["pb:publish-verification-results"]["href"] | ||
end | ||
|
||
def publish_verification_results(verification_results_url, results) | ||
put("/pacticipants/Bar/branches/main/versions/#{JSON.parse(results)["providerApplicationVersion"]}", nil, { "CONTENT_TYPE" => "application/json" }) | ||
post(verification_results_url, results, request_headers) | ||
end | ||
|
||
def pending_status_from(pacts_for_verification_response) | ||
JSON.parse(pacts_for_verification_response.body)["_embedded"]["pacts"][0]["verificationProperties"]["pending"] | ||
end | ||
|
||
context "a pact" do | ||
describe "when it is first published" do | ||
it "is pending" do | ||
publish_pact | ||
pacts_for_verification_response = get_pacts_for_verification | ||
expect(pending_status_from(pacts_for_verification_response)).to be true | ||
end | ||
end | ||
|
||
describe "when it is verified unsuccessfully" do | ||
it "is still pending" do | ||
# CONSUMER BUILD | ||
# publish pact | ||
publish_pact | ||
|
||
# PROVIDER BUILD | ||
# fetch pacts to verify | ||
pacts_for_verification_response = get_pacts_for_verification | ||
pact_url = pact_url_from(pacts_for_verification_response) | ||
pact_response = get_pact(pact_url) | ||
|
||
# verify pact... failure... | ||
|
||
# publish failure verification results | ||
verification_results_url = verification_results_url_from(pact_response) | ||
publish_verification_results(verification_results_url, failed_verification_results) | ||
|
||
# ANOTHER PROVIDER BUILD | ||
# get pacts for verification | ||
pacts_for_verification_response = get_pacts_for_verification | ||
# still pending | ||
expect(pending_status_from(pacts_for_verification_response)).to be true | ||
end | ||
end | ||
|
||
describe "when it is verified successfully" do | ||
it "is no longer pending" do | ||
# CONSUMER BUILD | ||
publish_pact | ||
|
||
# PROVIDER BUILD | ||
pacts_for_verification_response = get_pacts_for_verification | ||
|
||
# fetch pact | ||
pact_url = pact_url_from(pacts_for_verification_response) | ||
pact_response = get_pact(pact_url) | ||
|
||
# verify pact... success! | ||
|
||
# publish failure verification results | ||
verification_results_url = verification_results_url_from(pact_response) | ||
publish_verification_results(verification_results_url, successful_verification_results) | ||
|
||
# ANOTHER PROVIDER BUILD 2 | ||
# get pacts for verification | ||
# publish successful verification results | ||
pacts_for_verification_response = get_pacts_for_verification | ||
# not pending any more | ||
expect(pending_status_from(pacts_for_verification_response)).to be false | ||
end | ||
end | ||
|
||
|
||
describe "when it is verified successfully by one branch, and then another branch of the provider is created" do | ||
it "is not pending for the new branch" do | ||
# CONSUMER BUILD | ||
publish_pact | ||
|
||
# PROVIDER BUILD | ||
pacts_for_verification_response = get_pacts_for_verification | ||
|
||
# fetch pact | ||
pact_url = pact_url_from(pacts_for_verification_response) | ||
pact_response = get_pact(pact_url) | ||
|
||
# verify pact... success! | ||
|
||
# publish failure verification results | ||
verification_results_url = verification_results_url_from(pact_response) | ||
publish_verification_results(verification_results_url, successful_verification_results) | ||
|
||
# ANOTHER PROVIDER BUILD 2 from another branch | ||
# get pacts for verification | ||
# publish successful verification results | ||
pacts_for_verification_response = get_pacts_for_verification("feat/foo") | ||
# not pending | ||
expect(pending_status_from(pacts_for_verification_response)).to be false | ||
end | ||
end | ||
end | ||
end |
Oops, something went wrong.