Some checks failed
Lock Threads / action (push) Has been cancelled
Mark stale issues and pull requests / stale (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot EE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot EE docker images / merge (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/amd64, ubuntu-latest) (push) Has been cancelled
Publish Chatwoot CE docker images / build (linux/arm64, ubuntu-22.04-arm) (push) Has been cancelled
Publish Chatwoot CE docker images / merge (push) Has been cancelled
Run Chatwoot CE spec / lint-backend (push) Has been cancelled
Run Chatwoot CE spec / lint-frontend (push) Has been cancelled
Run Chatwoot CE spec / frontend-tests (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (0, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (1, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (10, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (11, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (12, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (13, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (14, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (15, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (2, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (3, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (4, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (5, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (6, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (7, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (8, 16) (push) Has been cancelled
Run Chatwoot CE spec / backend-tests (9, 16) (push) Has been cancelled
Run Linux nightly installer / nightly (push) Has been cancelled
- Add Logistics component with progress tracking - Add OrderDetail component for order information - Support data-driven steps and actions - Add blue color scale to widget SCSS - Fix node overflow and progress bar rendering issues - Add English translations for dashboard components Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
54 lines
1.9 KiB
Ruby
54 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe AccountUser, type: :model do
|
|
describe 'associations' do
|
|
# option and dependant nullify
|
|
it { is_expected.to belong_to(:custom_role).optional }
|
|
end
|
|
|
|
describe 'permissions' do
|
|
context 'when custom role is assigned' do
|
|
it 'returns permissions of the custom role along with `custom_role` permission' do
|
|
account = create(:account)
|
|
custom_role = create(:custom_role, account: account)
|
|
account_user = create(:account_user, account: account, custom_role: custom_role)
|
|
|
|
expect(account_user.permissions).to eq(custom_role.permissions + ['custom_role'])
|
|
end
|
|
end
|
|
|
|
context 'when custom role is not assigned' do
|
|
it 'returns permissions of the default role' do
|
|
account = create(:account)
|
|
account_user = create(:account_user, account: account)
|
|
|
|
expect(account_user.permissions).to eq([account_user.role])
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'audit log' do
|
|
context 'when account user is created' do
|
|
it 'has associated audit log created' do
|
|
account_user = create(:account_user)
|
|
account_user_audit_log = Audited::Audit.where(auditable_type: 'AccountUser', action: 'create').first
|
|
expect(account_user_audit_log).to be_present
|
|
expect(account_user_audit_log.associated).to eq(account_user.account)
|
|
end
|
|
end
|
|
|
|
context 'when account user is updated' do
|
|
it 'has associated audit log created' do
|
|
account_user = create(:account_user)
|
|
account_user.update!(availability: 'offline')
|
|
account_user_audit_log = Audited::Audit.where(auditable_type: 'AccountUser', action: 'update').first
|
|
expect(account_user_audit_log).to be_present
|
|
expect(account_user_audit_log.associated).to eq(account_user.account)
|
|
expect(account_user_audit_log.audited_changes).to eq('availability' => [0, 1])
|
|
end
|
|
end
|
|
end
|
|
end
|