Add specs for Policies (#392)

* Add specs for Policies

* Fix CI issues
This commit is contained in:
Mukesh Chaudhary
2019-12-28 01:27:59 +05:30
committed by Sojan Jose
parent 19b4311e8b
commit 96f8070e79
5 changed files with 98 additions and 0 deletions

View File

@@ -0,0 +1,31 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe ContactPolicy, type: :policy do
subject(:contact_policy) { described_class }
let(:administrator) { create(:user, :administrator) }
let(:agent) { create(:user) }
let(:contact) { create(:contact) }
permissions :index?, :show?, :update? do
context 'when administrator' do
it { expect(contact_policy).to permit(administrator, contact) }
end
context 'when agent' do
it { expect(contact_policy).not_to permit(agent, contact) }
end
end
permissions :create? do
context 'when administrator' do
it { expect(contact_policy).to permit(administrator, contact) }
end
context 'when agent' do
it { expect(contact_policy).to permit(agent, contact) }
end
end
end

View File

@@ -0,0 +1,31 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe InboxPolicy, type: :policy do
subject(:inbox_policy) { described_class }
let(:administrator) { create(:user, :administrator) }
let(:agent) { create(:user) }
let(:inbox) { create(:inbox) }
permissions :create?, :destroy? do
context 'when administrator' do
it { expect(inbox_policy).to permit(administrator, inbox) }
end
context 'when agent' do
it { expect(inbox_policy).not_to permit(agent, inbox) }
end
end
permissions :index? do
context 'when administrator' do
it { expect(inbox_policy).to permit(administrator, inbox) }
end
context 'when agent' do
it { expect(inbox_policy).to permit(agent, inbox) }
end
end
end

View File

@@ -0,0 +1,31 @@
# frozen_string_literal: true
require 'rails_helper'
RSpec.describe UserPolicy, type: :policy do
subject(:user_policy) { described_class }
let(:administrator) { create(:user, :administrator) }
let(:agent) { create(:user) }
let(:user) { create(:user) }
permissions :create?, :update?, :destroy? do
context 'when administrator' do
it { expect(user_policy).to permit(administrator, user) }
end
context 'when agent' do
it { expect(user_policy).not_to permit(agent, user) }
end
end
permissions :index? do
context 'when administrator' do
it { expect(user_policy).to permit(administrator, user) }
end
context 'when agent' do
it { expect(user_policy).to permit(agent, user) }
end
end
end