mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 11:42:53 +08:00
FIX: Ignore posts needing approval when calculating reviewable counts. (#13464)
In #12841, we started setting the ReviewableQueuedPost's target and topic after approving it instead of storing them in the payload. As a result, the reviewable_counts query started to include queued posts. When a category is set to require approval, every post has an associated reviewable. Pointing that each post has an associated queued post is not necessary in this case, so I added a WHERE clause to skip them.
This commit is contained in:
parent
e76c583b91
commit
e0e1e24c14
|
@ -509,7 +509,8 @@ class TopicView
|
||||||
reviewable_scores s ON reviewable_id = r.id
|
reviewable_scores s ON reviewable_id = r.id
|
||||||
WHERE
|
WHERE
|
||||||
r.target_id IN (:post_ids) AND
|
r.target_id IN (:post_ids) AND
|
||||||
r.target_type = 'Post'
|
r.target_type = 'Post' AND
|
||||||
|
COALESCE(s.reason, '') != 'category'
|
||||||
GROUP BY
|
GROUP BY
|
||||||
target_id
|
target_id
|
||||||
SQL
|
SQL
|
||||||
|
|
|
@ -915,4 +915,41 @@ describe TopicView do
|
||||||
expect(topic_view.show_read_indicator?).to be_falsey
|
expect(topic_view.show_read_indicator?).to be_falsey
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#reviewable_counts' do
|
||||||
|
it 'exclude posts queued because the category needs approval' do
|
||||||
|
category = Fabricate.build(:category, user: admin)
|
||||||
|
category.custom_fields[Category::REQUIRE_TOPIC_APPROVAL] = true
|
||||||
|
category.save!
|
||||||
|
manager = NewPostManager.new(
|
||||||
|
user,
|
||||||
|
raw: 'to the handler I say enqueue me!',
|
||||||
|
title: 'this is the title of the queued post',
|
||||||
|
category: category.id
|
||||||
|
)
|
||||||
|
result = manager.perform
|
||||||
|
reviewable = result.reviewable
|
||||||
|
reviewable.perform(admin, :approve_post)
|
||||||
|
|
||||||
|
topic_view = TopicView.new(reviewable.topic, admin)
|
||||||
|
|
||||||
|
expect(topic_view.reviewable_counts).to be_empty
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'include posts queued for other reasons' do
|
||||||
|
Fabricate(:watched_word, word: "darn", action: WatchedWord.actions[:require_approval])
|
||||||
|
manager = NewPostManager.new(
|
||||||
|
user,
|
||||||
|
raw: 'this is darn new post content',
|
||||||
|
title: 'this is the title of the queued post'
|
||||||
|
)
|
||||||
|
result = manager.perform
|
||||||
|
reviewable = result.reviewable
|
||||||
|
reviewable.perform(admin, :approve_post)
|
||||||
|
|
||||||
|
topic_view = TopicView.new(reviewable.topic, admin)
|
||||||
|
|
||||||
|
expect(topic_view.reviewable_counts.keys).to contain_exactly(reviewable.target_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue
Block a user