minor optimizations for post rejected logs

This commit is contained in:
Arpit Jalan 2018-06-02 09:25:41 +05:30
parent 597ffd7e3f
commit 36f9af4fa4
4 changed files with 17 additions and 8 deletions

View File

@ -46,9 +46,9 @@ class StaffActionLogger
topic = deleted_post.topic || Topic.with_deleted.find_by(id: deleted_post.topic_id) topic = deleted_post.topic || Topic.with_deleted.find_by(id: deleted_post.topic_id)
username = deleted_post.user.try(:username) || "unknown" username = deleted_post.user.try(:username) || I18n.t('staff_action_logs.unknown')
name = deleted_post.user.try(:name) || "unknown" name = deleted_post.user.try(:name) || I18n.t('staff_action_logs.unknown')
topic_title = topic.try(:title) || "not found" topic_title = topic.try(:title) || I18n.t('staff_action_logs.not_found')
details = [ details = [
"id: #{deleted_post.id}", "id: #{deleted_post.id}",
@ -530,9 +530,9 @@ class StaffActionLogger
raise Discourse::InvalidParameters.new(:rejected_post) unless rejected_post && rejected_post.is_a?(QueuedPost) raise Discourse::InvalidParameters.new(:rejected_post) unless rejected_post && rejected_post.is_a?(QueuedPost)
topic = rejected_post.topic || Topic.with_deleted.find_by(id: rejected_post.topic_id) topic = rejected_post.topic || Topic.with_deleted.find_by(id: rejected_post.topic_id)
topic_title = topic&.title || "not found" topic_title = topic&.title || I18n.t('staff_action_logs.not_found')
username = rejected_post.user&.username || "unknown" username = rejected_post.user&.username || I18n.t('staff_action_logs.unknown')
name = rejected_post.user&.name || "unknown" name = rejected_post.user&.name || I18n.t('staff_action_logs.unknown')
details = [ details = [
"created_at: #{rejected_post.created_at}", "created_at: #{rejected_post.created_at}",

View File

@ -3881,3 +3881,7 @@ en:
linked: '%{username} linked to your post from "%{topic}" - %{site_title}' linked: '%{username} linked to your post from "%{topic}" - %{site_title}'
confirm_title: 'Notifications enabled - %{site_title}' confirm_title: 'Notifications enabled - %{site_title}'
confirm_body: 'Success! Notifications have been enabled.' confirm_body: 'Success! Notifications have been enabled.'
staff_action_logs:
not_found: "not found"
unknown: "unknown"

View File

@ -86,8 +86,10 @@ describe QueuedPost do
# It removes the pending action # It removes the pending action
expect(UserAction.where(queued_post_id: qp.id).count).to eq(0) expect(UserAction.where(queued_post_id: qp.id).count).to eq(0)
# Logs staff action log for rejected post # Logs staff action for rejected post
expect(UserHistory.where(action: UserHistory.actions[:post_rejected]).count).to eq(1) post_rejected_logs = UserHistory.where(action: UserHistory.actions[:post_rejected])
expect(post_rejected_logs.count).to eq(1)
expect(post_rejected_logs.first.details).to include(qp.raw)
# We can't reject twice # We can't reject twice
expect(-> { qp.reject!(admin) }).to raise_error(QueuedPost::InvalidStateTransition) expect(-> { qp.reject!(admin) }).to raise_error(QueuedPost::InvalidStateTransition)

View File

@ -504,6 +504,9 @@ describe StaffActionLogger do
it 'creates a new UserHistory record' do it 'creates a new UserHistory record' do
expect { log_post_rejected }.to change { UserHistory.count }.by(1) expect { log_post_rejected }.to change { UserHistory.count }.by(1)
user_history = UserHistory.last
expect(user_history.action).to eq(UserHistory.actions[:post_rejected])
expect(user_history.details).to include(rejected_post.raw)
end end
end end
end end