From de79700d8e64eb71d3e54eb6a0f50c411111fca5 Mon Sep 17 00:00:00 2001 From: Martin Meyerhoff Date: Wed, 10 Apr 2024 21:14:53 +0200 Subject: [PATCH] Nullify Ingredients::Page on Page destroy When we delete a page, page ingredients that point to that page should be nullified. (cherry picked from commit d183256cd57b80fdb793b634b7e27c662c56b0dd) --- app/models/alchemy/page.rb | 2 ++ spec/models/alchemy/page_spec.rb | 8 ++++++++ 2 files changed, 10 insertions(+) diff --git a/app/models/alchemy/page.rb b/app/models/alchemy/page.rb index 98400542cc..005559b56f 100644 --- a/app/models/alchemy/page.rb +++ b/app/models/alchemy/page.rb @@ -121,6 +121,8 @@ class Page < BaseRecord has_one :draft_version, -> { drafts }, class_name: "Alchemy::PageVersion" has_one :public_version, -> { published }, class_name: "Alchemy::PageVersion", autosave: -> { persisted? } + has_many :page_ingredients, class_name: "Alchemy::Ingredients::Page", foreign_key: :related_object_id, dependent: :nullify + before_validation :set_language, if: -> { language.nil? } diff --git a/spec/models/alchemy/page_spec.rb b/spec/models/alchemy/page_spec.rb index 32dce44585..713bb2f8cc 100644 --- a/spec/models/alchemy/page_spec.rb +++ b/spec/models/alchemy/page_spec.rb @@ -224,6 +224,14 @@ module Alchemy it "destroys elements along with itself" do expect { page.destroy! }.to change(Alchemy::Element, :count).from(3).to(0) end + + context "with a page ingredient pointing to the page" do + let!(:ingredient) { create(:alchemy_ingredient_page, page: page) } + + it "nullifies the foreign key on the ingredient" do + expect { page.destroy! }.to change { ingredient.reload.related_object_id }.from(page.id).to(nil) + end + end end end