mirror of
				https://github.com/yiisoft/yii2.git
				synced 2025-11-04 06:37:55 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			133 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * @link http://www.yiiframework.com/
 | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC
 | 
						|
 * @license http://www.yiiframework.com/license/
 | 
						|
 */
 | 
						|
 | 
						|
namespace yiiunit\framework\db;
 | 
						|
 | 
						|
use Yii;
 | 
						|
use yii\db\BatchQueryResult;
 | 
						|
use yii\db\Query;
 | 
						|
use yiiunit\data\ar\ActiveRecord;
 | 
						|
use yiiunit\data\ar\Customer;
 | 
						|
 | 
						|
abstract class BatchQueryResultTest extends DatabaseTestCase
 | 
						|
{
 | 
						|
    public function setUp()
 | 
						|
    {
 | 
						|
        parent::setUp();
 | 
						|
        ActiveRecord::$db = $this->getConnection();
 | 
						|
    }
 | 
						|
 | 
						|
    public function testQuery()
 | 
						|
    {
 | 
						|
        $db = $this->getConnection();
 | 
						|
 | 
						|
        // initialize property test
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->orderBy('id');
 | 
						|
        $result = $query->batch(2, $db);
 | 
						|
        $this->assertInstanceOf(BatchQueryResult::className(), $result);
 | 
						|
        $this->assertEquals(2, $result->batchSize);
 | 
						|
        $this->assertSame($result->query, $query);
 | 
						|
 | 
						|
        // normal query
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->orderBy('id');
 | 
						|
        $allRows = [];
 | 
						|
        $batch = $query->batch(2, $db);
 | 
						|
        foreach ($batch as $rows) {
 | 
						|
            $allRows = array_merge($allRows, $rows);
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        $this->assertEquals('user1', $allRows[0]['name']);
 | 
						|
        $this->assertEquals('user2', $allRows[1]['name']);
 | 
						|
        $this->assertEquals('user3', $allRows[2]['name']);
 | 
						|
        // rewind
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($batch as $rows) {
 | 
						|
            $allRows = array_merge($allRows, $rows);
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        // reset
 | 
						|
        $batch->reset();
 | 
						|
 | 
						|
        // empty query
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->where(['id' => 100]);
 | 
						|
        $allRows = [];
 | 
						|
        $batch = $query->batch(2, $db);
 | 
						|
        foreach ($batch as $rows) {
 | 
						|
            $allRows = array_merge($allRows, $rows);
 | 
						|
        }
 | 
						|
        $this->assertCount(0, $allRows);
 | 
						|
 | 
						|
        // query with index
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->indexBy('name');
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($query->batch(2, $db) as $rows) {
 | 
						|
            $allRows = array_merge($allRows, $rows);
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        $this->assertEquals('address1', $allRows['user1']['address']);
 | 
						|
        $this->assertEquals('address2', $allRows['user2']['address']);
 | 
						|
        $this->assertEquals('address3', $allRows['user3']['address']);
 | 
						|
 | 
						|
        // each
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->orderBy('id');
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($query->each(2, $db) as $index => $row) {
 | 
						|
            $allRows[$index] = $row;
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        $this->assertEquals('user1', $allRows[0]['name']);
 | 
						|
        $this->assertEquals('user2', $allRows[1]['name']);
 | 
						|
        $this->assertEquals('user3', $allRows[2]['name']);
 | 
						|
 | 
						|
        // each with key
 | 
						|
        $query = new Query();
 | 
						|
        $query->from('customer')->orderBy('id')->indexBy('name');
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($query->each(100, $db) as $key => $row) {
 | 
						|
            $allRows[$key] = $row;
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        $this->assertEquals('address1', $allRows['user1']['address']);
 | 
						|
        $this->assertEquals('address2', $allRows['user2']['address']);
 | 
						|
        $this->assertEquals('address3', $allRows['user3']['address']);
 | 
						|
    }
 | 
						|
 | 
						|
    public function testActiveQuery()
 | 
						|
    {
 | 
						|
        $db = $this->getConnection();
 | 
						|
 | 
						|
        $query = Customer::find()->orderBy('id');
 | 
						|
        $customers = [];
 | 
						|
        foreach ($query->batch(2, $db) as $models) {
 | 
						|
            $customers = array_merge($customers, $models);
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $customers);
 | 
						|
        $this->assertEquals('user1', $customers[0]->name);
 | 
						|
        $this->assertEquals('user2', $customers[1]->name);
 | 
						|
        $this->assertEquals('user3', $customers[2]->name);
 | 
						|
 | 
						|
        // batch with eager loading
 | 
						|
        $query = Customer::find()->with('orders')->orderBy('id');
 | 
						|
        $customers = [];
 | 
						|
        foreach ($query->batch(2, $db) as $models) {
 | 
						|
            $customers = array_merge($customers, $models);
 | 
						|
            foreach ($models as $model) {
 | 
						|
                $this->assertTrue($model->isRelationPopulated('orders'));
 | 
						|
            }
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $customers);
 | 
						|
        $this->assertCount(1, $customers[0]->orders);
 | 
						|
        $this->assertCount(2, $customers[1]->orders);
 | 
						|
        $this->assertCount(0, $customers[2]->orders);
 | 
						|
    }
 | 
						|
}
 |