Paul Klimov
11 years ago
4 changed files with 324 additions and 21 deletions
@ -0,0 +1,110 @@ |
|||||||
|
<?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']); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue