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.
		
		
		
		
		
			
		
			
				
					
					
						
							86 lines
						
					
					
						
							2.1 KiB
						
					
					
				
			
		
		
	
	
							86 lines
						
					
					
						
							2.1 KiB
						
					
					
				| <?php | |
| /** | |
|  * @link http://www.yiiframework.com/ | |
|  * @copyright Copyright (c) 2008 Yii Software LLC | |
|  * @license http://www.yiiframework.com/license/ | |
|  */ | |
|  | |
| namespace yiiunit\framework\data; | |
|  | |
| use yii\data\ActiveDataProvider; | |
| use yii\db\Query; | |
| use yiiunit\data\ar\ActiveRecord; | |
| use yiiunit\framework\db\DatabaseTestCase; | |
| use yiiunit\data\ar\Order; | |
|  | |
| /** | |
|  * @author Qiang Xue <qiang.xue@gmail.com> | |
|  * @since 2.0 | |
|  */ | |
| class ActiveDataProviderTest extends DatabaseTestCase | |
| { | |
| 	protected function setUp() | |
| 	{ | |
| 		parent::setUp(); | |
| 		ActiveRecord::$db = $this->getConnection(); | |
| 	} | |
|  | |
| 	public function testActiveQuery() | |
| 	{ | |
| 		$provider = new ActiveDataProvider(array( | |
| 			'query' => Order::find()->orderBy('id'), | |
| 		)); | |
| 		$orders = $provider->getModels(); | |
| 		$this->assertEquals(3, count($orders)); | |
| 		$this->assertTrue($orders[0] instanceof Order); | |
| 		$this->assertEquals(array(1, 2, 3), $provider->getKeys()); | |
|  | |
| 		$provider = new ActiveDataProvider(array( | |
| 			'query' => Order::find(), | |
| 			'pagination' => array( | |
| 				'pageSize' => 2, | |
| 			) | |
| 		)); | |
| 		$orders = $provider->getModels(); | |
| 		$this->assertEquals(2, count($orders)); | |
| 	} | |
|  | |
| 	public function testQuery() | |
| 	{ | |
| 		$query = new Query; | |
| 		$provider = new ActiveDataProvider(array( | |
| 			'db' => $this->getConnection(), | |
| 			'query' => $query->from('tbl_order')->orderBy('id'), | |
| 		)); | |
| 		$orders = $provider->getModels(); | |
| 		$this->assertEquals(3, count($orders)); | |
| 		$this->assertTrue(is_array($orders[0])); | |
| 		$this->assertEquals(array(0, 1, 2), $provider->getKeys()); | |
|  | |
| 		$query = new Query; | |
| 		$provider = new ActiveDataProvider(array( | |
| 			'db' => $this->getConnection(), | |
| 			'query' => $query->from('tbl_order'), | |
| 			'pagination' => array( | |
| 				'pageSize' => 2, | |
| 			) | |
| 		)); | |
| 		$orders = $provider->getModels(); | |
| 		$this->assertEquals(2, count($orders)); | |
| 	} | |
|  | |
| 	public function testRefresh() | |
| 	{ | |
| 		$query = new Query; | |
| 		$provider = new ActiveDataProvider(array( | |
| 			'db' => $this->getConnection(), | |
| 			'query' => $query->from('tbl_order')->orderBy('id'), | |
| 		)); | |
| 		$this->assertEquals(3, count($provider->getModels())); | |
|  | |
| 		$provider->getPagination()->pageSize = 2; | |
| 		$this->assertEquals(3, count($provider->getModels())); | |
| 		$provider->refresh(); | |
| 		$this->assertEquals(2, count($provider->getModels())); | |
| 	} | |
| }
 | |
| 
 |