FEATURE: adds revision_count to moderators_activity (#6218)

Co-Authored-By: Simon Cossar <scossar@users.noreply.github.com>
This commit is contained in:
Joffrey JAFFEUX 2018-07-31 23:40:45 -04:00 committed by GitHub
parent b6939093eb
commit 849f0d00f6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 154 additions and 67 deletions

View File

@ -721,6 +721,10 @@ class Report
{ {
property: :post_count, property: :post_count,
title: I18n.t("reports.moderators_activity.labels.post_count") title: I18n.t("reports.moderators_activity.labels.post_count")
},
{
property: :revision_count,
title: I18n.t("reports.moderators_activity.labels.revision_count")
} }
] ]
@ -787,6 +791,19 @@ class Report
ON df.user_id = af.user_id ON df.user_id = af.user_id
SQL SQL
revision_count_query = <<~SQL
SELECT pr.user_id,
COUNT(*) AS revision_count
FROM post_revisions pr
JOIN users u
ON u.id = pr.user_id
WHERE u.moderator = 'true'
AND u.id > 0
AND pr.created_at >= '#{report.start_date}'
AND pr.created_at <= '#{report.end_date}'
GROUP BY pr.user_id
SQL
topic_count_query = <<~SQL topic_count_query = <<~SQL
SELECT t.user_id, SELECT t.user_id,
COUNT(*) AS topic_count COUNT(*) AS topic_count
@ -841,6 +858,10 @@ class Report
mod_data[row.user_id][:flag_count] = row.flag_count mod_data[row.user_id][:flag_count] = row.flag_count
end end
DB.query(revision_count_query).each do |row|
mod_data[row.user_id][:revision_count] = row.revision_count
end
DB.query(topic_count_query).each do |row| DB.query(topic_count_query).each do |row|
mod_data[row.user_id][:topic_count] = row.topic_count mod_data[row.user_id][:topic_count] = row.topic_count
end end

View File

@ -864,6 +864,7 @@ en:
topic_count: Topics created topic_count: Topics created
post_count: Posts created post_count: Posts created
pm_count: PMs created pm_count: PMs created
revision_count: Revisions
flags_status: flags_status:
title: "Flags status" title: "Flags status"
values: values:

View File

@ -534,94 +534,159 @@ describe Report do
end end
describe 'moderator activity' do describe 'moderator activity' do
let(:report) { Report.find('moderators_activity', start_date: 1.months.ago.beginning_of_day, end_date: Date.today) } let(:report) {
let(:previous_report) { Report.find('moderators_activity', start_date: 2.months.ago.beginning_of_day, end_date: 1.month.ago.end_of_day) } Report.find('moderators_activity')
}
let(:sam) { Fabricate(:user, moderator: true, username: 'sam') }
let(:jeff) { Fabricate(:user, moderator: true, username: 'jeff') }
include_examples 'no data' include_examples 'no data'
context "with moderators" do context "with moderators" do
before do before do
freeze_time(Date.today) freeze_time(Date.today)
bob = Fabricate(:user, moderator: true, username: 'bob')
bob.user_visits.create(visited_at: 2.days.ago, time_read: 200)
bob.user_visits.create(visited_at: 1.day.ago, time_read: 100)
Fabricate(:topic, user: bob, created_at: 1.day.ago)
sally = Fabricate(:user, moderator: true, username: 'sally')
sally.user_visits.create(visited_at: 2.days.ago, time_read: 1000)
sally.user_visits.create(visited_at: 1.day.ago, time_read: 2000)
topic = Fabricate(:topic)
2.times {
Fabricate(:post, user: sally, topic: topic, created_at: 1.day.ago)
}
flag_user = Fabricate(:user)
flag_post = Fabricate(:post, user: flag_user)
action = PostAction.new(user_id: flag_user.id,
post_action_type_id: PostActionType.types[:off_topic],
post_id: flag_post.id,
agreed_by_id: sally.id,
created_at: 1.day.ago,
agreed_at: Time.now)
action.save
bob.user_visits.create(visited_at: 45.days.ago, time_read: 200)
old_topic = Fabricate(:topic, user: bob, created_at: 45.days.ago)
3.times {
Fabricate(:post, user: bob, topic: old_topic, created_at: 45.days.ago)
}
old_flag_user = Fabricate(:user)
old_flag_post = Fabricate(:post, user: old_flag_user, created_at: 45.days.ago)
old_action = PostAction.new(user_id: old_flag_user.id,
post_action_type_id: PostActionType.types[:spam],
post_id: old_flag_post.id,
agreed_by_id: bob.id,
created_at: 44.days.ago,
agreed_at: 44.days.ago)
old_action.save
end end
it "returns a report with data" do context "time read" do
expect(report.data).to be_present before do
sam.user_visits.create(visited_at: 2.days.ago, time_read: 200)
sam.user_visits.create(visited_at: 1.day.ago, time_read: 100)
jeff.user_visits.create(visited_at: 2.days.ago, time_read: 1000)
jeff.user_visits.create(visited_at: 1.day.ago, time_read: 2000)
Fabricate(:topic, created_at: 1.day.ago)
end
it "returns the correct read times" do
expect(report.data[0][:username]).to eq('sam')
expect(report.data[0][:time_read]).to eq(300)
expect(report.data[1][:username]).to eq('jeff')
expect(report.data[1][:time_read]).to eq(3000)
end
end end
it "returns data for two moderators" do context "flags" do
expect(report.data.count).to eq(2) before do
flagged_post = Fabricate(:post)
PostAction.act(jeff, flagged_post, PostActionType.types[:off_topic])
PostAction.agree_flags!(flagged_post, jeff)
end
it "returns the correct read times" do
expect(report.data.count).to eq(1)
expect(report.data[0][:flag_count]).to eq(1)
expect(report.data[0][:username]).to eq("jeff")
end
end end
it "returns the correct usernames" do context "topics" do
expect(report.data[0][:username]).to eq('bob') before do
expect(report.data[1][:username]).to eq('sally') Fabricate(:topic, user: sam)
Fabricate(:topic, user: sam)
Fabricate(:topic, user: jeff)
end
it "returns the correct topic count" do
expect(report.data[0][:topic_count]).to eq(2)
expect(report.data[0][:username]).to eq('sam')
expect(report.data[1][:topic_count]).to eq(1)
expect(report.data[1][:username]).to eq('jeff')
end
context "private messages" do
before do
Fabricate(:private_message_topic, user: jeff)
end
it "doesnt count private topic" do
expect(report.data[0][:topic_count]).to eq(2)
expect(report.data[1][:topic_count]).to eq(1)
end
end
end end
it "returns the correct read times" do context "posts" do
expect(report.data[0][:time_read]).to eq(300) before do
expect(report.data[1][:time_read]).to eq(3000) Fabricate(:post, user: sam)
Fabricate(:post, user: sam)
Fabricate(:post, user: jeff)
end
it "returns the correct topic count" do
expect(report.data[0][:topic_count]).to eq(2)
expect(report.data[0][:username]).to eq('sam')
expect(report.data[1][:topic_count]).to eq(1)
expect(report.data[1][:username]).to eq('jeff')
end
context "private messages" do
before do
Fabricate(:private_message_post, user: jeff)
end
it "doesnt count private post" do
expect(report.data[0][:post_count]).to eq(2)
expect(report.data[1][:post_count]).to eq(1)
end
end
end end
it "returns the correct agreed flag count" do context "private messages" do
expect(report.data[0][:flag_count]).to be_blank before do
expect(report.data[1][:flag_count]).to eq(1) Fabricate(:post, user: sam)
Fabricate(:topic, user: sam)
Fabricate(:post, user: jeff)
Fabricate(:private_message_post, user: jeff)
end
it "returns the correct topic count" do
expect(report.data[0][:pm_count]).to be_blank
expect(report.data[0][:username]).to eq('sam')
expect(report.data[1][:pm_count]).to eq(1)
expect(report.data[1][:username]).to eq('jeff')
end
end end
it "returns the correct topic count" do context "revisions" do
expect(report.data[0][:topic_count]).to eq(1) before do
expect(report.data[1][:topic_count]).to be_blank post = Fabricate(:post)
post.revise(sam, raw: 'updated body', edit_reason: 'not cool')
end
it "returns the correct revisions count" do
expect(report.data[0][:revision_count]).to eq(1)
expect(report.data[0][:username]).to eq('sam')
end
context "revise own post" do
before do
post = Fabricate(:post, user: sam)
Fabricate(:post, user: sam)
.revise(sam, raw: 'updated body', edit_reason: 'not cool')
Fabricate(:post)
.revise(sam, raw: 'updated body', edit_reason: 'not cool')
end
it "doesnt count a revison on your own post" do
expect(report.data[0][:revision_count]).to eq(2)
expect(report.data[0][:username]).to eq('sam')
end
end
end end
it "returns the correct post count" do context "previous data" do
expect(report.data[0][:post_count]).to be_blank before do
expect(report.data[1][:post_count]).to eq(2) Fabricate(:topic, user: sam, created_at: 1.year.ago)
end end
it "returns the correct data for the time period" do it "doesnt count old data" do
expect(previous_report.data[0][:flag_count]).to eq(1) expect(report.data[0][:topic_count]).to be_blank
expect(previous_report.data[0][:topic_count]).to eq(1) expect(report.data[0][:username]).to eq('sam')
expect(previous_report.data[0][:post_count]).to eq(3) end
expect(previous_report.data[0][:time_read]).to eq(200)
expect(previous_report.data[1][:flag_count]).to be_blank
expect(previous_report.data[1][:topic_count]).to be_blank
expect(previous_report.data[1][:post_count]).to be_blank
expect(previous_report.data[1][:time_read]).to be_blank
end end
end end
end end