Restructure omni services and add Chatwoot research snapshot
This commit is contained in:
35
research/chatwoot/spec/policies/user_policy_spec.rb
Normal file
35
research/chatwoot/spec/policies/user_policy_spec.rb
Normal file
@@ -0,0 +1,35 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe UserPolicy, type: :policy do
|
||||
subject(:user_policy) { described_class }
|
||||
|
||||
let(:account) { create(:account) }
|
||||
|
||||
let(:administrator) { create(:user, :administrator, account: account) }
|
||||
let(:agent) { create(:user, account: account) }
|
||||
let(:user) { create(:user, account: account) }
|
||||
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 } }
|
||||
|
||||
permissions :create?, :update?, :destroy? do
|
||||
context 'when administrator' do
|
||||
it { expect(user_policy).to permit(administrator_context, user) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(user_policy).not_to permit(agent_context, user) }
|
||||
end
|
||||
end
|
||||
|
||||
permissions :index? do
|
||||
context 'when administrator' do
|
||||
it { expect(user_policy).to permit(administrator_context, user) }
|
||||
end
|
||||
|
||||
context 'when agent' do
|
||||
it { expect(user_policy).to permit(agent_context, user) }
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user