require 'rails_helper' RSpec.describe ReviewableHistory, type: :model do let(:user) { Fabricate(:user) } let(:admin) { Fabricate(:admin) } let(:moderator) { Fabricate(:moderator) } it "adds a `created` history event when a reviewable is created" do reviewable = ReviewableUser.needs_review!(target: user, created_by: admin) reviewable.perform(moderator, :approve_user) reviewable = ReviewableUser.needs_review!(target: user, created_by: admin) history = reviewable.history expect(history.size).to eq(3) expect(history[0].reviewable_history_type).to eq(ReviewableHistory.types[:created]) expect(history[0].status).to eq(Reviewable.statuses[:pending]) expect(history[0].created_by).to eq(admin) end it "adds a `transitioned` event when transitioning" do reviewable = ReviewableUser.needs_review!(target: user, created_by: admin) reviewable.perform(moderator, :approve_user) reviewable = ReviewableUser.needs_review!(target: user, created_by: admin) history = reviewable.history expect(history.size).to eq(3) expect(history[1].reviewable_history_type).to eq(ReviewableHistory.types[:transitioned]) expect(history[1].status).to eq(Reviewable.statuses[:approved]) expect(history[1].created_by).to eq(moderator) expect(history[2].reviewable_history_type).to eq(ReviewableHistory.types[:transitioned]) expect(history[2].status).to eq(Reviewable.statuses[:pending]) expect(history[2].created_by).to eq(admin) end it "won't log a transition to the same state" do p0 = Fabricate(:post) reviewable = PostActionCreator.spam(Fabricate(:user), p0).reviewable expect(reviewable.reviewable_histories.size).to eq(1) PostActionCreator.inappropriate(Fabricate(:user), p0) expect(reviewable.reload.reviewable_histories.size).to eq(1) end it "adds an `edited` event when edited" do reviewable = Fabricate(:reviewable) old_category = reviewable.category reviewable.update_fields({ category_id: nil }, moderator) history = reviewable.history expect(history.size).to eq(2) expect(history[1].reviewable_history_type).to eq(ReviewableHistory.types[:edited]) expect(history[1].created_by).to eq(moderator) expect(history[1].edited).to eq("category_id" => [old_category.id, nil]) end end