FIX: post counts in user stats when changing post owner

This commit is contained in:
Neil Lalonde 2017-11-02 17:48:48 -04:00
parent 21dd2ccd43
commit 18d65fe7e5
2 changed files with 35 additions and 7 deletions

View File

@ -290,9 +290,11 @@ class PostRevisor
private_message = @post.topic.private_message? private_message = @post.topic.private_message?
prev_owner_user_stat = prev_owner.user_stat prev_owner_user_stat = prev_owner.user_stat
prev_owner_user_stat.post_count -= 1 unless private_message
prev_owner_user_stat.post_count -= 1 if @post.post_type == Post.types[:regular]
prev_owner_user_stat.topic_count -= 1 if @post.is_first_post? prev_owner_user_stat.topic_count -= 1 if @post.is_first_post?
prev_owner_user_stat.likes_received -= likes if !private_message prev_owner_user_stat.likes_received -= likes
end
prev_owner_user_stat.update_topic_reply_count prev_owner_user_stat.update_topic_reply_count
if @post.created_at == prev_owner.user_stat.first_post_created_at if @post.created_at == prev_owner.user_stat.first_post_created_at
@ -302,9 +304,11 @@ class PostRevisor
prev_owner_user_stat.save! prev_owner_user_stat.save!
new_owner_user_stat = new_owner.user_stat new_owner_user_stat = new_owner.user_stat
new_owner_user_stat.post_count += 1 unless private_message
new_owner_user_stat.post_count += 1 if @post.post_type == Post.types[:regular]
new_owner_user_stat.topic_count += 1 if @post.is_first_post? new_owner_user_stat.topic_count += 1 if @post.is_first_post?
new_owner_user_stat.likes_received += likes if !private_message new_owner_user_stat.likes_received += likes
end
new_owner_user_stat.update_topic_reply_count new_owner_user_stat.update_topic_reply_count
new_owner_user_stat.save! new_owner_user_stat.save!
end end

View File

@ -131,19 +131,43 @@ describe PostOwnerChanger do
expect(user_a_stat.likes_received).to eq(1) expect(user_a_stat.likes_received).to eq(1)
end end
it "handles whispers" do
whisper = PostCreator.new(
editor,
topic_id: p1.topic_id,
reply_to_post_number: 1,
post_type: Post.types[:whisper],
raw: 'this is a whispered reply'
).create
user_stat = editor.user_stat
expect {
described_class.new(
post_ids: [whisper.id],
topic_id: topic.id,
new_owner: Fabricate(:admin),
acting_user: editor
).change_owner!
}.to_not change { user_stat.reload.post_count }
end
context 'private message topic' do context 'private message topic' do
let(:topic) { Fabricate(:private_message_topic) } let(:topic) { Fabricate(:private_message_topic) }
it "should update users' counts" do it "should update users' counts" do
PostAction.act(p2user, p1, PostActionType.types[:like]) PostAction.act(p2user, p1, PostActionType.types[:like])
expect {
change_owners change_owners
}.to_not change { p1user.user_stat.post_count }
expect(p1user.user_stat.likes_received).to eq(0) expect(p1user.user_stat.likes_received).to eq(0)
user_a_stat = user_a.user_stat user_a_stat = user_a.user_stat
expect(user_a_stat.first_post_created_at).to be_present expect(user_a_stat.first_post_created_at).to be_present
expect(user_a_stat.likes_received).to eq(0) expect(user_a_stat.likes_received).to eq(0)
expect(user_a_stat.post_count).to eq(0)
end end
end end