Files
yii2/tests/framework/behaviors/AttributeBehaviorTest.php
2025-04-26 19:03:07 -04:00

163 lines
3.8 KiB
PHP

<?php
/**
* @link https://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license https://www.yiiframework.com/license/
*/
namespace yiiunit\framework\behaviors;
use Yii;
use yii\behaviors\AttributeBehavior;
use yii\db\ActiveRecord;
use yii\db\Connection;
use yiiunit\TestCase;
/**
* Unit test for [[\yii\behaviors\AttributeBehavior]].
* @see AttributeBehavior
*
* @group behaviors
*/
class AttributeBehaviorTest extends TestCase
{
/**
* @var Connection test db connection
*/
protected $dbConnection;
public static function setUpBeforeClass(): void
{
if (!extension_loaded('pdo') || !extension_loaded('pdo_sqlite')) {
static::markTestSkipped('PDO and SQLite extensions are required.');
}
}
protected function setUp(): void
{
$this->mockApplication([
'components' => [
'db' => [
'class' => '\yii\db\Connection',
'dsn' => 'sqlite::memory:',
],
],
]);
$columns = [
'id' => 'pk',
'name' => 'string',
'alias' => 'string',
];
Yii::$app->getDb()->createCommand()->createTable('test_attribute', $columns)->execute();
}
protected function tearDown(): void
{
Yii::$app->getDb()->close();
parent::tearDown();
}
// Tests :
/**
* @return array
*/
public static function preserveNonEmptyValuesDataProvider(): array
{
return [
[
'John Doe',
false,
'John Doe',
null,
],
[
'John Doe',
false,
'John Doe',
'Johnny',
],
[
'John Doe',
true,
'John Doe',
null,
],
[
'Johnny',
true,
'John Doe',
'Johnny',
],
];
}
/**
* @dataProvider preserveNonEmptyValuesDataProvider
*
* @param string $aliasExpected The expected value of the alias attribute.
* @param bool $preserveNonEmptyValues Whether to preserve non-empty values.
* @param string $name The value of the name attribute.
* @param string|null $alias The value of the alias attribute.
*/
public function testPreserveNonEmptyValues(
string $aliasExpected,
bool $preserveNonEmptyValues,
string $name,
string $alias = null
): void {
$model = new ActiveRecordWithAttributeBehavior();
$model->attributeBehavior->preserveNonEmptyValues = $preserveNonEmptyValues;
$model->name = $name;
$model->alias = $alias;
$model->validate();
$this->assertEquals($aliasExpected, $model->alias);
}
}
/**
* Test Active Record class with [[AttributeBehavior]] behavior attached.
*
* @property int $id
* @property string $name
* @property string $alias
*
* @property AttributeBehavior $attributeBehavior
*/
class ActiveRecordWithAttributeBehavior extends ActiveRecord
{
/**
* {@inheritdoc}
*/
public function behaviors()
{
return [
'attribute' => [
'class' => AttributeBehavior::class,
'attributes' => [
self::EVENT_BEFORE_VALIDATE => 'alias',
],
'value' => fn($event) => $event->sender->name,
],
];
}
/**
* {@inheritdoc}
*/
public static function tableName()
{
return 'test_attribute';
}
/**
* @return AttributeBehavior
*/
public function getAttributeBehavior()
{
return $this->getBehavior('attribute');
}
}