# Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ require 'rails_helper' require 'models/concerns/has_collection_update_examples' require 'models/concerns/has_xss_sanitized_note_examples' RSpec.describe Permission, type: :model do it_behaves_like 'HasCollectionUpdate', collection_factory: :permission it_behaves_like 'HasXssSanitizedNote', model_factory: :permission, attribut_name: :description describe '.with_parents' do context 'when given a simple string (no dots)' do it 'returns an array containing only that string' do expect(described_class.with_parents('foo')).to eq(['foo']) end end context 'when given a String permission name (dot-delimited identifier)' do it 'returns an array of String ancestors (desc. from root)' do expect(described_class.with_parents('foo.bar.baz')) .to eq(%w[foo foo.bar foo.bar.baz]) end end end describe '.join_with' do let!(:agents) { create_list(:agent, 5) } let!(:customers) { create_list(:customer, 5) } it 'does include agents' do expect(described_class.join_with(User, 'ticket.agent')).to include(*agents) end it 'does exclude customers' do expect(described_class.join_with(User, 'ticket.agent')).not_to include(*customers) end end end