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.
		
		
		
		
		
			
		
			
				
					
					
						
							247 lines
						
					
					
						
							6.4 KiB
						
					
					
				
			
		
		
	
	
							247 lines
						
					
					
						
							6.4 KiB
						
					
					
				<?php | 
						|
 | 
						|
namespace yiiunit\extensions\mongo; | 
						|
 | 
						|
use yii\mongo\ActiveQuery; | 
						|
use yiiunit\data\ar\mongo\ActiveRecord; | 
						|
use yiiunit\data\ar\mongo\Customer; | 
						|
 | 
						|
/** | 
						|
 * @group mongo | 
						|
 */ | 
						|
class ActiveRecordTest extends MongoTestCase | 
						|
{ | 
						|
	/** | 
						|
	 * @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); | 
						|
		$ret = Customer::updateAll(['$set' => ['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); | 
						|
	} | 
						|
} |