|
|
|
<?php
|
|
|
|
|
|
|
|
namespace yiiunit\extensions\mongodb;
|
|
|
|
|
|
|
|
use yii\mongodb\ActiveQuery;
|
|
|
|
use yiiunit\data\ar\mongodb\ActiveRecord;
|
|
|
|
use yiiunit\data\ar\mongodb\Customer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group mongodb
|
|
|
|
*/
|
|
|
|
class ActiveRecordTest extends MongoDbTestCase
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var array[] list of test rows.
|
|
|
|
*/
|
|
|
|
protected $testRows = [];
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
ActiveRecord::$db = $this->getConnection();
|
|
|
|
$this->setUpTestRows();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function tearDown()
|
|
|
|
{
|
|
|
|
$this->dropCollection(Customer::collectionName());
|
|
|
|
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,
|
|
|
|
'email' => 'email' . $i,
|
|
|
|
'address' => 'address' . $i,
|
|
|
|
'status' => $i,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
$collection->batchInsert($rows);
|
|
|
|
$this->testRows = $rows;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Tests :
|
|
|
|
|
|
|
|
public function testFind()
|
|
|
|
{
|
|
|
|
// find one
|
|
|
|
$result = Customer::find();
|
|
|
|
$this->assertTrue($result instanceof ActiveQuery);
|
|
|
|
$customer = $result->one();
|
|
|
|
$this->assertTrue($customer instanceof Customer);
|
|
|
|
|
|
|
|
// find all
|
|
|
|
$customers = Customer::find()->all();
|
|
|
|
$this->assertEquals(10, count($customers));
|
|
|
|
$this->assertTrue($customers[0] instanceof Customer);
|
|
|
|
$this->assertTrue($customers[1] instanceof Customer);
|
|
|
|
|
|
|
|
// find by _id
|
|
|
|
$testId = $this->testRows[0]['_id'];
|
|
|
|
$customer = Customer::find($testId);
|
|
|
|
$this->assertTrue($customer instanceof Customer);
|
|
|
|
$this->assertEquals($testId, $customer->_id);
|
|
|
|
|
|
|
|
// find by column values
|
|
|
|
$customer = Customer::find(['name' => 'name5']);
|
|
|
|
$this->assertTrue($customer instanceof Customer);
|
|
|
|
$this->assertEquals($this->testRows[4]['_id'], $customer->_id);
|
|
|
|
$this->assertEquals('name5', $customer->name);
|
|
|
|
$customer = Customer::find(['name' => 'unexisting name']);
|
|
|
|
$this->assertNull($customer);
|
|
|
|
|
|
|
|
// find by attributes
|
|
|
|
$customer = Customer::find()->where(['status' => 4])->one();
|
|
|
|
$this->assertTrue($customer instanceof Customer);
|
|
|
|
$this->assertEquals(4, $customer->status);
|
|
|
|
|
|
|
|
// find count, sum, average, min, max, distinct
|
|
|
|
$this->assertEquals(10, Customer::find()->count());
|
|
|
|
$this->assertEquals(1, Customer::find()->where(['status' => 2])->count());
|
|
|
|
$this->assertEquals((1+10)/2*10, Customer::find()->sum('status'));
|
|
|
|
$this->assertEquals((1+10)/2, Customer::find()->average('status'));
|
|
|
|
$this->assertEquals(1, Customer::find()->min('status'));
|
|
|
|
$this->assertEquals(10, Customer::find()->max('status'));
|
|
|
|
$this->assertEquals(range(1, 10), Customer::find()->distinct('status'));
|
|
|
|
|
|
|
|
// scope
|
|
|
|
$this->assertEquals(1, Customer::find()->activeOnly()->count());
|
|
|
|
|
|
|
|
// asArray
|
|
|
|
$testRow = $this->testRows[2];
|
|
|
|
$customer = Customer::find()->where(['_id' => $testRow['_id']])->asArray()->one();
|
|
|
|
$this->assertEquals($testRow, $customer);
|
|
|
|
|
|
|
|
// indexBy
|
|
|
|
$customers = Customer::find()->indexBy('name')->all();
|
|
|
|
$this->assertTrue($customers['name1'] instanceof Customer);
|
|
|
|
$this->assertTrue($customers['name2'] instanceof Customer);
|
|
|
|
|
|
|
|
// indexBy callable
|
|
|
|
$customers = Customer::find()->indexBy(function ($customer) {
|
|
|
|
return $customer->status . '-' . $customer->status;
|
|
|
|
})->all();
|
|
|
|
$this->assertTrue($customers['1-1'] instanceof Customer);
|
|
|
|
$this->assertTrue($customers['2-2'] instanceof Customer);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInsert()
|
|
|
|
{
|
|
|
|
$record = new Customer;
|
|
|
|
$record->name = 'new name';
|
|
|
|
$record->email = 'new email';
|
|
|
|
$record->address = 'new address';
|
|
|
|
$record->status = 7;
|
|
|
|
|
|
|
|
$this->assertTrue($record->isNewRecord);
|
|
|
|
|
|
|
|
$record->save();
|
|
|
|
|
|
|
|
$this->assertTrue($record->_id instanceof \MongoId);
|
|
|
|
$this->assertFalse($record->isNewRecord);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testInsert
|
|
|
|
*/
|
|
|
|
public function testUpdate()
|
|
|
|
{
|
|
|
|
$record = new Customer;
|
|
|
|
$record->name = 'new name';
|
|
|
|
$record->email = 'new email';
|
|
|
|
$record->address = 'new address';
|
|
|
|
$record->status = 7;
|
|
|
|
$record->save();
|
|
|
|
|
|
|
|
// save
|
|
|
|
$record = Customer::find($record->_id);
|
|
|
|
$this->assertTrue($record instanceof Customer);
|
|
|
|
$this->assertEquals(7, $record->status);
|
|
|
|
$this->assertFalse($record->isNewRecord);
|
|
|
|
|
|
|
|
$record->status = 9;
|
|
|
|
$record->save();
|
|
|
|
$this->assertEquals(9, $record->status);
|
|
|
|
$this->assertFalse($record->isNewRecord);
|
|
|
|
$record2 = Customer::find($record->_id);
|
|
|
|
$this->assertEquals(9, $record2->status);
|
|
|
|
|
|
|
|
// updateAll
|
|
|
|
$pk = ['_id' => $record->_id];
|
|
|
|
$ret = Customer::updateAll(['status' => 55], $pk);
|
|
|
|
$this->assertEquals(1, $ret);
|
|
|
|
$record = Customer::find($pk);
|
|
|
|
$this->assertEquals(55, $record->status);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testInsert
|
|
|
|
*/
|
|
|
|
public function testDelete()
|
|
|
|
{
|
|
|
|
// delete
|
|
|
|
$record = new Customer;
|
|
|
|
$record->name = 'new name';
|
|
|
|
$record->email = 'new email';
|
|
|
|
$record->address = 'new address';
|
|
|
|
$record->status = 7;
|
|
|
|
$record->save();
|
|
|
|
|
|
|
|
$record = Customer::find($record->_id);
|
|
|
|
$record->delete();
|
|
|
|
$record = Customer::find($record->_id);
|
|
|
|
$this->assertNull($record);
|
|
|
|
|
|
|
|
// deleteAll
|
|
|
|
$record = new Customer;
|
|
|
|
$record->name = 'new name';
|
|
|
|
$record->email = 'new email';
|
|
|
|
$record->address = 'new address';
|
|
|
|
$record->status = 7;
|
|
|
|
$record->save();
|
|
|
|
|
|
|
|
$ret = Customer::deleteAll(['name' => 'new name']);
|
|
|
|
$this->assertEquals(1, $ret);
|
|
|
|
$records = Customer::find()->where(['name' => 'new name'])->all();
|
|
|
|
$this->assertEquals(0, count($records));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUpdateAllCounters()
|
|
|
|
{
|
|
|
|
$this->assertEquals(1, Customer::updateAllCounters(['status' => 10], ['status' => 10]));
|
|
|
|
|
|
|
|
$record = Customer::find(['status' => 10]);
|
|
|
|
$this->assertNull($record);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testUpdateAllCounters
|
|
|
|
*/
|
|
|
|
public function testUpdateCounters()
|
|
|
|
{
|
|
|
|
$record = Customer::find($this->testRows[9]);
|
|
|
|
|
|
|
|
$originalCounter = $record->status;
|
|
|
|
$counterIncrement = 20;
|
|
|
|
$record->updateCounters(['status' => $counterIncrement]);
|
|
|
|
$this->assertEquals($originalCounter + $counterIncrement, $record->status);
|
|
|
|
|
|
|
|
$refreshedRecord = Customer::find($record->_id);
|
|
|
|
$this->assertEquals($originalCounter + $counterIncrement, $refreshedRecord->status);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @depends testUpdate
|
|
|
|
*/
|
|
|
|
public function testUpdateNestedAttribute()
|
|
|
|
{
|
|
|
|
$record = new Customer;
|
|
|
|
$record->name = 'new name';
|
|
|
|
$record->email = 'new email';
|
|
|
|
$record->address = [
|
|
|
|
'city' => 'SomeCity',
|
|
|
|
'street' => 'SomeStreet',
|
|
|
|
];
|
|
|
|
$record->status = 7;
|
|
|
|
$record->save();
|
|
|
|
|
|
|
|
// save
|
|
|
|
$record = Customer::find($record->_id);
|
|
|
|
$newAddress = [
|
|
|
|
'city' => 'AnotherCity'
|
|
|
|
];
|
|
|
|
$record->address = $newAddress;
|
|
|
|
$record->save();
|
|
|
|
$record2 = Customer::find($record->_id);
|
|
|
|
$this->assertEquals($newAddress, $record2->address);
|
|
|
|
}
|
|
|
|
}
|