FIX: Updating avatar didn't trigger a rebake of posts with quotes of the user (#27184)

This commit is contained in:
Gerhard Schlager 2024-05-27 09:57:48 +02:00 committed by GitHub
parent 9aede9c8d8
commit 5e61d55940
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 25 additions and 1 deletions

View File

@ -1485,7 +1485,7 @@ class User < ActiveRecord::Base
end end
# mark all the user's quoted posts as "needing a rebake" # mark all the user's quoted posts as "needing a rebake"
Post.rebake_all_quoted_posts(self.id) if self.will_save_change_to_uploaded_avatar_id? Post.rebake_all_quoted_posts(self.id) if saved_change_to_uploaded_avatar_id?
end end
def first_post_created_at def first_post_created_at

View File

@ -669,6 +669,30 @@ RSpec.describe User do
expect(user.user_option.email_messages_level).to eq(UserOption.email_level_types[:always]) expect(user.user_option.email_messages_level).to eq(UserOption.email_level_types[:always])
expect(user.user_option.email_level).to eq(UserOption.email_level_types[:only_when_away]) expect(user.user_option.email_level).to eq(UserOption.email_level_types[:only_when_away])
end end
context "with avatar" do
let(:user) { build(:user, uploaded_avatar_id: 99, username: "Sam") }
it "mark all the user's quoted posts as 'needing a rebake' when the avatar changes" do
topic = Fabricate(:topic, user: user)
quoted_post = create_post(user: user, topic: topic, post_number: 1, raw: "quoted post")
post = create_post(raw: <<~RAW)
Lorem ipsum
[quote="#{user.username}, post:1, topic:#{quoted_post.topic.id}"]
quoted post
[/quote]
RAW
expect(post.baked_version).not_to be_nil
user.update!(name: "Sam")
expect(post.reload.baked_version).not_to be_nil
user.update!(uploaded_avatar_id: 100)
expect(post.reload.baked_version).to be_nil
end
end
end end
it "downcases email addresses" do it "downcases email addresses" do