mirror of
https://github.com/discourse/discourse.git
synced 2025-01-12 23:14:01 +08:00
4b1e017722
The mistake was made when flags were moved to the database. The `notify_moderators` (something else) flag should be the last position on the list. This commit contains 3 changes: - update fixtures order; - remove position and enable from fixtures (they can be overridden by admin and we don't want seed to restore them); - migration to fix data if the order was not changed by admin.
61 lines
1.7 KiB
Ruby
61 lines
1.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe(ReorderFlag) do
|
|
subject(:result) do
|
|
described_class.call(flag_id: flag.id, guardian: current_user.guardian, direction: direction)
|
|
end
|
|
|
|
let(:flag) { Flag.order(:position).last }
|
|
let(:direction) { "up" }
|
|
|
|
context "when user is not allowed to perform the action" do
|
|
fab!(:current_user) { Fabricate(:user) }
|
|
|
|
it { is_expected.to fail_a_policy(:invalid_access) }
|
|
end
|
|
|
|
context "when direction is invalid" do
|
|
fab!(:current_user) { Fabricate(:admin) }
|
|
let(:direction) { "side" }
|
|
|
|
it { is_expected.to fail_a_contract }
|
|
end
|
|
|
|
context "when move is invalid" do
|
|
fab!(:current_user) { Fabricate(:admin) }
|
|
let(:direction) { "down" }
|
|
|
|
it { is_expected.to fail_a_policy(:invalid_move) }
|
|
end
|
|
|
|
context "when user is allowed to perform the action" do
|
|
fab!(:current_user) { Fabricate(:admin) }
|
|
|
|
after do
|
|
described_class.call(flag_id: flag.id, guardian: current_user.guardian, direction: "down")
|
|
end
|
|
|
|
it "sets the service result as successful" do
|
|
expect(result).to be_a_success
|
|
end
|
|
|
|
it "moves the flag" do
|
|
expect(Flag.order(:position).map(&:name)).to eq(
|
|
%w[notify_user off_topic inappropriate spam illegal notify_moderators],
|
|
)
|
|
result
|
|
expect(Flag.order(:position).map(&:name)).to eq(
|
|
%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
|
|
end
|
|
end
|