Skip to content

Commit

Permalink
Merge pull request #1298 from alphagov/content-modelling/call-embedde…
Browse files Browse the repository at this point in the history
…d-endpoint

Rename `embedded` endpoint and associated method
  • Loading branch information
pezholio authored Nov 26, 2024
2 parents 4eff919 + 3a7a4ab commit 5d9845e
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 23 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# Changelog

## Unreleased

* Rename `get_content_by_embedded_document` and call renamed endpoint [PR](/~https://github.com/alphagov/gds-api-adapters/pull/1298)

## 97.3.0

* Add page and order args to get_content_by_embedded_document test helper [PR](/~https://github.com/alphagov/gds-api-adapters/pull/1295)
Expand Down
13 changes: 9 additions & 4 deletions lib/gds_api/publishing_api.rb
Original file line number Diff line number Diff line change
Expand Up @@ -342,18 +342,23 @@ def get_content_items(params)
# @param content_id [UUID]
# @param params [Hash]
#
# publishing_api.get_content_by_embedded_document(
# publishing_api.get_host_content_for_content_id(
# "4b148ebc-b2bb-40db-8e48-dd8cff363ff7",
# { page: 1, order: '-last_edited_at' }
# )
#
# @return [GdsApi::Response] A response containing a summarised list of the content items which embed the target.
# The content items returned will be in either the draft of published state.
#
# @see /~https://github.com/alphagov/publishing-api/blob/main/docs/api.md#get-v2contentcontent_idembedded
def get_content_by_embedded_document(content_id, params = {})
# @see /~https://github.com/alphagov/publishing-api/blob/main/docs/api.md#get-v2contentcontent_idhost-content
def get_host_content_for_content_id(content_id, params = {})
query = query_string(params)
get_json("#{endpoint}/v2/content/#{content_id}/embedded#{query}")
get_json("#{endpoint}/v2/content/#{content_id}/host-content#{query}")
end

def get_content_by_embedded_document(content_id, params = {})
warn "GdsAPI::PublishingApi: #get_content_by_embedded_document deprecated (please use #get_host_content_for_content_id)"
get_host_content_for_content_id(content_id, params)
end

# Returns an Enumerator of content items for the provided
Expand Down
38 changes: 19 additions & 19 deletions test/pacts/publishing_api/get_embedded_content_pact_test.rb
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
require "test_helper"
require "gds_api/publishing_api"

describe "GdsApi::PublishingApi#get_content_by_embedded_document pact tests" do
describe "GdsApi::PublishingApi#get_host_content_for_content_id pact tests" do
include PactTest

let(:api_client) { GdsApi::PublishingApi.new(publishing_api_host) }
Expand Down Expand Up @@ -33,17 +33,17 @@
it "responds with 200 if the target content item exists" do
publishing_api
.given("a content item exists (content_id: #{content_id}) that embeds the reusable content (content_id: #{reusable_content_id})")
.upon_receiving("a get_content_by_embedded_document request")
.upon_receiving("a get_host_content_for_content_id request")
.with(
method: :get,
path: "/v2/content/#{reusable_content_id}/embedded",
path: "/v2/content/#{reusable_content_id}/host-content",
)
.will_respond_with(
status: 200,
body: expected_body,
)

response = api_client.get_content_by_embedded_document(reusable_content_id)
response = api_client.get_host_content_for_content_id(reusable_content_id)

assert_equal(expected_body, response.parsed_content)
end
Expand All @@ -69,10 +69,10 @@

it "returns the first page of results" do
publishing_api_with_multiple_content_items
.upon_receiving("a get_content_by_embedded_document request for multiple pages")
.upon_receiving("a get_host_content_for_content_id request for multiple pages")
.with(
method: :get,
path: "/v2/content/#{reusable_content_id}/embedded",
path: "/v2/content/#{reusable_content_id}/host-content",
)
.will_respond_with(
status: 200,
Expand All @@ -84,15 +84,15 @@
},
)

api_client.get_content_by_embedded_document(reusable_content_id)
api_client.get_host_content_for_content_id(reusable_content_id)
end

it "supports a page argument" do
publishing_api_with_multiple_content_items
.upon_receiving("a get_content_by_embedded_document request for multiple pages with a page argument")
.upon_receiving("a get_host_content_for_content_id request for multiple pages with a page argument")
.with(
method: :get,
path: "/v2/content/#{reusable_content_id}/embedded",
path: "/v2/content/#{reusable_content_id}/host-content",
query: "page=2",
)
.will_respond_with(
Expand All @@ -105,15 +105,15 @@
},
)

api_client.get_content_by_embedded_document(reusable_content_id, { page: 2 })
api_client.get_host_content_for_content_id(reusable_content_id, { page: 2 })
end

it "supports a per page argument" do
publishing_api_with_multiple_content_items
.upon_receiving("a get_content_by_embedded_document request for multiple pages with a per_page argument")
.upon_receiving("a get_host_content_for_content_id request for multiple pages with a per_page argument")
.with(
method: :get,
path: "/v2/content/#{reusable_content_id}/embedded",
path: "/v2/content/#{reusable_content_id}/host-content",
query: "per_page=1",
)
.will_respond_with(
Expand All @@ -126,15 +126,15 @@
},
)

api_client.get_content_by_embedded_document(reusable_content_id, { per_page: 1 })
api_client.get_host_content_for_content_id(reusable_content_id, { per_page: 1 })
end

it "supports sorting" do
publishing_api_with_multiple_content_items
.upon_receiving("a get_content_by_embedded_document request for multiple pages with sorting")
.upon_receiving("a get_host_content_for_content_id request for multiple pages with sorting")
.with(
method: :get,
path: "/v2/content/#{reusable_content_id}/embedded",
path: "/v2/content/#{reusable_content_id}/host-content",
query: "order=-last_edited_at",
)
.will_respond_with(
Expand All @@ -147,25 +147,25 @@
},
)

api_client.get_content_by_embedded_document(reusable_content_id, { order: "-last_edited_at" })
api_client.get_host_content_for_content_id(reusable_content_id, { order: "-last_edited_at" })
end
end

it "responds with 404 if the content item does not exist" do
missing_content_id = "missing-content-id"
publishing_api
.given("no content exists")
.upon_receiving("a get_content_by_embedded_document request")
.upon_receiving("a get_host_content_for_content_id request")
.with(
method: :get,
path: "/v2/content/#{missing_content_id}/embedded",
path: "/v2/content/#{missing_content_id}/host-content",
)
.will_respond_with(
status: 404,
)

assert_raises(GdsApi::HTTPNotFound) do
api_client.get_content_by_embedded_document(missing_content_id)
api_client.get_host_content_for_content_id(missing_content_id)
end
end
end
11 changes: 11 additions & 0 deletions test/publishing_api_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -31,4 +31,15 @@
end
end
end

describe "#get_content_by_embedded_document" do
it "sends a warning and calls #get_host_content_for_content_id" do
content_id = SecureRandom.uuid
args = { some: "args" }
api_client.expects(:warn).with("GdsAPI::PublishingApi: #get_content_by_embedded_document deprecated (please use #get_host_content_for_content_id)")
api_client.expects(:get_host_content_for_content_id).with(content_id, args)

api_client.get_content_by_embedded_document(content_id, args)
end
end
end

0 comments on commit 5d9845e

Please sign in to comment.