db->driverName === 'sqlsrv') { $this->db->createCommand()->truncateTable('profile')->execute(); } parent::beforeLoad(); } protected function getData() { $data = parent::getData(); if ($this->db->driverName === 'sqlsrv') { array_walk($data, static function (&$item) { unset($item['id']); }); } return $data; } } class CustomerFixture extends ActiveFixture { public $modelClass = 'yiiunit\data\ar\Customer'; public $depends = [ 'yiiunit\framework\test\ProfileFixture', ]; public function beforeLoad() { if ($this->db->driverName === 'sqlsrv') { $this->db->createCommand()->truncateTable('customer')->execute(); } parent::beforeLoad(); } } class CustomDirectoryFixture extends ActiveFixture { public $modelClass = 'yiiunit\data\ar\Customer'; public $dataDirectory = '@app/framework/test/custom'; public function beforeLoad() { if ($this->db->driverName === 'sqlsrv') { $this->db->createCommand()->truncateTable('customer')->execute(); } parent::beforeLoad(); } } class AnimalFixture extends ActiveFixture { public $modelClass = 'yiiunit\data\ar\Animal'; } class BaseDbTestCase { use FixtureTrait; public function setUp() { $this->initFixtures(); } public function tearDown() { } } class CustomerDbTestCase extends BaseDbTestCase { public function fixtures() { return [ 'customers' => CustomerFixture::className(), ]; } } class CustomDirectoryDbTestCase extends BaseDbTestCase { public function fixtures() { return [ 'customers' => CustomDirectoryFixture::className(), ]; } } class DataPathDbTestCase extends BaseDbTestCase { public function fixtures() { return [ 'customers' => [ 'class' => CustomDirectoryFixture::className(), 'dataFile' => '@app/framework/test/data/customer.php' ] ]; } } class TruncateTestCase extends BaseDbTestCase { public function fixtures() { return [ 'animals' => [ 'class' => AnimalFixture::className(), ] ]; } } /** * @group fixture * @group db */ class ActiveFixtureTest extends DatabaseTestCase { protected $driverName = 'mysql'; public function setUp() { parent::setUp(); $db = $this->getConnection(); \Yii::$app->set('db', $db); ActiveRecord::$db = $db; } public function tearDown() { parent::tearDown(); } public function testGetData() { $test = new CustomerDbTestCase(); $test->setUp(); $fixture = $test->getFixture('customers'); $this->assertEquals(CustomerFixture::className(), get_class($fixture)); $this->assertCount(2, $fixture); $this->assertEquals(1, $fixture['customer1']['id']); $this->assertEquals('customer1@example.com', $fixture['customer1']['email']); $this->assertEquals(1, $fixture['customer1']['profile_id']); $this->assertEquals(2, $fixture['customer2']['id']); $this->assertEquals('customer2@example.com', $fixture['customer2']['email']); $this->assertEquals(2, $fixture['customer2']['profile_id']); $test->tearDown(); } public function testGetModel() { $test = new CustomerDbTestCase(); $test->setUp(); $fixture = $test->getFixture('customers'); $this->assertEquals(Customer::className(), get_class($fixture->getModel('customer1'))); $this->assertEquals(1, $fixture->getModel('customer1')->id); $this->assertEquals('customer1@example.com', $fixture->getModel('customer1')->email); $this->assertEquals(1, $fixture['customer1']['profile_id']); $this->assertEquals(2, $fixture->getModel('customer2')->id); $this->assertEquals('customer2@example.com', $fixture->getModel('customer2')->email); $this->assertEquals(2, $fixture['customer2']['profile_id']); $test->tearDown(); } public function testDataDirectory() { $test = new CustomDirectoryDbTestCase(); $test->setUp(); $fixture = $test->getFixture('customers'); $directory = $fixture->getModel('directory'); $this->assertEquals(1, $directory->id); $this->assertEquals('directory@example.com', $directory['email']); $test->tearDown(); } public function testDataPath() { $test = new DataPathDbTestCase(); $test->setUp(); $fixture = $test->getFixture('customers'); $customer = $fixture->getModel('customer1'); $this->assertEquals(1, $customer->id); $this->assertEquals('customer1@example.com', $customer['email']); $test->tearDown(); } public function testTruncate() { $test = new TruncateTestCase(); $test->setUp(); $fixture = $test->getFixture('animals'); $this->assertEmpty($fixture->data); $test->tearDown(); } }