2023-02-23 13:50:10 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2023-11-08 08:50:37 -05:00
|
|
|
require_relative "../../../support/sentiment_inference_stubs"
|
2023-02-23 13:50:10 -05:00
|
|
|
|
2023-11-08 08:50:37 -05:00
|
|
|
RSpec.describe DiscourseAi::Sentiment::EntryPoint do
|
2023-12-13 22:07:28 -05:00
|
|
|
fab!(:user) { Fabricate(:user, refresh_auto_groups: true) }
|
2023-02-23 13:50:10 -05:00
|
|
|
|
|
|
|
describe "registering event callbacks" do
|
|
|
|
context "when creating a post" do
|
|
|
|
let(:creator) do
|
|
|
|
PostCreator.new(
|
|
|
|
user,
|
|
|
|
raw: "this is the new content for my topic",
|
|
|
|
title: "this is my new topic title",
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "queues a job on create if sentiment analysis is enabled" do
|
|
|
|
SiteSetting.ai_sentiment_enabled = true
|
|
|
|
|
|
|
|
expect { creator.create }.to change(Jobs::PostSentimentAnalysis.jobs, :size).by(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does nothing if sentiment analysis is disabled" do
|
|
|
|
SiteSetting.ai_sentiment_enabled = false
|
|
|
|
|
|
|
|
expect { creator.create }.not_to change(Jobs::PostSentimentAnalysis.jobs, :size)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when editing a post" do
|
|
|
|
fab!(:post) { Fabricate(:post, user: user) }
|
|
|
|
let(:revisor) { PostRevisor.new(post) }
|
|
|
|
|
|
|
|
it "queues a job on update if sentiment analysis is enabled" do
|
|
|
|
SiteSetting.ai_sentiment_enabled = true
|
|
|
|
|
|
|
|
expect { revisor.revise!(user, raw: "This is my new test") }.to change(
|
|
|
|
Jobs::PostSentimentAnalysis.jobs,
|
|
|
|
:size,
|
|
|
|
).by(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does nothing if sentiment analysis is disabled" do
|
|
|
|
SiteSetting.ai_sentiment_enabled = false
|
|
|
|
|
|
|
|
expect { revisor.revise!(user, raw: "This is my new test") }.not_to change(
|
|
|
|
Jobs::PostSentimentAnalysis.jobs,
|
|
|
|
:size,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2023-11-08 08:50:37 -05:00
|
|
|
|
|
|
|
describe "custom reports" do
|
|
|
|
before { SiteSetting.ai_sentiment_inference_service_api_endpoint = "http://test.com" }
|
|
|
|
|
|
|
|
fab!(:pm) { Fabricate(:private_message_post) }
|
|
|
|
|
|
|
|
fab!(:post_1) { Fabricate(:post) }
|
|
|
|
fab!(:post_2) { Fabricate(:post) }
|
|
|
|
|
|
|
|
describe "overall_sentiment report" do
|
|
|
|
let(:positive_classification) { { negative: 2, neutral: 30, positive: 70 } }
|
2023-11-09 15:23:25 -05:00
|
|
|
let(:negative_classification) { { negative: 65, neutral: 2, positive: 10 } }
|
2023-11-08 08:50:37 -05:00
|
|
|
|
|
|
|
def sentiment_classification(post, classification)
|
|
|
|
Fabricate(:sentiment_classification, target: post, classification: classification)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "calculate averages using only public posts" do
|
|
|
|
sentiment_classification(post_1, positive_classification)
|
|
|
|
sentiment_classification(post_2, negative_classification)
|
|
|
|
sentiment_classification(pm, positive_classification)
|
|
|
|
|
|
|
|
report = Report.find("overall_sentiment")
|
|
|
|
positive_data_point = report.data[0][:data].first[:y].to_i
|
|
|
|
negative_data_point = report.data[1][:data].first[:y].to_i
|
|
|
|
|
2023-11-09 15:23:25 -05:00
|
|
|
expect(positive_data_point).to eq(1)
|
|
|
|
expect(negative_data_point).to eq(-1)
|
2023-11-08 08:50:37 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "post_emotion report" do
|
|
|
|
let(:emotion_1) do
|
|
|
|
{ sadness: 49, surprise: 23, neutral: 6, fear: 34, anger: 87, joy: 22, disgust: 70 }
|
|
|
|
end
|
|
|
|
let(:emotion_2) do
|
|
|
|
{ sadness: 19, surprise: 63, neutral: 45, fear: 44, anger: 27, joy: 62, disgust: 30 }
|
|
|
|
end
|
2023-11-08 12:58:35 -05:00
|
|
|
let(:model_used) { "emotion" }
|
2023-11-08 08:50:37 -05:00
|
|
|
|
|
|
|
def emotion_classification(post, classification)
|
|
|
|
Fabricate(
|
|
|
|
:sentiment_classification,
|
|
|
|
target: post,
|
2023-11-08 12:58:35 -05:00
|
|
|
model_used: model_used,
|
2023-11-08 08:50:37 -05:00
|
|
|
classification: classification,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "calculate averages using only public posts" do
|
|
|
|
post_1.user.update!(trust_level: TrustLevel[0])
|
|
|
|
post_2.user.update!(trust_level: TrustLevel[3])
|
|
|
|
pm.user.update!(trust_level: TrustLevel[0])
|
2023-11-09 15:23:25 -05:00
|
|
|
threshold = 30
|
2023-11-08 08:50:37 -05:00
|
|
|
|
|
|
|
emotion_classification(post_1, emotion_1)
|
|
|
|
emotion_classification(post_2, emotion_2)
|
|
|
|
emotion_classification(pm, emotion_2)
|
|
|
|
|
|
|
|
report = Report.find("post_emotion")
|
2023-11-09 15:23:25 -05:00
|
|
|
tl_01_point = report.data[0][:data]
|
|
|
|
tl_234_point = report.data[1][:data]
|
|
|
|
|
|
|
|
tl_01_point.each do |point|
|
|
|
|
expected = emotion_1[point[:x].downcase.to_sym] > threshold ? 1 : 0
|
|
|
|
expect(point[:y]).to eq(expected)
|
|
|
|
end
|
|
|
|
|
|
|
|
tl_234_point.each do |point|
|
|
|
|
expected = emotion_2[point[:x].downcase.to_sym] > threshold ? 1 : 0
|
|
|
|
expect(point[:y]).to eq(expected)
|
|
|
|
end
|
2023-11-08 08:50:37 -05:00
|
|
|
end
|
2023-11-08 11:05:36 -05:00
|
|
|
|
|
|
|
it "doesn't try to divide by zero if there are no data in a TL group" do
|
|
|
|
post_1.user.update!(trust_level: TrustLevel[3])
|
|
|
|
post_2.user.update!(trust_level: TrustLevel[3])
|
|
|
|
|
|
|
|
emotion_classification(post_1, emotion_1)
|
|
|
|
emotion_classification(post_2, emotion_2)
|
|
|
|
|
|
|
|
report = Report.find("post_emotion")
|
|
|
|
tl_01_point = report.data[0][:data].first
|
|
|
|
|
|
|
|
expect(tl_01_point[:y]).to be_zero
|
|
|
|
end
|
2023-11-08 08:50:37 -05:00
|
|
|
end
|
|
|
|
end
|
2023-02-23 13:50:10 -05:00
|
|
|
end
|