DEV: Add reviewables:populate rake task (#30540)

Adds a new reviewables:populate rake task that works in a similar fashion to the existing *:populate rake tasks. The rake task creates pending reviewable of all core types, with possibility for plugins to extend the task to populate their own reviewable types.
This commit is contained in:
Osama Sayegh 2025-01-03 05:05:04 +03:00 committed by GitHub
parent 4aa7a89371
commit 5a55c9062a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 186 additions and 3 deletions

View File

@ -13,6 +13,10 @@ class ReviewablePost < Reviewable
created_or_edited_by.has_trust_level?(TrustLevel[4]) created_or_edited_by.has_trust_level?(TrustLevel[4])
return return
end end
queue_for_review(post)
end
def self.queue_for_review(post)
system_user = Discourse.system_user system_user = Discourse.system_user
needs_review!( needs_review!(

View File

@ -37,7 +37,7 @@ module DiscourseDev
raise 'To run this rake task in a production site, set the value of `ALLOW_DEV_POPULATE` environment variable to "1"' raise 'To run this rake task in a production site, set the value of `ALLOW_DEV_POPULATE` environment variable to "1"'
end end
unless ignore_current_count || @ignore_current_count if !ignore_current_count && !@ignore_current_count
if current_count >= @count if current_count >= @count
puts "Already have #{current_count} #{type} records" puts "Already have #{current_count} #{type} records"

View File

@ -0,0 +1,62 @@
# frozen_string_literal: true
require "discourse_dev/record"
require "faker"
module DiscourseDev
class Reviewable < Record
def initialize(users, topics, posts)
@users = users
@topics = topics
@posts = posts
end
def self.populate!
users = create_needed_users(10)
topics = create_needed_topics(5)
posts = create_needed_posts(10, topics)
(
[ReviewableFlaggedPost, ReviewableQueuedPost, ReviewablePost, ReviewableUser] +
DiscoursePluginRegistry.discourse_dev_populate_reviewable_types.to_a
).each { |klass| klass.new(users, topics, posts).populate! }
end
private
def self.create_needed_users(count)
users = ::User.human_users.limit(count).to_a
(count - users.size).times { users << User.new.create! } if users.size < count
users
end
def self.create_needed_topics(count)
topics =
::Topic
.listable_topics
.where("id NOT IN (?)", ::Category.pluck(:topic_id))
.limit(count)
.to_a
(count - topics.size).times { topics << Topic.new.create! } if topics.size < count
topics
end
def self.create_needed_posts(count, topics)
per_topic = count / topics.size
posts = []
topics.each do |topic|
current_count = topic.posts.where("post_number > 1").count
(count - current_count).times { Post.new(topic, 1).create! } if current_count < count
posts.push(*topic.posts.where("post_number > 1").limit(per_topic).to_a)
end
posts
end
end
end

View File

@ -0,0 +1,35 @@
# frozen_string_literal: true
require "discourse_dev/reviewable"
require "faker"
module DiscourseDev
class ReviewableFlaggedPost < Reviewable
def populate!
types = PostActionType.notify_flag_types.keys
posts = @posts.sample(types.size + 1)
users = @users.sample(types.size + 3)
types.each do |type|
post = posts.pop
user = users.pop
reason = nil
reason = Faker::Lorem.paragraph if type == :notify_moderators
PostActionCreator.create(user, post, type, reason:)
end
posts.pop.tap do |post|
type = types.excluding(:notify_moderators).sample
3.times do
user = users.pop
PostActionCreator.create(user, post, type)
end
end
end
end
end

View File

@ -0,0 +1,12 @@
# frozen_string_literal: true
require "discourse_dev/reviewable"
require "faker"
module DiscourseDev
class ReviewablePost < Reviewable
def populate!
@posts.sample(2).each { |post| ::ReviewablePost.queue_for_review(post) }
end
end
end

View File

@ -0,0 +1,27 @@
# frozen_string_literal: true
require "discourse_dev/reviewable"
require "faker"
module DiscourseDev
class ReviewableQueuedPost < Reviewable
def populate!
2.times do
topic = @topics.sample
manager =
NewPostManager.new(
@users.sample,
{
topic_id: topic.id,
raw: Faker::DiscourseMarkdown.sandwich(sentences: 3),
tags: nil,
typing_duration_msecs: Faker::Number.between(from: 2_000, to: 5_000),
composer_open_duration_msecs: Faker::Number.between(from: 5_500, to: 10_000),
reply_to_post_number: topic.posts.sample.post_number,
},
)
manager.enqueue(:watched_word, creator_opts: { skip_validations: true })
end
end
end
end

View File

@ -0,0 +1,37 @@
# frozen_string_literal: true
require "discourse_dev/reviewable"
require "faker"
module DiscourseDev
class ReviewableUser < Reviewable
def populate!
reasons = %i[must_approve_users invite_only suspect_user]
@users
.sample(reasons.size)
.zip(reasons)
.each do |(user, reason)|
reviewable =
::ReviewableUser.needs_review!(
target: user,
created_by: Discourse.system_user,
reviewable_by_moderator: true,
payload: {
username: user.username,
name: user.name,
email: user.email,
bio: user.user_profile&.bio_raw,
website: user.user_profile&.website,
},
)
reviewable.add_score(
Discourse.system_user,
ReviewableScore.types[:needs_approval],
reason:,
force_review: true,
)
end
end
end
end

View File

@ -73,6 +73,7 @@ class DiscoursePluginRegistry
define_register :groups_callback_for_users_search_controller_action, Hash define_register :groups_callback_for_users_search_controller_action, Hash
define_register :mail_pollers, Set define_register :mail_pollers, Set
define_register :site_setting_areas, Set define_register :site_setting_areas, Set
define_register :discourse_dev_populate_reviewable_types, Set
define_filtered_register :staff_user_custom_fields define_filtered_register :staff_user_custom_fields
define_filtered_register :public_user_custom_fields define_filtered_register :public_user_custom_fields

View File

@ -253,7 +253,7 @@ class NewPostManager
end end
# Enqueue this post # Enqueue this post
def enqueue(reason = nil) def enqueue(reason = nil, creator_opts: {})
result = NewPostResult.new(:enqueued) result = NewPostResult.new(:enqueued)
payload = { raw: @args[:raw], tags: @args[:tags] } payload = { raw: @args[:raw], tags: @args[:tags] }
%w[typing_duration_msecs composer_open_duration_msecs reply_to_post_number].each do |a| %w[typing_duration_msecs composer_open_duration_msecs reply_to_post_number].each do |a|
@ -277,7 +277,7 @@ class NewPostManager
reviewable.category_id = args[:category] if args[:category].present? reviewable.category_id = args[:category] if args[:category].present?
reviewable.created_new! reviewable.created_new!
create_options = reviewable.create_options create_options = reviewable.create_options.merge(creator_opts)
creator = creator =
( (

View File

@ -29,6 +29,11 @@ task "topics:populate" => ["db:load_config"] do |_, args|
end end
end end
desc "Creates sample reviewables"
task "reviewables:populate" => ["db:load_config"] do |_, args|
DiscourseDev::Reviewable.populate!
end
desc "Creates sample private messages" desc "Creates sample private messages"
task "private_messages:populate", [:recipient] => ["db:load_config"] do |_, args| task "private_messages:populate", [:recipient] => ["db:load_config"] do |_, args|
args.with_defaults(type: "string") args.with_defaults(type: "string")