|
|
|
<?php
|
|
|
|
|
|
|
|
namespace yiiunit\extensions\mongodb;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group mongodb
|
|
|
|
*/
|
|
|
|
class CollectionTest extends MongoDbTestCase
|
|
|
|
{
|
|
|
|
protected function tearDown()
|
|
|
|
{
|
|
|
|
$this->dropCollection('customer');
|
|
|
|
$this->dropCollection('mapReduceOut');
|
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tests :
|
|
|
|
|
|
|
|
public function testGetName()
|
|
|
|
{
|
|
|
|
$collectionName = 'customer';
|
|
|
|
$collection = $this->getConnection()->getCollection($collectionName);
|
|
|
|
$this->assertEquals($collectionName, $collection->getName());
|
|
|
|
$this->assertEquals($this->mongoDbConfig['defaultDatabaseName'] . '.' . $collectionName, $collection->getFullName());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testFind()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$cursor = $collection->find();
|
|
|
|
$this->assertTrue($cursor instanceof \MongoCursor);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInsert()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$id = $collection->insert($data);
|
|
|
|
$this->assertTrue($id instanceof \MongoId);
|
|
|
|
$this->assertNotEmpty($id->__toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testInsert
|
|
|
|
* @depends testFind
|
|
|
|
*/
|
|
|
|
public function testFindAll()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$id = $collection->insert($data);
|
|
|
|
|
|
|
|
$cursor = $collection->find();
|
|
|
|
$rows = [];
|
|
|
|
foreach ($cursor as $row) {
|
|
|
|
$rows[] = $row;
|
|
|
|
}
|
|
|
|
$this->assertEquals(1, count($rows));
|
|
|
|
$this->assertEquals($id, $rows[0]['_id']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testFind
|
|
|
|
*/
|
|
|
|
public function testBatchInsert()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$rows = [
|
|
|
|
[
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'customer 2',
|
|
|
|
'address' => 'customer 2 address',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$insertedRows = $collection->batchInsert($rows);
|
|
|
|
$this->assertTrue($insertedRows[0]['_id'] instanceof \MongoId);
|
|
|
|
$this->assertTrue($insertedRows[1]['_id'] instanceof \MongoId);
|
|
|
|
$this->assertEquals(count($rows), $collection->find()->count());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSave()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$id = $collection->save($data);
|
|
|
|
$this->assertTrue($id instanceof \MongoId);
|
|
|
|
$this->assertNotEmpty($id->__toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testSave
|
|
|
|
*/
|
|
|
|
public function testUpdateBySave()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$newId = $collection->save($data);
|
|
|
|
|
|
|
|
$updatedId = $collection->save($data);
|
|
|
|
$this->assertEquals($newId, $updatedId, 'Unable to update data!');
|
|
|
|
|
|
|
|
$data['_id'] = $newId->__toString();
|
|
|
|
$updatedId = $collection->save($data);
|
|
|
|
$this->assertEquals($newId, $updatedId, 'Unable to updated data by string id!');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testFindAll
|
|
|
|
*/
|
|
|
|
public function testRemove()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$id = $collection->insert($data);
|
|
|
|
|
|
|
|
$count = $collection->remove(['_id' => $id]);
|
|
|
|
$this->assertEquals(1, $count);
|
|
|
|
|
|
|
|
$rows = $this->findAll($collection);
|
|
|
|
$this->assertEquals(0, count($rows));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testFindAll
|
|
|
|
*/
|
|
|
|
public function testUpdate()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$data = [
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
];
|
|
|
|
$id = $collection->insert($data);
|
|
|
|
|
|
|
|
$newData = [
|
|
|
|
'name' => 'new name'
|
|
|
|
];
|
|
|
|
$count = $collection->update(['_id' => $id], $newData);
|
|
|
|
$this->assertEquals(1, $count);
|
|
|
|
|
|
|
|
list($row) = $this->findAll($collection);
|
|
|
|
$this->assertEquals($newData['name'], $row['name']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testBatchInsert
|
|
|
|
*/
|
|
|
|
public function testGroup()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$rows = [
|
|
|
|
[
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'address' => 'customer 1 address',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'customer 2',
|
|
|
|
'address' => 'customer 2 address',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$collection->batchInsert($rows);
|
|
|
|
|
|
|
|
$keys = ['address' => 1];
|
|
|
|
$initial = ['items' => []];
|
|
|
|
$reduce = "function (obj, prev) { prev.items.push(obj.name); }";
|
|
|
|
$result = $collection->group($keys, $initial, $reduce);
|
|
|
|
$this->assertEquals(2, count($result));
|
|
|
|
$this->assertNotEmpty($result[0]['address']);
|
|
|
|
$this->assertNotEmpty($result[0]['items']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testBatchInsert
|
|
|
|
*/
|
|
|
|
public function testMapReduce()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$rows = [
|
|
|
|
[
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'status' => 1,
|
|
|
|
'amount' => 100,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'customer 2',
|
|
|
|
'status' => 1,
|
|
|
|
'amount' => 200,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'customer 2',
|
|
|
|
'status' => 2,
|
|
|
|
'amount' => 400,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'customer 2',
|
|
|
|
'status' => 3,
|
|
|
|
'amount' => 500,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$collection->batchInsert($rows);
|
|
|
|
|
|
|
|
$result = $collection->mapReduce(
|
|
|
|
'function () {emit(this.status, this.amount)}',
|
|
|
|
'function (key, values) {return Array.sum(values)}',
|
|
|
|
'mapReduceOut',
|
|
|
|
['status' => ['$lt' => 3]]
|
|
|
|
);
|
|
|
|
$this->assertEquals('mapReduceOut', $result);
|
|
|
|
|
|
|
|
$outputCollection = $this->getConnection()->getCollection($result);
|
|
|
|
$rows = $this->findAll($outputCollection);
|
|
|
|
$expectedRows = [
|
|
|
|
[
|
|
|
|
'_id' => 1,
|
|
|
|
'value' => 300,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'_id' => 2,
|
|
|
|
'value' => 400,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$this->assertEquals($expectedRows, $rows);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCreateIndex()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$columns = [
|
|
|
|
'name',
|
|
|
|
'status' => \MongoCollection::DESCENDING,
|
|
|
|
];
|
|
|
|
$this->assertTrue($collection->createIndex($columns));
|
|
|
|
$indexInfo = $collection->mongoCollection->getIndexInfo();
|
|
|
|
$this->assertEquals(2, count($indexInfo));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testCreateIndex
|
|
|
|
*/
|
|
|
|
public function testDropIndex()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
|
|
|
|
$collection->createIndex('name');
|
|
|
|
$this->assertTrue($collection->dropIndex('name'));
|
|
|
|
$indexInfo = $collection->mongoCollection->getIndexInfo();
|
|
|
|
$this->assertEquals(1, count($indexInfo));
|
|
|
|
|
|
|
|
$this->setExpectedException('\yii\mongodb\Exception');
|
|
|
|
$collection->dropIndex('name');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testCreateIndex
|
|
|
|
*/
|
|
|
|
public function testDropAllIndexes()
|
|
|
|
{
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
$collection->createIndex('name');
|
|
|
|
$this->assertEquals(2, $collection->dropAllIndexes());
|
|
|
|
$indexInfo = $collection->mongoCollection->getIndexInfo();
|
|
|
|
$this->assertEquals(1, count($indexInfo));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testBatchInsert
|
|
|
|
* @depends testCreateIndex
|
|
|
|
*/
|
|
|
|
public function testFullTextSearch()
|
|
|
|
{
|
|
|
|
if (version_compare('2.4', $this->getServerVersion(), '>')) {
|
|
|
|
$this->markTestSkipped("Mongo Server 2.4 required.");
|
|
|
|
}
|
|
|
|
|
|
|
|
$collection = $this->getConnection()->getCollection('customer');
|
|
|
|
|
|
|
|
$rows = [
|
|
|
|
[
|
|
|
|
'name' => 'customer 1',
|
|
|
|
'status' => 1,
|
|
|
|
'amount' => 100,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'some customer',
|
|
|
|
'status' => 1,
|
|
|
|
'amount' => 200,
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'name' => 'no search keyword',
|
|
|
|
'status' => 1,
|
|
|
|
'amount' => 200,
|
|
|
|
],
|
|
|
|
];
|
|
|
|
$collection->batchInsert($rows);
|
|
|
|
$collection->createIndex(['name' => 'text']);
|
|
|
|
|
|
|
|
$result = $collection->fullTextSearch('customer');
|
|
|
|
$this->assertNotEmpty($result);
|
|
|
|
$this->assertCount(2, $result);
|
|
|
|
}
|
|
|
|
}
|