DEV: Move autotag to topic creator (#12790)

This move was necessary to automatically tag the topic with the right
tags from creation time. The process post job may be delayed for a
short time.
This commit is contained in:
Bianca Nenciu 2021-04-23 16:55:34 +03:00 committed by GitHub
parent a97e3e249d
commit 8c4a11c006
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 43 additions and 63 deletions

View File

@ -36,7 +36,6 @@ module Jobs
post.update_column(:cooked, cp.html) post.update_column(:cooked, cp.html)
post.topic.update_excerpt(post.excerpt_for_topic) if post.is_first_post? post.topic.update_excerpt(post.excerpt_for_topic) if post.is_first_post?
extract_links(post) extract_links(post)
auto_tag(post) if SiteSetting.tagging_enabled? && post.post_number == 1
post.publish_change_to_clients! :revised post.publish_change_to_clients! :revised
end end
end end
@ -61,25 +60,6 @@ module Jobs
TopicLink.extract_from(post) TopicLink.extract_from(post)
QuotedPost.extract_from(post) QuotedPost.extract_from(post)
end end
def auto_tag(post)
word_watcher = WordWatcher.new("#{post.topic.title} #{post.raw}")
old_tags = post.topic.tags.pluck(:name).to_set
new_tags = old_tags.dup
WordWatcher.words_for_action(:tag).each do |word, tags|
new_tags += tags.split(",") if word_watcher.matches?(word)
end
if old_tags != new_tags
post.revise(
Discourse.system_user,
tags: new_tags.to_a,
edit_reason: I18n.t(:watched_words_auto_tag)
)
end
end
end end
end end

View File

@ -176,6 +176,16 @@ class TopicCreator
topic.errors.add(:base, :unable_to_tag) topic.errors.add(:base, :unable_to_tag)
rollback_from_errors!(topic) rollback_from_errors!(topic)
end end
guardian = Guardian.new(Discourse.system_user)
word_watcher = WordWatcher.new("#{@opts[:title]} #{@opts[:raw]}")
word_watcher_tags = topic.tags.map(&:name)
WordWatcher.words_for_action(:tag).each do |word, tags|
if word_watcher.matches?(word)
word_watcher_tags += tags.split(",")
end
end
DiscourseTagging.tag_topic_by_names(topic, guardian, word_watcher_tags)
end end
def setup_auto_close_time(topic) def setup_auto_close_time(topic)

View File

@ -494,6 +494,39 @@ describe PostCreator do
expect(@post.topic.tags.map(&:name)).to eq([existing_tag1.name]) expect(@post.topic.tags.map(&:name)).to eq([existing_tag1.name])
end end
end end
context "automatically tags first posts" do
before do
SiteSetting.min_trust_to_create_tag = 0
SiteSetting.min_trust_level_to_tag_topics = 0
end
context "without regular expressions" do
it "works" do
Fabricate(:watched_word, action: WatchedWord.actions[:tag], word: "hello", replacement: "greetings , hey")
@post = creator_with_tags.create
expect(@post.topic.tags.map(&:name)).to match_array(tag_names + ['greetings', 'hey'])
end
it "does not treat as regular expressions" do
Fabricate(:watched_word, action: WatchedWord.actions[:tag], word: "he(llo|y)", replacement: "greetings , hey")
@post = creator_with_tags.create
expect(@post.topic.tags.map(&:name)).to match_array(tag_names)
end
end
context "with regular expressions" do
it "works" do
SiteSetting.watched_words_regular_expressions = true
Fabricate(:watched_word, action: WatchedWord.actions[:tag], word: "he(llo|y)", replacement: "greetings , hey")
@post = creator_with_tags.create
expect(@post.topic.tags.map(&:name)).to match_array(tag_names + ['greetings', 'hey'])
end
end
end
end end
end end
end end

View File

@ -89,49 +89,6 @@ describe Jobs::ProcessPost do
Jobs::ProcessPost.new.execute(post_id: post2.id) Jobs::ProcessPost.new.execute(post_id: post2.id)
expect(post.topic.reload.excerpt).to eq("Some OP content") expect(post.topic.reload.excerpt).to eq("Some OP content")
end end
it "automatically tags first posts" do
SiteSetting.tagging_enabled = true
Fabricate(:watched_word, action: WatchedWord.actions[:tag], word: "Greetings?", replacement: "hello , world")
post = Fabricate(:post, raw: "Greeting", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly()
post = Fabricate(:post, raw: "Greetings", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly()
post = Fabricate(:post, raw: "Greetings?", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly("hello", "world")
topic = Fabricate(:topic, title: "Greetings? People")
post = Fabricate(:post, topic: topic, raw: "nothing yet", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly("hello", "world")
end
it "automatically tags first posts (regex)" do
SiteSetting.tagging_enabled = true
SiteSetting.watched_words_regular_expressions = true
Fabricate(:watched_word, action: WatchedWord.actions[:tag], word: "Greetings?", replacement: "hello , world")
post = Fabricate(:post, raw: "Greeting", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly("hello", "world")
post = Fabricate(:post, raw: "Greetings", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly("hello", "world")
post = Fabricate(:post, raw: "Greetings?", cooked: "")
Jobs::ProcessPost.new.execute(post_id: post.id)
expect(post.topic.reload.tags.pluck(:name)).to contain_exactly("hello", "world")
end
end end
end end