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.
246 lines
6.4 KiB
246 lines
6.4 KiB
<?php |
|
|
|
namespace yiiunit\extensions\mongodb; |
|
|
|
use yii\mongodb\ActiveQuery; |
|
use yiiunit\data\ar\mongodb\ActiveRecord; |
|
use yiiunit\data\ar\mongodb\Customer; |
|
|
|
/** |
|
* @group mongo |
|
*/ |
|
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); |
|
} |
|
} |