2016-03-20 02:25:26 +03:00
|
|
|
|
<?php
|
|
|
|
|
namespace tests\codeception\api\models;
|
|
|
|
|
|
|
|
|
|
use api\models\ChangeUsernameForm;
|
|
|
|
|
use Codeception\Specify;
|
|
|
|
|
use common\models\Account;
|
2016-04-23 21:44:10 +03:00
|
|
|
|
use common\models\UsernameHistory;
|
2016-03-20 02:25:26 +03:00
|
|
|
|
use tests\codeception\api\unit\DbTestCase;
|
|
|
|
|
use tests\codeception\common\fixtures\AccountFixture;
|
|
|
|
|
use Yii;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @property array $accounts
|
|
|
|
|
*/
|
|
|
|
|
class ChangeUsernameFormTest extends DbTestCase {
|
|
|
|
|
use Specify;
|
|
|
|
|
|
|
|
|
|
public function fixtures() {
|
|
|
|
|
return [
|
|
|
|
|
'accounts' => [
|
|
|
|
|
'class' => AccountFixture::class,
|
|
|
|
|
'dataFile' => '@tests/codeception/common/fixtures/data/accounts.php',
|
|
|
|
|
],
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function testChange() {
|
|
|
|
|
$this->specify('successfully change username to new one', function() {
|
|
|
|
|
$model = new DummyChangeUsernameForm([
|
|
|
|
|
'password' => 'password_0',
|
|
|
|
|
'username' => 'my_new_nickname',
|
|
|
|
|
]);
|
|
|
|
|
expect($model->change())->true();
|
|
|
|
|
expect(Account::findOne(1)->username)->equals('my_new_nickname');
|
2016-04-23 21:44:10 +03:00
|
|
|
|
expect(UsernameHistory::findOne(['username' => 'my_new_nickname']))->isInstanceOf(UsernameHistory::class);
|
2016-03-20 02:25:26 +03:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2016-05-02 16:13:18 +03:00
|
|
|
|
public function testUsernameUnavailable() {
|
|
|
|
|
$this->specify('error.username_not_available expected if username is already taken', function() {
|
|
|
|
|
$model = new DummyChangeUsernameForm([
|
|
|
|
|
'password' => 'password_0',
|
|
|
|
|
'username' => 'Jon',
|
|
|
|
|
]);
|
|
|
|
|
$model->validate();
|
|
|
|
|
expect($model->getErrors('username'))->equals(['error.username_not_available']);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
$this->specify('error.username_not_available is NOT expected if username is already taken by CURRENT user', function() {
|
|
|
|
|
$model = new DummyChangeUsernameForm([
|
|
|
|
|
'password' => 'password_0',
|
|
|
|
|
'username' => 'Admin',
|
|
|
|
|
]);
|
|
|
|
|
$model->validate();
|
|
|
|
|
expect($model->getErrors('username'))->equals([]);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2016-04-23 21:44:10 +03:00
|
|
|
|
public function testCreateTask() {
|
|
|
|
|
$model = new DummyChangeUsernameForm();
|
|
|
|
|
$model->createTask('1', 'test1', 'test');
|
|
|
|
|
// TODO: у меня пока нет идей о том, чтобы это как-то успешно протестировать, увы
|
|
|
|
|
// но по крайней мере можно убедиться, что оно не падает где-то на этом шаге
|
|
|
|
|
}
|
|
|
|
|
|
2016-03-20 02:25:26 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO: тут образуется магическая переменная 1, что не круто. После перехода на php7 можно заюзать анонимный класс
|
|
|
|
|
// и создавать модель прямо внутри теста, где доступен объект фикстур с именами переменных
|
|
|
|
|
|
|
|
|
|
class DummyChangeUsernameForm extends ChangeUsernameForm {
|
|
|
|
|
|
|
|
|
|
protected function getAccount() {
|
|
|
|
|
return Account::findOne(1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|