mirror of
				https://github.com/yiisoft/yii2.git
				synced 2025-11-04 14:46:19 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			151 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * @link https://www.yiiframework.com/
 | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC
 | 
						|
 * @license https://www.yiiframework.com/license/
 | 
						|
 */
 | 
						|
 | 
						|
namespace yiiunit\framework\db;
 | 
						|
 | 
						|
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');
 | 
						|
        $batch = $query->batch(2, $db);
 | 
						|
        $allRows = $this->getAllRowsFromBatch($batch);
 | 
						|
        $this->assertCount(3, $allRows);
 | 
						|
        $this->assertEquals('user1', $allRows[0]['name']);
 | 
						|
        $this->assertEquals('user2', $allRows[1]['name']);
 | 
						|
        $this->assertEquals('user3', $allRows[2]['name']);
 | 
						|
        // rewind
 | 
						|
        $allRows = $this->getAllRowsFromBatch($batch);
 | 
						|
        $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 = $this->getAllRowsFromBatch($query->batch(2, $db));
 | 
						|
        $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 = $this->getAllRowsFromEach($query->each(2, $db));
 | 
						|
        $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 = $this->getAllRowsFromEach($query->each(100, $db));
 | 
						|
        $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 = $this->getAllRowsFromBatch($query->batch(2, $db));
 | 
						|
        $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 = $this->getAllRowsFromBatch($query->batch(2, $db));
 | 
						|
        foreach ($customers as $customer) {
 | 
						|
            $this->assertTrue($customer->isRelationPopulated('orders'));
 | 
						|
        }
 | 
						|
        $this->assertCount(3, $customers);
 | 
						|
        $this->assertCount(1, $customers[0]->orders);
 | 
						|
        $this->assertCount(2, $customers[1]->orders);
 | 
						|
        $this->assertCount(0, $customers[2]->orders);
 | 
						|
    }
 | 
						|
 | 
						|
    public function testBatchWithoutDbParameter()
 | 
						|
    {
 | 
						|
        $query = Customer::find()->orderBy('id')->limit(3);
 | 
						|
        $customers = $this->getAllRowsFromBatch($query->batch(2));
 | 
						|
        $this->assertCount(3, $customers);
 | 
						|
        $this->assertEquals('user1', $customers[0]->name);
 | 
						|
        $this->assertEquals('user2', $customers[1]->name);
 | 
						|
        $this->assertEquals('user3', $customers[2]->name);
 | 
						|
    }
 | 
						|
 | 
						|
    public function testBatchWithIndexBy()
 | 
						|
    {
 | 
						|
        $query = Customer::find()->orderBy('id')->limit(3)->indexBy('id');
 | 
						|
        $customers = $this->getAllRowsFromBatch($query->batch(2));
 | 
						|
        $this->assertCount(3, $customers);
 | 
						|
        $this->assertEquals('user1', $customers[0]->name);
 | 
						|
        $this->assertEquals('user2', $customers[1]->name);
 | 
						|
        $this->assertEquals('user3', $customers[2]->name);
 | 
						|
    }
 | 
						|
 | 
						|
    protected function getAllRowsFromBatch(BatchQueryResult $batch)
 | 
						|
    {
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($batch as $rows) {
 | 
						|
            $allRows = array_merge($allRows, $rows);
 | 
						|
        }
 | 
						|
 | 
						|
        return $allRows;
 | 
						|
    }
 | 
						|
 | 
						|
    protected function getAllRowsFromEach(BatchQueryResult $each)
 | 
						|
    {
 | 
						|
        $allRows = [];
 | 
						|
        foreach ($each as $index => $row) {
 | 
						|
            $allRows[$index] = $row;
 | 
						|
        }
 | 
						|
 | 
						|
        return $allRows;
 | 
						|
    }
 | 
						|
}
 |