2019-04-30 08:27:42 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-10-11 17:41:23 +08:00
|
|
|
require 'rails_helper'
|
2013-07-24 05:58:26 +08:00
|
|
|
|
2013-09-11 09:21:16 +08:00
|
|
|
describe UserHistory do
|
2014-03-01 05:30:45 +08:00
|
|
|
|
2016-01-08 18:53:52 +08:00
|
|
|
describe '#actions' do
|
|
|
|
context "verify enum sequence" do
|
|
|
|
before do
|
|
|
|
@actions = UserHistory.actions
|
|
|
|
end
|
|
|
|
|
|
|
|
it "'delete_user' should be at 1st position" do
|
|
|
|
expect(@actions[:delete_user]).to eq(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "'change_site_text' should be at 29th position" do
|
|
|
|
expect(@actions[:change_site_text]).to eq(29)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2014-03-01 05:30:45 +08:00
|
|
|
describe '#staff_action_records' do
|
|
|
|
context "with some records" do
|
2019-04-10 20:53:17 +08:00
|
|
|
let(:admin) { Fabricate(:admin) }
|
|
|
|
let(:custom_type) { 'confirmed_ham' }
|
|
|
|
|
2014-03-01 05:30:45 +08:00
|
|
|
before do
|
2017-07-28 09:20:09 +08:00
|
|
|
@change_site_setting = UserHistory.create!(action: UserHistory.actions[:change_site_setting], subject: "title", previous_value: "Old", new_value: "New")
|
|
|
|
@change_trust_level = UserHistory.create!(action: UserHistory.actions[:change_trust_level], target_user_id: Fabricate(:user).id, details: "stuff happened")
|
2019-04-10 20:53:17 +08:00
|
|
|
@custom_history = StaffActionLogger.new(admin).log_custom('confirmed_ham', admin_only: true)
|
2014-03-01 05:30:45 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it "returns all records for admins" do
|
2019-04-10 20:53:17 +08:00
|
|
|
records = described_class.staff_action_records(admin).to_a
|
|
|
|
expect(records.size).to eq(3)
|
2014-03-01 05:30:45 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't return records to moderators that only admins should see" do
|
|
|
|
records = described_class.staff_action_records(Fabricate(:moderator)).to_a
|
2019-04-10 20:53:17 +08:00
|
|
|
expect(records).not_to include([@change_site_setting])
|
2014-03-01 05:30:45 +08:00
|
|
|
end
|
2019-03-28 04:29:15 +08:00
|
|
|
|
|
|
|
it 'filters by action' do
|
2019-04-10 20:53:17 +08:00
|
|
|
records = described_class.staff_action_records(admin, action_id: @change_site_setting.action_before_type_cast).to_a
|
2019-03-28 04:29:15 +08:00
|
|
|
expect(records.size).to eq(1)
|
|
|
|
expect(records.first).to eq(@change_site_setting)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'filters by action_name' do
|
2019-04-10 20:53:17 +08:00
|
|
|
records = described_class.staff_action_records(admin, action_name: "change_site_setting").to_a
|
2019-03-28 04:29:15 +08:00
|
|
|
expect(records.size).to eq(1)
|
|
|
|
expect(records.first).to eq(@change_site_setting)
|
|
|
|
end
|
2019-04-10 20:53:17 +08:00
|
|
|
|
|
|
|
it 'Uses action_name as custom_type when searching for custom_staff logs' do
|
|
|
|
records = described_class.staff_action_records(
|
|
|
|
admin, action_name: custom_type, action_id: described_class.actions[:custom_staff]
|
|
|
|
).to_a
|
|
|
|
|
|
|
|
expect(records.size).to eq(1)
|
|
|
|
expect(records.first).to eq(@custom_history)
|
|
|
|
end
|
2014-03-01 05:30:45 +08:00
|
|
|
end
|
|
|
|
end
|
2013-07-24 05:58:26 +08:00
|
|
|
end
|