mastodon/spec/policies/account_moderation_note_policy_spec.rb

53 lines
1.3 KiB
Ruby
Raw Permalink Normal View History

# frozen_string_literal: true
require 'rails_helper'
RSpec.describe AccountModerationNotePolicy do
subject { described_class }
let(:admin) { Fabricate(:user, role: UserRole.find_by(name: 'Admin')).account }
let(:john) { Fabricate(:account) }
permissions :create? do
2023-05-04 03:49:08 +00:00
context 'when staff' do
it 'grants to create' do
expect(subject).to permit(admin, AccountModerationNote)
end
end
2023-05-04 03:49:08 +00:00
context 'when not staff' do
it 'denies to create' do
expect(subject).to_not permit(john, AccountModerationNote)
end
end
end
permissions :destroy? do
let(:account_moderation_note) do
Fabricate(:account_moderation_note,
account: john,
target_account: Fabricate(:account))
end
2023-05-04 03:49:08 +00:00
context 'when admin' do
it 'grants to destroy' do
expect(subject).to permit(admin, account_moderation_note)
end
end
2023-05-04 03:49:08 +00:00
context 'when owner' do
it 'grants to destroy' do
expect(subject).to permit(john, account_moderation_note)
end
end
2023-05-04 03:49:08 +00:00
context 'when neither admin nor owner' do
let(:kevin) { Fabricate(:account) }
it 'denies to destroy' do
expect(subject).to_not permit(kevin, account_moderation_note)
end
end
end
end