From 35e1c56655dfb1e26ee741e0b60cf898909fcbf3 Mon Sep 17 00:00:00 2001 From: Callum Knights Date: Mon, 9 Dec 2024 15:08:00 +0000 Subject: [PATCH] Add bare minimum presenter for editionable topical event --- app/models/editionable_topical_event.rb | 8 ++++ .../editionable_topical_event_presenter.rb | 40 +++++++++++++++++ ...ditionable_topical_event_presenter_test.rb | 43 +++++++++++++++++++ 3 files changed, 91 insertions(+) create mode 100644 app/presenters/publishing_api/editionable_topical_event_presenter.rb create mode 100644 test/unit/app/presenters/publishing_api/editionable_topical_event_presenter_test.rb diff --git a/app/models/editionable_topical_event.rb b/app/models/editionable_topical_event.rb index 21f905102c4..6b509e92a8a 100644 --- a/app/models/editionable_topical_event.rb +++ b/app/models/editionable_topical_event.rb @@ -3,6 +3,14 @@ def display_type_key "editionable_topical_event" end + def publishing_api_presenter + PublishingApi::EditionableTopicalEventPresenter + end + + def base_path + "/government/editionable-topical-events/#{slug}" + end + def self.format_name "topical event" end diff --git a/app/presenters/publishing_api/editionable_topical_event_presenter.rb b/app/presenters/publishing_api/editionable_topical_event_presenter.rb new file mode 100644 index 00000000000..864980c03cc --- /dev/null +++ b/app/presenters/publishing_api/editionable_topical_event_presenter.rb @@ -0,0 +1,40 @@ +module PublishingApi + class EditionableTopicalEventPresenter + include Rails.application.routes.url_helpers + include ActionView::Helpers::UrlHelper + + attr_accessor :item, :update_type, :state + + def initialize(item, update_type: nil, state: "published") + self.item = item + self.update_type = update_type || "major" + self.state = state + end + + delegate :content_id, to: :item + + def content + content = BaseItemPresenter.new( + item, + update_type:, + ).base_attributes + + content.merge!( + details:, + document_type: item.class.name.underscore, + public_updated_at: item.updated_at, + rendering_app: Whitehall::RenderingApp::COLLECTIONS_FRONTEND, + schema_name: "topical_event", + ) + content.merge!(PayloadBuilder::PolymorphicPath.for(item)) + end + + def links + {} + end + + def details + {} + end + end +end diff --git a/test/unit/app/presenters/publishing_api/editionable_topical_event_presenter_test.rb b/test/unit/app/presenters/publishing_api/editionable_topical_event_presenter_test.rb new file mode 100644 index 00000000000..c9d07ac19a2 --- /dev/null +++ b/test/unit/app/presenters/publishing_api/editionable_topical_event_presenter_test.rb @@ -0,0 +1,43 @@ +require "test_helper" + +class PublishingApi::EditionableTopicalEventPresenterTest < ActiveSupport::TestCase + def present(...) + PublishingApi::EditionableTopicalEventPresenter.new(...) + end + + test "presents a Topical Event ready for adding to the publishing API" do + topical_event = create(:editionable_topical_event) + + public_path = topical_event.public_path + + expected_hash = { + base_path: public_path, + title: topical_event.title, + schema_name: "topical_event", + document_type: "editionable_topical_event", + locale: "en", + publishing_app: Whitehall::PublishingApp::WHITEHALL, + rendering_app: Whitehall::RenderingApp::COLLECTIONS_FRONTEND, + public_updated_at: topical_event.updated_at, + routes: [{ path: public_path, type: "exact" }], + redirects: [], + details: {}, + update_type: "major", + } + + expected_links = {} + + presented_item = present(topical_event) + + assert_equal expected_hash, presented_item.content + assert_equal "major", presented_item.update_type + assert_equal topical_event.content_id, presented_item.content_id + + # TODO: uncomment the below assertion when the editionable_topical_event model is + # finished and all content can be added to this presenter. + # assert_valid_against_publisher_schema(presented_item.content, "topical_event") + + assert_equal expected_links, presented_item.links + assert_valid_against_links_schema({ links: presented_item.links }, "topical_event") + end +end