FIX: post edited webhook does not reflect updated topic title

This fix ensures that when a topic title is edited the new title shows
up in the post webhook instead of the old title.

Rather than passing in the old topic object to the PostRevisor the
PostRevisor initializer will load the updated topic object inside of the
initializer if you don't pass it in. This will allow the post_edited
webhook to have the correct topic values.

Original bug reported at:

https://meta.discourse.org/t/post-edited-webhook-does-not-reflect-updated-topic-title/144722
This commit is contained in:
Blake Erickson 2020-03-21 07:33:10 -06:00
parent dbfec4b268
commit c97244ca11
2 changed files with 11 additions and 1 deletions

View File

@ -366,7 +366,7 @@ class TopicsController < ApplicationController
if changes.length > 0 if changes.length > 0
first_post = topic.ordered_posts.first first_post = topic.ordered_posts.first
success = PostRevisor.new(first_post, topic).revise!(current_user, changes, validate_post: false) success = PostRevisor.new(first_post).revise!(current_user, changes, validate_post: false)
end end
# this is used to return the title to the client as it may have been changed by "TextCleaner" # this is used to return the title to the client as it may have been changed by "TextCleaner"

View File

@ -946,6 +946,9 @@ RSpec.describe TopicsController do
end end
describe 'with permission' do describe 'with permission' do
fab!(:post_hook) { Fabricate(:post_web_hook) }
fab!(:topic_hook) { Fabricate(:topic_web_hook) }
it 'succeeds' do it 'succeeds' do
put "/t/#{topic.slug}/#{topic.id}.json" put "/t/#{topic.slug}/#{topic.id}.json"
@ -971,6 +974,13 @@ RSpec.describe TopicsController do
topic.reload topic.reload
expect(topic.title).to eq('This is a new title for the topic') expect(topic.title).to eq('This is a new title for the topic')
expect(Jobs::EmitWebHookEvent.jobs.length).to eq(2)
job_args = Jobs::EmitWebHookEvent.jobs[0]["args"].first
expect(job_args["event_name"]).to eq("post_edited")
payload = JSON.parse(job_args["payload"])
expect(payload["topic_title"]).to eq('This is a new title for the topic')
end end
it "returns errors with invalid titles" do it "returns errors with invalid titles" do