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.
		
		
		
		
			
				
					83 lines
				
				2.1 KiB
			
		
		
			
		
	
	
					83 lines
				
				2.1 KiB
			| 
											12 years ago
										 | <?php
 | ||
|  | 
 | ||
| 
											12 years ago
										 | namespace yiiunit\extensions\mongodb;
 | ||
| 
											12 years ago
										 | 
 | ||
| 
											12 years ago
										 | use yiiunit\data\ar\mongodb\ActiveRecord;
 | ||
|  | use yiiunit\data\ar\mongodb\Customer;
 | ||
|  | use yiiunit\data\ar\mongodb\CustomerOrder;
 | ||
| 
											12 years ago
										 | 
 | ||
|  | /**
 | ||
|  |  * @group mongo
 | ||
|  |  */
 | ||
| 
											12 years ago
										 | class ActiveRelationTest extends MongoDbTestCase
 | ||
| 
											12 years ago
										 | {
 | ||
|  | 	protected function setUp()
 | ||
|  | 	{
 | ||
|  | 		parent::setUp();
 | ||
|  | 		ActiveRecord::$db = $this->getConnection();
 | ||
|  | 		$this->setUpTestRows();
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 	protected function tearDown()
 | ||
|  | 	{
 | ||
|  | 		$this->dropCollection(Customer::collectionName());
 | ||
|  | 		$this->dropCollection(CustomerOrder::collectionName());
 | ||
|  | 		parent::tearDown();
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 	/**
 | ||
|  | 	 * Sets up test rows.
 | ||
|  | 	 */
 | ||
|  | 	protected function setUpTestRows()
 | ||
|  | 	{
 | ||
|  | 		$customerCollection = $this->getConnection()->getCollection('customer');
 | ||
|  | 
 | ||
|  | 		$customers = [];
 | ||
|  | 		for ($i = 1; $i <= 5; $i++) {
 | ||
|  | 			$customers[] = [
 | ||
|  | 				'name' => 'name' . $i,
 | ||
|  | 				'email' => 'email' . $i,
 | ||
|  | 				'address' => 'address' . $i,
 | ||
|  | 				'status' => $i,
 | ||
|  | 			];
 | ||
|  | 		}
 | ||
|  | 		$customerCollection->batchInsert($customers);
 | ||
|  | 
 | ||
|  | 		$customerOrderCollection = $this->getConnection()->getCollection('customer_order');
 | ||
|  | 		$customerOrders = [];
 | ||
|  | 		foreach ($customers as $customer) {
 | ||
|  | 			$customerOrders[] = [
 | ||
|  | 				'customer_id' => $customer['_id'],
 | ||
|  | 				'number' => $customer['status'],
 | ||
|  | 			];
 | ||
|  | 			$customerOrders[] = [
 | ||
|  | 				'customer_id' => $customer['_id'],
 | ||
|  | 				'number' => $customer['status'] + 1,
 | ||
|  | 			];
 | ||
|  | 		}
 | ||
|  | 		$customerOrderCollection->batchInsert($customerOrders);
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 	// Tests :
 | ||
|  | 
 | ||
|  | 	public function testFindLazy()
 | ||
|  | 	{
 | ||
|  | 		/** @var CustomerOrder $order */
 | ||
|  | 		$order = CustomerOrder::find(['number' => 2]);
 | ||
|  | 		$this->assertFalse($order->isRelationPopulated('customer'));
 | ||
|  | 		$index = $order->customer;
 | ||
|  | 		$this->assertTrue($order->isRelationPopulated('customer'));
 | ||
|  | 		$this->assertTrue($index instanceof Customer);
 | ||
|  | 		$this->assertEquals(1, count($order->populatedRelations));
 | ||
|  | 	}
 | ||
|  | 
 | ||
|  | 	public function testFindEager()
 | ||
|  | 	{
 | ||
|  | 		$orders = CustomerOrder::find()->with('customer')->all();
 | ||
|  | 		$this->assertEquals(10, count($orders));
 | ||
|  | 		$this->assertTrue($orders[0]->isRelationPopulated('customer'));
 | ||
|  | 		$this->assertTrue($orders[1]->isRelationPopulated('customer'));
 | ||
| 
											12 years ago
										 | 		$this->assertTrue($orders[0]->customer instanceof Customer);
 | ||
|  | 		$this->assertTrue($orders[1]->customer instanceof Customer);
 | ||
| 
											12 years ago
										 | 	}
 | ||
|  | }
 |