mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 14:27:33 -08:00
Add more LDAP tests - including pagination(!)
This commit is contained in:
parent
16da994e28
commit
5a60df55d1
|
@ -105,4 +105,106 @@ class LdapTest extends TestCase
|
||||||
$results = Ldap::findAndBindUserLdap("username","password");
|
$results = Ldap::findAndBindUserLdap("username","password");
|
||||||
$this->assertEqualsCanonicalizing(["count" =>1,0 =>['sn' => 'Surname','firstname' => 'FirstName']],$results);
|
$this->assertEqualsCanonicalizing(["count" =>1,0 =>['sn' => 'Surname','firstname' => 'FirstName']],$results);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFindAndBindBadPassword()
|
||||||
|
{
|
||||||
|
$this->settings->enableLdap();
|
||||||
|
|
||||||
|
$ldap_connect = $this->getFunctionMock("App\\Models", "ldap_connect");
|
||||||
|
$ldap_connect->expects($this->once())->willReturn('hello');
|
||||||
|
|
||||||
|
$ldap_set_option = $this->getFunctionMock("App\\Models", "ldap_set_option");
|
||||||
|
$ldap_set_option->expects($this->exactly(3));
|
||||||
|
|
||||||
|
// note - we return FALSE first, to simulate a bad-bind, then TRUE the second time to simulate a successful admin bind
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_bind")->expects($this->exactly(2))->willReturn(false, true);
|
||||||
|
|
||||||
|
// $this->getFunctionMock("App\\Models","ldap_error")->expects($this->once())->willReturn("exception");
|
||||||
|
|
||||||
|
|
||||||
|
// $this->expectExceptionMessage("exception");
|
||||||
|
$results = Ldap::findAndBindUserLdap("username","password");
|
||||||
|
$this->assertFalse($results);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFindAndBindCannotFindSelf()
|
||||||
|
{
|
||||||
|
$this->settings->enableLdap();
|
||||||
|
|
||||||
|
$ldap_connect = $this->getFunctionMock("App\\Models", "ldap_connect");
|
||||||
|
$ldap_connect->expects($this->once())->willReturn('hello');
|
||||||
|
|
||||||
|
$ldap_set_option = $this->getFunctionMock("App\\Models", "ldap_set_option");
|
||||||
|
$ldap_set_option->expects($this->exactly(3));
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_bind")->expects($this->once())->willReturn(true);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_search")->expects($this->once())->willReturn(false);
|
||||||
|
|
||||||
|
$this->expectExceptionMessage("Could not search LDAP:");
|
||||||
|
$results = Ldap::findAndBindUserLdap("username","password");
|
||||||
|
$this->assertFalse($results);
|
||||||
|
}
|
||||||
|
|
||||||
|
//maybe should do an AD test as well?
|
||||||
|
|
||||||
|
public function testFindLdapUsers()
|
||||||
|
{
|
||||||
|
$this->settings->enableLdap();
|
||||||
|
|
||||||
|
$ldap_connect = $this->getFunctionMock("App\\Models", "ldap_connect");
|
||||||
|
$ldap_connect->expects($this->once())->willReturn('hello');
|
||||||
|
|
||||||
|
$ldap_set_option = $this->getFunctionMock("App\\Models", "ldap_set_option");
|
||||||
|
$ldap_set_option->expects($this->exactly(3));
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_bind")->expects($this->once())->willReturn(true);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_search")->expects($this->once())->willReturn(["stuff"]);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_parse_result")->expects($this->once())->willReturn(true);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_get_entries")->expects($this->once())->willReturn(["count" => 1]);
|
||||||
|
|
||||||
|
$results = Ldap::findLdapUsers();
|
||||||
|
|
||||||
|
$this->assertEqualsCanonicalizing(["count" => 1], $results);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFindLdapUsersPaginated()
|
||||||
|
{
|
||||||
|
$this->settings->enableLdap();
|
||||||
|
|
||||||
|
$ldap_connect = $this->getFunctionMock("App\\Models", "ldap_connect");
|
||||||
|
$ldap_connect->expects($this->once())->willReturn('hello');
|
||||||
|
|
||||||
|
$ldap_set_option = $this->getFunctionMock("App\\Models", "ldap_set_option");
|
||||||
|
$ldap_set_option->expects($this->exactly(3));
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_bind")->expects($this->once())->willReturn(true);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_search")->expects($this->exactly(2))->willReturn(["stuff"]);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_parse_result")->expects($this->exactly(2))->willReturnCallback(
|
||||||
|
function ($ldapconn, $search_results, $errcode , $matcheddn , $errmsg , $referrals, &$controls) {
|
||||||
|
static $count = 0;
|
||||||
|
if($count == 0) {
|
||||||
|
$count++;
|
||||||
|
$controls[LDAP_CONTROL_PAGEDRESULTS]['value']['cookie'] = "cookie";
|
||||||
|
return ["count" => 1];
|
||||||
|
} else {
|
||||||
|
$controls = [];
|
||||||
|
return ["count" => 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->getFunctionMock("App\\Models", "ldap_get_entries")->expects($this->exactly(2))->willReturn(["count" => 1]);
|
||||||
|
|
||||||
|
$results = Ldap::findLdapUsers();
|
||||||
|
|
||||||
|
$this->assertEqualsCanonicalizing(["count" => 2], $results);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue