2024-06-04 23:27:06 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2024-07-02 18:45:37 -04:00
|
|
|
RSpec.describe(Flags::ReorderFlag) do
|
2024-10-17 11:15:35 -04:00
|
|
|
describe described_class::Contract, type: :model do
|
|
|
|
it { is_expected.to validate_presence_of(:flag_id) }
|
|
|
|
it { is_expected.to validate_inclusion_of(:direction).in_array(%w[up down]) }
|
2024-06-04 23:27:06 -04:00
|
|
|
end
|
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
describe ".call" do
|
|
|
|
subject(:result) { described_class.call(**params, **dependencies) }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
fab!(:current_user) { Fabricate(:admin) }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
let(:params) { { flag_id: flag_id, direction: } }
|
|
|
|
let(:dependencies) { { guardian: current_user.guardian } }
|
|
|
|
let(:flag_id) { flag.id }
|
|
|
|
let(:flag) { Flag.order(:position).last }
|
|
|
|
let(:direction) { "up" }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
context "when contract is invalid" do
|
|
|
|
let(:direction) { "left" }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
it { is_expected.to fail_a_contract }
|
|
|
|
end
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
context "when model is not found" do
|
|
|
|
let(:flag_id) { 0 }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
it { is_expected.to fail_to_find_a_model(:flag) }
|
|
|
|
end
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
context "when user is not allowed to perform the action" do
|
|
|
|
fab!(:current_user) { Fabricate(:user) }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
it { is_expected.to fail_a_policy(:invalid_access) }
|
2024-06-05 19:40:14 -04:00
|
|
|
end
|
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
context "when move is invalid" do
|
|
|
|
let(:direction) { "down" }
|
2024-06-04 23:27:06 -04:00
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
it { is_expected.to fail_a_policy(:invalid_move) }
|
2024-06-04 23:27:06 -04:00
|
|
|
end
|
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
context "when everything's ok" do
|
2024-10-21 22:18:57 -04:00
|
|
|
after do
|
|
|
|
described_class.call(flag_id: flag.id, guardian: current_user.guardian, direction: "down")
|
|
|
|
end
|
|
|
|
|
2024-10-17 11:15:35 -04:00
|
|
|
it { is_expected.to run_successfully }
|
|
|
|
|
|
|
|
it "moves the flag" do
|
|
|
|
expect { result }.to change { Flag.order(:position).map(&:name) }.from(
|
|
|
|
%w[notify_user off_topic inappropriate spam illegal notify_moderators],
|
|
|
|
).to(%w[notify_user off_topic inappropriate spam notify_moderators illegal])
|
|
|
|
end
|
|
|
|
|
|
|
|
it "logs the action" do
|
|
|
|
expect { result }.to change { UserHistory.count }.by(1)
|
|
|
|
expect(UserHistory.last).to have_attributes(
|
|
|
|
custom_type: "move_flag",
|
|
|
|
details: "flag: #{result[:flag].name}\ndirection: up",
|
|
|
|
)
|
|
|
|
end
|
2024-06-04 23:27:06 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|