2013-06-03 15:34:57 +02:00
|
|
|
<?php
|
2014-04-09 14:18:14 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
2013-06-03 15:34:57 +02:00
|
|
|
namespace Tests\Icinga\Protocol\Ldap;
|
2014-04-09 14:18:14 +02:00
|
|
|
|
2014-11-18 13:11:52 +01:00
|
|
|
use Icinga\Data\ConfigObject;
|
2014-04-10 10:32:50 +02:00
|
|
|
use Icinga\Test\BaseTestCase;
|
|
|
|
use Icinga\Protocol\Ldap\Connection;
|
2014-04-09 14:18:14 +02:00
|
|
|
|
2014-04-10 10:32:50 +02:00
|
|
|
class QueryTest extends BaseTestCase
|
2013-06-03 15:34:57 +02:00
|
|
|
{
|
|
|
|
private function emptySelect()
|
|
|
|
{
|
2014-11-18 13:11:52 +01:00
|
|
|
$config = new ConfigObject(
|
2013-10-22 16:24:49 +02:00
|
|
|
array(
|
|
|
|
'hostname' => 'localhost',
|
|
|
|
'root_dn' => 'dc=example,dc=com',
|
|
|
|
'bind_dn' => 'cn=user,ou=users,dc=example,dc=com',
|
|
|
|
'bind_pw' => '***'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2014-04-10 10:32:50 +02:00
|
|
|
$connection = new Connection($config);
|
2013-06-03 15:34:57 +02:00
|
|
|
return $connection->select();
|
|
|
|
}
|
|
|
|
|
|
|
|
private function prepareSelect()
|
|
|
|
{
|
|
|
|
$select = $this->emptySelect();
|
|
|
|
$select->from('dummyClass', array('testIntColumn', 'testStringColumn'))
|
|
|
|
->where('testIntColumn', 1)
|
|
|
|
->where('testStringColumn', 'test')
|
|
|
|
->where('testWildcard', 'abc*')
|
|
|
|
->order('testIntColumn')
|
|
|
|
->limit(10, 4);
|
|
|
|
return $select;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLimit()
|
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertEquals(10, $select->getLimit());
|
|
|
|
$this->assertEquals(4, $select->getOffset());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testHasLimit()
|
|
|
|
{
|
|
|
|
$select = $this->emptySelect();
|
|
|
|
$this->assertFalse($select->hasLimit());
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertTrue($select->hasLimit());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testHasOffset()
|
|
|
|
{
|
|
|
|
$select = $this->emptySelect();
|
|
|
|
$this->assertFalse($select->hasOffset());
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertTrue($select->hasOffset());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetLimit()
|
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertEquals(10, $select->getLimit());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetOffset()
|
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertEquals(10, $select->getLimit());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testFetchTree()
|
|
|
|
{
|
|
|
|
$this->markTestIncomplete('testFetchTree is not implemented yet - requires real LDAP');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testFrom()
|
|
|
|
{
|
|
|
|
return $this->testListFields();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testWhere()
|
|
|
|
{
|
|
|
|
$this->markTestIncomplete('testWhere is not implemented yet');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testOrder()
|
|
|
|
{
|
|
|
|
$select = $this->emptySelect()->order('bla');
|
|
|
|
// tested by testGetSortColumns
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testListFields()
|
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$this->assertEquals(
|
|
|
|
array('testIntColumn', 'testStringColumn'),
|
|
|
|
$select->listFields()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetSortColumns()
|
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$cols = $select->getSortColumns();
|
|
|
|
$this->assertEquals('testIntColumn', $cols[0][0]);
|
|
|
|
}
|
|
|
|
|
2014-09-02 10:17:01 +02:00
|
|
|
public function testCreateQuery()
|
2013-06-03 15:34:57 +02:00
|
|
|
{
|
|
|
|
$select = $this->prepareSelect();
|
|
|
|
$res = '(&(objectClass=dummyClass)(testIntColumn=1)(testStringColumn=test)(testWildcard=abc*))';
|
2014-09-02 10:17:01 +02:00
|
|
|
$this->assertEquals($res, $select->create());
|
2013-06-03 15:34:57 +02:00
|
|
|
}
|
|
|
|
}
|