Restructure omni services and add Chatwoot research snapshot
This commit is contained in:
66
research/chatwoot/spec/enterprise/models/user_spec.rb
Normal file
66
research/chatwoot/spec/enterprise/models/user_spec.rb
Normal file
@@ -0,0 +1,66 @@
|
||||
# frozen_string_literal: true
|
||||
|
||||
require 'rails_helper'
|
||||
|
||||
RSpec.describe User do
|
||||
let!(:user) { create(:user) }
|
||||
|
||||
describe 'before validation for pricing plans' do
|
||||
let!(:existing_user) { create(:user) }
|
||||
let(:new_user) { build(:user) }
|
||||
|
||||
context 'when pricing plan is not premium' do
|
||||
before do
|
||||
allow(ChatwootHub).to receive(:pricing_plan).and_return('community')
|
||||
allow(ChatwootHub).to receive(:pricing_plan_quantity).and_return(0)
|
||||
end
|
||||
|
||||
it 'does not add an error to the user' do
|
||||
new_user.valid?
|
||||
expect(new_user.errors[:base]).to be_empty
|
||||
end
|
||||
end
|
||||
|
||||
context 'when pricing plan is premium' do
|
||||
before do
|
||||
allow(ChatwootHub).to receive(:pricing_plan).and_return('premium')
|
||||
end
|
||||
|
||||
context 'when the user limit is reached' do
|
||||
it 'adds an error when trying to create a user' do
|
||||
allow(ChatwootHub).to receive(:pricing_plan_quantity).and_return(1)
|
||||
new_user.valid?
|
||||
expect(new_user.errors[:base]).to include('User limit reached. Please purchase more licenses from super admin')
|
||||
end
|
||||
|
||||
it 'will not add error when trying to update a existing user' do
|
||||
allow(ChatwootHub).to receive(:pricing_plan_quantity).and_return(1)
|
||||
existing_user.update(name: 'new name')
|
||||
# since there is user and existing user, we are already over limits
|
||||
existing_user.valid?
|
||||
expect(existing_user.errors[:base]).to be_empty
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the user limit is not reached' do
|
||||
it 'does not add an error to the user' do
|
||||
allow(ChatwootHub).to receive(:pricing_plan_quantity).and_return(3)
|
||||
new_user.valid?
|
||||
expect(user.errors[:base]).to be_empty
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe 'audit log' do
|
||||
before do
|
||||
create(:user)
|
||||
end
|
||||
|
||||
context 'when user is created' do
|
||||
it 'has no associated audit log created' do
|
||||
expect(Audited::Audit.where(auditable_type: 'User', action: 'create').count).to eq 0
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user