mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-03 09:57:45 -08:00
710e738e8e
Signed-off-by: snipe <snipe@snipe.net>
63 lines
2 KiB
PHP
63 lines
2 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature\Settings;
|
|
|
|
use Tests\TestCase;
|
|
use App\Models\User;
|
|
|
|
|
|
class LdapSettingsTest extends TestCase
|
|
{
|
|
public function testPermissionRequiredToViewLdapSettings()
|
|
{
|
|
$this->actingAs(User::factory()->create())
|
|
->get(route('settings.ldap.index'))
|
|
->assertForbidden();
|
|
}
|
|
|
|
public function testLdapSettingsCanBeSaved()
|
|
{
|
|
$response = $this->actingAs(User::factory()->superuser()->create())
|
|
->post(route('settings.ldap.save', [
|
|
'ldap_enabled' => 1,
|
|
'ldap_username_field' => 'samaccountname',
|
|
'ldap_filter' => 'uid=',
|
|
'ldap_auth_filter_query' => 'uid=',
|
|
'ldap_uname' => 'SomeUserField',
|
|
'ldap_pword' => 'MyAwesomePassword',
|
|
'ldap_basedn' => 'uid=',
|
|
'ldap_fname_field' => 'SomeFirstnameField',
|
|
'ldap_server' => 'ldaps://ldap.example.com',
|
|
]))
|
|
->assertStatus(302)
|
|
->assertValid('ldap_enabled')
|
|
->assertRedirect(route('settings.ldap.index'))
|
|
->assertSessionHasNoErrors();
|
|
$this->followRedirects($response)->assertSee('alert-success');
|
|
}
|
|
|
|
public function testLdapSettingsAreValidatedCorrectly()
|
|
{
|
|
$response = $this->actingAs(User::factory()->superuser()->create())
|
|
->from(route('settings.ldap.index'))
|
|
->post(route('settings.ldap.save', [
|
|
'ldap_enabled' => 1,
|
|
'ldap_username_field' => 'sAMAccountName',
|
|
'ldap_filter' => '(uid=)',
|
|
]))
|
|
->assertStatus(302)
|
|
->assertRedirect(route('settings.ldap.index'))
|
|
->assertSessionHasErrors([
|
|
'ldap_username_field',
|
|
'ldap_auth_filter_query',
|
|
'ldap_uname',
|
|
'ldap_pword',
|
|
'ldap_basedn',
|
|
'ldap_fname_field',
|
|
'ldap_server',
|
|
]);
|
|
$this->followRedirects($response)->assertSee('alert-danger');
|
|
}
|
|
|
|
}
|