123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe LdapSourceConfig, type: :db_migration do
- context 'with existing LDAP sources' do
- let!(:ldap_source) { create(:ldap_source, preferences: preferences) }
- let(:preferences) do
- {
- 'host_url' => host_url,
- 'options' => { 'dc=foo,dc=example,dc=com'=>'dc=foo,dc=example,dc=com' },
- 'option' => 'dc=foo,dc=example,dc=com',
- 'base_dn' => 'dc=foo,dc=example,dc=com',
- 'bind_user' => 'dummy',
- 'bind_pw' => 'dummy',
- 'user_uid' => 'uid',
- 'user_filter' => '(objectClass=posixaccount)',
- 'group_uid' => 'dn',
- 'group_filter' => '(objectClass=posixgroup)',
- 'user_attributes' => { 'cn' => 'firstname', 'sn' => 'lastname', 'mail' => 'email', 'uid' => 'login', 'telephonenumber' => 'phone' },
- 'group_role_map' => { 'cn=admin,ou=groups,dc=foo,dc=example,dc=com' => ['1'], 'cn=1st level,ou=groups,dc=foo,dc=example,dc=com' => ['2'] },
- 'unassigned_users' => 'sigup_roles',
- }
- end
- context 'with LDAPS' do
- let(:host_url) { 'ldaps://ldaps.example.com' }
- it 'migrates the LdapSource', :aggregate_failures do
- migrate
- ldap_source.reload
- expect(ldap_source.preferences['host']).to eq('ldaps.example.com')
- expect(ldap_source.preferences['ssl']).to eq('ssl')
- expect(ldap_source.preferences).not_to have_key('host_url')
- end
- end
- context 'with LDAP' do
- let(:host_url) { 'ldap://ldap.example.com' }
- it 'migrates the LdapSource', :aggregate_failures do
- migrate
- ldap_source.reload
- expect(ldap_source.preferences['host']).to eq('ldap.example.com')
- expect(ldap_source.preferences['ssl']).to eq('off')
- expect(ldap_source.preferences).not_to have_key('host_url')
- end
- end
- context 'without host_url' do
- let(:preferences) do
- {
- 'host' => 'ldap.example.com',
- 'ssl' => ssl,
- 'options' => { 'dc=foo,dc=example,dc=com'=>'dc=foo,dc=example,dc=com' },
- 'option' => 'dc=foo,dc=example,dc=com',
- 'base_dn' => 'dc=foo,dc=example,dc=com',
- 'bind_user' => 'dummy',
- 'bind_pw' => 'dummy',
- 'user_uid' => 'uid',
- 'user_filter' => '(objectClass=posixaccount)',
- 'group_uid' => 'dn',
- 'group_filter' => '(objectClass=posixgroup)',
- 'user_attributes' => { 'cn' => 'firstname', 'sn' => 'lastname', 'mail' => 'email', 'uid' => 'login', 'telephonenumber' => 'phone' },
- 'group_role_map' => { 'cn=admin,ou=groups,dc=foo,dc=example,dc=com' => ['1'], 'cn=1st level,ou=groups,dc=foo,dc=example,dc=com' => ['2'] },
- 'unassigned_users' => 'sigup_roles',
- }
- end
- context 'with ssl = true' do
- let(:ssl) { true }
- it 'migrates the LdapSource', :aggregate_failures do
- migrate
- ldap_source.reload
- expect(ldap_source.preferences['host']).to eq('ldap.example.com')
- expect(ldap_source.preferences['ssl']).to eq('ssl')
- expect(ldap_source.preferences).not_to have_key('host_url')
- end
- end
- context 'with ssl = false' do
- let(:ssl) { false }
- it 'migrates the LdapSource', :aggregate_failures do
- migrate
- ldap_source.reload
- expect(ldap_source.preferences['host']).to eq('ldap.example.com')
- expect(ldap_source.preferences['ssl']).to eq('off')
- expect(ldap_source.preferences).not_to have_key('host_url')
- end
- end
- end
- end
- end
|