You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
2.3 KiB
110 lines
2.3 KiB
11 years ago
|
<?php
|
||
|
|
||
|
namespace yiiunit\extensions\mongo;
|
||
|
|
||
|
use yii\mongo\Query;
|
||
|
|
||
|
/**
|
||
|
* @group mongo
|
||
|
*/
|
||
|
class QueryRunTest extends MongoTestCase
|
||
|
{
|
||
|
protected function setUp()
|
||
|
{
|
||
|
parent::setUp();
|
||
|
$this->setUpTestRows();
|
||
|
}
|
||
|
|
||
|
protected function tearDown()
|
||
|
{
|
||
|
$this->dropCollection('customer');
|
||
|
parent::tearDown();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets up test rows.
|
||
|
*/
|
||
|
protected function setUpTestRows()
|
||
|
{
|
||
|
$collection = $this->getConnection()->getCollection('customer');
|
||
|
$rows = [];
|
||
|
for ($i = 1; $i <= 10; $i++) {
|
||
|
$rows[] = [
|
||
|
'name' => 'name' . $i,
|
||
|
'address' => 'address' . $i,
|
||
|
];
|
||
|
}
|
||
|
$collection->batchInsert($rows);
|
||
|
}
|
||
|
|
||
|
// Tests :
|
||
|
|
||
|
public function testAll()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')->all($connection);
|
||
|
$this->assertEquals(10, count($rows));
|
||
|
}
|
||
|
|
||
|
public function testDirectMatch()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')
|
||
|
->where(['name' => 'name1'])
|
||
|
->all($connection);
|
||
|
$this->assertEquals(1, count($rows));
|
||
|
$this->assertEquals('name1', $rows[0]['name']);
|
||
|
}
|
||
|
|
||
|
public function testIndexBy()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')
|
||
|
->indexBy('name')
|
||
|
->all($connection);
|
||
|
$this->assertEquals(10, count($rows));
|
||
|
$this->assertNotEmpty($rows['name1']);
|
||
|
}
|
||
|
|
||
|
public function testInCondition()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')
|
||
|
->where([
|
||
|
'name' => [
|
||
|
'in' => ['name1', 'name5']
|
||
|
]
|
||
|
])
|
||
|
->all($connection);
|
||
|
$this->assertEquals(2, count($rows));
|
||
|
$this->assertEquals('name1', $rows[0]['name']);
|
||
|
$this->assertEquals('name5', $rows[1]['name']);
|
||
|
}
|
||
|
|
||
|
public function testOrCondition()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')
|
||
|
->where(['name' => 'name1'])
|
||
|
->orWhere(['address' => 'address5'])
|
||
|
->all($connection);
|
||
|
$this->assertEquals(2, count($rows));
|
||
|
$this->assertEquals('name1', $rows[0]['name']);
|
||
|
$this->assertEquals('address5', $rows[1]['address']);
|
||
|
}
|
||
|
|
||
|
public function testOrder()
|
||
|
{
|
||
|
$connection = $this->getConnection();
|
||
|
$query = new Query;
|
||
|
$rows = $query->from('customer')
|
||
|
->orderBy(['name' => SORT_DESC])
|
||
|
->all($connection);
|
||
|
$this->assertEquals('name9', $rows[0]['name']);
|
||
|
}
|
||
|
}
|