FIX: Refresh whole post stream when category changes (#111)

Only if the old and new category have different 'solved' settings.
This commit is contained in:
Bianca Nenciu 2021-01-20 12:26:37 +02:00 committed by GitHub
parent c407e0f0f4
commit 6d91419caf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 41 additions and 0 deletions

View File

@ -602,4 +602,14 @@ SQL
SQL SQL
}) })
end end
on(:before_post_publish_changes) do |post_changes, topic_changes, options|
category_id_changes = topic_changes.diff["category_id"]
next if category_id_changes.blank?
old_category_allows = Guardian.new.allow_accepted_answers_on_category?(category_id_changes[0])
new_category_allows = Guardian.new.allow_accepted_answers_on_category?(category_id_changes[1])
options[:refresh_stream] = true if old_category_allows != new_category_allows
end
end end

View File

@ -0,0 +1,31 @@
# frozen_string_literal: true
require 'rails_helper'
require 'post_revisor'
describe PostRevisor do
fab!(:category) { Fabricate(:category_with_definition) }
fab!(:category_solved) do
category = Fabricate(:category_with_definition)
category.upsert_custom_fields("enable_accepted_answers" => "true")
category
end
it "refreshes post stream when topic category changes to a solved category" do
topic = Fabricate(:topic, category: Fabricate(:category_with_definition))
post = Fabricate(:post, topic: topic)
messages = MessageBus.track_publish("/topic/#{topic.id}") do
described_class.new(post).revise!(Fabricate(:admin), { category_id: category.id })
end
expect(messages.first.data[:refresh_stream]).to eq(nil)
messages = MessageBus.track_publish("/topic/#{topic.id}") do
described_class.new(post).revise!(Fabricate(:admin), { category_id: category_solved.id })
end
expect(messages.first.data[:refresh_stream]).to eq(true)
end
end