mirror of
https://github.com/yiisoft/yii2.git
synced 2025-08-18 17:21:26 +08:00

- Moved everything test-related into `tests` directory. Codeception tests are in `codeception`. - Removed database module since we're using fixtures and migrations. - Moved console entry points and bootstrap into `tests/codeception/bin`. - Adjusted travis build scripts. - Adjusted documentation to be consistent and reflect changes made.
61 lines
1.6 KiB
PHP
61 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace codeception\common\_helpers;
|
|
|
|
use codeception\common\fixtures\UserFixture;
|
|
use Codeception\Module;
|
|
use yii\test\FixtureTrait;
|
|
|
|
/**
|
|
* This helper is used to populate database with needed fixtures before any tests should be run.
|
|
* For example - populate database with demo login user that should be used in acceptance and functional tests.
|
|
* All fixtures will be loaded before suite will be starded and unloaded after it.
|
|
*/
|
|
class FixtureHelper extends Module
|
|
{
|
|
|
|
/**
|
|
* Redeclare visibility because codeception includes all public methods that not starts from "_"
|
|
* and not excluded by module settings, in guy class.
|
|
*/
|
|
use FixtureTrait {
|
|
loadFixtures as protected;
|
|
fixtures as protected;
|
|
globalFixtures as protected;
|
|
unloadFixtures as protected;
|
|
getFixtures as protected;
|
|
getFixture as protected;
|
|
}
|
|
|
|
/**
|
|
* Method called before any suite tests run. Loads User fixture login user
|
|
* to use in acceptance and functional tests.
|
|
* @param array $settings
|
|
*/
|
|
public function _beforeSuite($settings = [])
|
|
{
|
|
$this->loadFixtures();
|
|
}
|
|
|
|
/**
|
|
* Method is called after all suite tests run
|
|
*/
|
|
public function _afterSuite()
|
|
{
|
|
$this->unloadFixtures();
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function fixtures()
|
|
{
|
|
return [
|
|
'user' => [
|
|
'class' => UserFixture::className(),
|
|
'dataFile' => '@codeception/common/fixtures/data/init_login.php',
|
|
],
|
|
];
|
|
}
|
|
}
|