diff --git a/app/helpers/admin/republishing_helper.rb b/app/helpers/admin/republishing_helper.rb index 8ce6860f56c..c5712d6cbf7 100644 --- a/app/helpers/admin/republishing_helper.rb +++ b/app/helpers/admin/republishing_helper.rb @@ -24,6 +24,13 @@ def bulk_content_type_metadata confirmation_path: admin_bulk_republishing_all_confirm_path("all-documents-with-pre-publication-editions-with-html-attachments"), republish_method: -> { BulkRepublisher.new.republish_all_documents_with_pre_publication_editions_with_html_attachments }, }, + all_documents_with_publicly_visible_editions_with_attachments: { + id: "all-documents-with-publicly-visible-editions-with-attachments", + name: "all documents with publicly-visible editions with attachments", + republishing_path: admin_bulk_republishing_all_republish_path("all-documents-with-publicly-visible-editions-with-attachments"), + confirmation_path: admin_bulk_republishing_all_confirm_path("all-documents-with-publicly-visible-editions-with-attachments"), + republish_method: -> { BulkRepublisher.new.republish_all_documents_with_publicly_visible_editions_with_attachments }, + }, all_documents_with_publicly_visible_editions_with_html_attachments: { id: "all-documents-with-publicly-visible-editions-with-html-attachments", name: "all documents with publicly-visible editions with HTML attachments", diff --git a/app/models/republishing_event.rb b/app/models/republishing_event.rb index 3db8f6c3137..bd8a187b8ba 100644 --- a/app/models/republishing_event.rb +++ b/app/models/republishing_event.rb @@ -12,6 +12,7 @@ class RepublishingEvent < ApplicationRecord all_documents all_documents_with_pre_publication_editions all_documents_with_pre_publication_editions_with_html_attachments + all_documents_with_publicly_visible_editions_with_attachments all_documents_with_publicly_visible_editions_with_html_attachments all_published_organisation_about_us_pages ] diff --git a/app/services/bulk_republisher.rb b/app/services/bulk_republisher.rb index 7b0050d484e..50bd0a73acd 100644 --- a/app/services/bulk_republisher.rb +++ b/app/services/bulk_republisher.rb @@ -23,6 +23,15 @@ def republish_all_documents_with_pre_publication_editions_with_html_attachments republish_by_document_ids(document_ids) end + def republish_all_documents_with_publicly_visible_editions_with_attachments + document_ids = Edition + .publicly_visible + .where(id: Attachment.where(attachable_type: "Edition").select(:attachable_id)) + .pluck(:document_id) + + republish_by_document_ids(document_ids) + end + def republish_all_documents_with_publicly_visible_editions_with_html_attachments document_ids = Edition .publicly_visible diff --git a/features/bulk-republishing-content.feature b/features/bulk-republishing-content.feature index bfcfe1b5ce0..6cd140c1df1 100644 --- a/features/bulk-republishing-content.feature +++ b/features/bulk-republishing-content.feature @@ -21,6 +21,11 @@ Feature: Bulk republishing content When I request a bulk republishing of all documents with pre-publication editions with HTML attachments Then I can see that all documents with pre-publication editions with HTML attachments have been queued for republishing + Scenario: Republish all documents with publicly-visible editions with attachments + Given Documents with publicly-visible editions with attachments exist + When I request a bulk republishing of all documents with publicly-visible editions with attachments + Then I can see that all documents with publicly-visible editions with attachments have been queued for republishing + Scenario: Republish all documents with publicly-visible editions with HTML attachments Given Documents with publicly-visible editions with HTML attachments exist When I request a bulk republishing of all documents with publicly-visible editions with HTML attachments diff --git a/features/step_definitions/bulk_republishing_content_steps.rb b/features/step_definitions/bulk_republishing_content_steps.rb index e7489a2bf06..651fdc36f8d 100644 --- a/features/step_definitions/bulk_republishing_content_steps.rb +++ b/features/step_definitions/bulk_republishing_content_steps.rb @@ -47,6 +47,24 @@ expect(page).to have_selector(".gem-c-success-alert", text: "All documents with pre-publication editions with HTML attachments have been queued for republishing") end +Given(/^Documents with publicly-visible editions with attachments exist$/) do + 2.times do + document = create(:document, editions: [build(:published_edition), build(:draft_edition)]) + create(:attachment, attachable_type: "Edition", attachable_id: document.live_edition.id) + end +end + +When(/^I request a bulk republishing of all documents with publicly-visible editions with attachments$/) do + visit admin_republishing_index_path + find("#all-documents-with-publicly-visible-editions-with-attachments").click + fill_in "What is the reason for republishing?", with: "It needs republishing" + click_button("Confirm republishing") +end + +Then(/^I can see that all documents with publicly-visible editions with attachments have been queued for republishing$/) do + expect(page).to have_selector(".gem-c-success-alert", text: "All documents with publicly-visible editions with attachments have been queued for republishing") +end + Given(/^Documents with publicly-visible editions with HTML attachments exist$/) do 2.times do document = create(:document, editions: [build(:published_edition), build(:draft_edition)]) diff --git a/test/functional/admin/republishing_controller_test.rb b/test/functional/admin/republishing_controller_test.rb index a0e2ff052c3..b6c467b8aa8 100644 --- a/test/functional/admin/republishing_controller_test.rb +++ b/test/functional/admin/republishing_controller_test.rb @@ -22,8 +22,9 @@ class Admin::RepublishingControllerTest < ActionController::TestCase assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(1) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents/confirm']", text: "Republish all documents" assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(2) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents-with-pre-publication-editions/confirm']", text: "Republish all documents with pre-publication editions" assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(3) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents-with-pre-publication-editions-with-html-attachments/confirm']", text: "Republish all documents with pre-publication editions with HTML attachments" - assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(4) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents-with-publicly-visible-editions-with-html-attachments/confirm']", text: "Republish all documents with publicly-visible editions with HTML attachments" - assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(5) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-published-organisation-about-us-pages/confirm']", text: "Republish all published organisation 'About us' pages" + assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(4) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents-with-publicly-visible-editions-with-attachments/confirm']", text: "Republish all documents with publicly-visible editions with attachments" + assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(5) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-documents-with-publicly-visible-editions-with-html-attachments/confirm']", text: "Republish all documents with publicly-visible editions with HTML attachments" + assert_select ".govuk-table:nth-of-type(3) .govuk-table__body .govuk-table__row:nth-child(6) .govuk-table__cell:nth-child(2) a[href='/government/admin/republishing/bulk/all-published-organisation-about-us-pages/confirm']", text: "Republish all published organisation 'About us' pages" assert_response :ok end diff --git a/test/unit/app/services/bulk_republisher_test.rb b/test/unit/app/services/bulk_republisher_test.rb index 6a0f064a80e..ec5a0766bc8 100644 --- a/test/unit/app/services/bulk_republisher_test.rb +++ b/test/unit/app/services/bulk_republisher_test.rb @@ -3,34 +3,6 @@ class BulkRepublisherTest < ActiveSupport::TestCase extend Minitest::Spec::DSL - describe "#republish_all_published_organisation_about_us_pages" do - test "queues all published organisation 'About us' pages for republishing" do - queue_sequence = sequence("queue") - - 2.times do - about_us_page = create(:about_corporate_information_page) - - PublishingApiDocumentRepublishingWorker - .expects(:perform_async_in_queue) - .with("bulk_republishing", about_us_page.document_id, true) - .in_sequence(queue_sequence) - end - - BulkRepublisher.new.republish_all_published_organisation_about_us_pages - end - - test "doesn't queue draft organisation 'About us' pages for republishing" do - about_us_page = create(:draft_about_corporate_information_page) - - PublishingApiDocumentRepublishingWorker - .expects(:perform_async_in_queue) - .with("bulk_republishing", about_us_page.document_id, true) - .never - - BulkRepublisher.new.republish_all_published_organisation_about_us_pages - end - end - describe "#republish_all_documents" do test "queues all documents for republishing" do queue_sequence = sequence("queue") @@ -118,6 +90,48 @@ class BulkRepublisherTest < ActiveSupport::TestCase end end + describe "#republish_all_documents_with_publicly_visible_editions_with_attachments" do + test "queues all documents with publicly-visible editions with attachments for republishing" do + queue_sequence = sequence("queue") + + 2.times do + document = create(:document, editions: [build(:published_edition), build(:draft_edition)]) + create(:attachment, attachable_type: "Edition", attachable_id: document.live_edition.id) + + PublishingApiDocumentRepublishingWorker + .expects(:perform_async_in_queue) + .with("bulk_republishing", document.id, true) + .in_sequence(queue_sequence) + end + + BulkRepublisher.new.republish_all_documents_with_publicly_visible_editions_with_attachments + end + + test "doesn't queue documents for republishing if the editions with attachments aren't publicly-visible editions" do + draft_edition = build(:draft_edition) + document = create(:document, editions: [draft_edition]) + create(:attachment, attachable_type: "Edition", attachable_id: draft_edition.id) + + PublishingApiDocumentRepublishingWorker + .expects(:perform_async_in_queue) + .with("bulk_republishing", document.id, true) + .never + + BulkRepublisher.new.republish_all_documents_with_publicly_visible_editions_with_attachments + end + + test "doesn't queue documents republishing when there are publicly-visible editions but none have attachments" do + document = create(:document, editions: [build(:published_edition), build(:draft_edition)]) + + PublishingApiDocumentRepublishingWorker + .expects(:perform_async_in_queue) + .with("bulk_republishing", document.id, true) + .never + + BulkRepublisher.new.republish_all_documents_with_publicly_visible_editions_with_attachments + end + end + describe "#republish_all_documents_with_publicly_visible_editions_with_html_attachments" do test "queues all documents with publicly-visible editions with HTML attachments for republishing" do queue_sequence = sequence("queue") @@ -159,4 +173,32 @@ class BulkRepublisherTest < ActiveSupport::TestCase BulkRepublisher.new.republish_all_documents_with_publicly_visible_editions_with_html_attachments end end + + describe "#republish_all_published_organisation_about_us_pages" do + test "queues all published organisation 'About us' pages for republishing" do + queue_sequence = sequence("queue") + + 2.times do + about_us_page = create(:about_corporate_information_page) + + PublishingApiDocumentRepublishingWorker + .expects(:perform_async_in_queue) + .with("bulk_republishing", about_us_page.document_id, true) + .in_sequence(queue_sequence) + end + + BulkRepublisher.new.republish_all_published_organisation_about_us_pages + end + + test "doesn't queue draft organisation 'About us' pages for republishing" do + about_us_page = create(:draft_about_corporate_information_page) + + PublishingApiDocumentRepublishingWorker + .expects(:perform_async_in_queue) + .with("bulk_republishing", about_us_page.document_id, true) + .never + + BulkRepublisher.new.republish_all_published_organisation_about_us_pages + end + end end