2019-12-27 19:57:59 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
RSpec.describe UserPolicy, type: :policy do
|
|
|
|
subject(:user_policy) { described_class }
|
|
|
|
|
2020-03-07 06:48:16 +00:00
|
|
|
let(:account) { create(:account) }
|
|
|
|
|
|
|
|
let(:administrator) { create(:user, :administrator, account: account) }
|
|
|
|
let(:agent) { create(:user, account: account) }
|
|
|
|
let(:user) { create(:user, account: account) }
|
2020-05-26 17:08:48 +00:00
|
|
|
let(:administrator_context) { { user: administrator, account: account, account_user: account.account_users.first } }
|
|
|
|
let(:agent_context) { { user: agent, account: account, account_user: account.account_users.first } }
|
2019-12-27 19:57:59 +00:00
|
|
|
|
|
|
|
permissions :create?, :update?, :destroy? do
|
|
|
|
context 'when administrator' do
|
2020-05-26 17:08:48 +00:00
|
|
|
it { expect(user_policy).to permit(administrator_context, user) }
|
2019-12-27 19:57:59 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when agent' do
|
2020-05-26 17:08:48 +00:00
|
|
|
it { expect(user_policy).not_to permit(agent_context, user) }
|
2019-12-27 19:57:59 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
permissions :index? do
|
|
|
|
context 'when administrator' do
|
2020-05-26 17:08:48 +00:00
|
|
|
it { expect(user_policy).to permit(administrator_context, user) }
|
2019-12-27 19:57:59 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when agent' do
|
2020-05-26 17:08:48 +00:00
|
|
|
it { expect(user_policy).to permit(agent_context, user) }
|
2019-12-27 19:57:59 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|