mirror of
https://github.com/archtechx/virtualcolumn.git
synced 2025-12-12 15:54:03 +00:00
214 lines
5.6 KiB
PHP
214 lines
5.6 KiB
PHP
<?php
|
|
|
|
namespace Stancl\VirtualColumn\Tests;
|
|
|
|
use Exception;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Orchestra\Testbench\TestCase;
|
|
use Stancl\VirtualColumn\VirtualColumn;
|
|
|
|
class VirtualColumnTest extends TestCase
|
|
{
|
|
public function setUp(): void
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->loadMigrationsFrom(__DIR__ . '/etc/migrations');
|
|
}
|
|
|
|
/** @test */
|
|
public function keys_which_dont_have_their_own_column_go_into_data_json_column()
|
|
{
|
|
$model = MyModel::create([
|
|
'foo' => 'bar',
|
|
]);
|
|
|
|
// Test that model works correctly
|
|
$this->assertSame('bar', $model->foo);
|
|
$this->assertSame(null, $model->data);
|
|
|
|
// Low level test to assert database structure
|
|
$this->assertSame(['foo' => 'bar'], json_decode(DB::table('my_models')->where('id', $model->id)->first()->data, true));
|
|
$this->assertSame(null, DB::table('my_models')->where('id', $model->id)->first()->foo ?? null);
|
|
|
|
// Model has the correct structure when retrieved
|
|
$model = MyModel::first();
|
|
$this->assertSame('bar', $model->foo);
|
|
$this->assertSame('bar', $model->getOriginal('foo'));
|
|
$this->assertSame(null, $model->data);
|
|
|
|
// Model can be updated
|
|
$model->update([
|
|
'foo' => 'baz',
|
|
'abc' => 'xyz',
|
|
]);
|
|
|
|
$this->assertSame('baz', $model->foo);
|
|
$this->assertSame('baz', $model->getOriginal('foo'));
|
|
$this->assertSame('xyz', $model->abc);
|
|
$this->assertSame('xyz', $model->getOriginal('abc'));
|
|
$this->assertSame(null, $model->data);
|
|
|
|
// Model can be retrieved after update & is structure correctly
|
|
$model = MyModel::first();
|
|
|
|
$this->assertSame('baz', $model->foo);
|
|
$this->assertSame('xyz', $model->abc);
|
|
$this->assertSame(null, $model->data);
|
|
}
|
|
|
|
/** @test */
|
|
public function model_is_always_decoded_when_accessed_by_user_event()
|
|
{
|
|
MyModel::retrieved(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::saving(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::updating(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::creating(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::saved(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::updated(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
MyModel::created(function (MyModel $model) {
|
|
$this->assertSame('decoded', $model->dataEncodingStatus);
|
|
});
|
|
|
|
|
|
$model = MyModel::create(['foo' => 'bar']);
|
|
$model->update(['foo' => 'baz']);
|
|
MyModel::first();
|
|
}
|
|
|
|
/** @test */
|
|
public function column_names_are_generated_correctly()
|
|
{
|
|
// FooModel's virtual data column name is 'virtual'
|
|
$virtualColumnName = 'virtual->foo';
|
|
$customColumnName = 'custom1';
|
|
|
|
/** @var FooModel $model */
|
|
$model = FooModel::create([
|
|
'custom1' => $customColumnName,
|
|
'foo' => $virtualColumnName
|
|
]);
|
|
|
|
$this->assertSame($customColumnName, $model->getColumnForQuery('custom1'));
|
|
$this->assertSame($virtualColumnName, $model->getColumnForQuery('foo'));
|
|
}
|
|
|
|
/** @test */
|
|
public function multiple_classes_cannot_extend_a_parent_that_uses_virtualcolumn()
|
|
{
|
|
|
|
// Create a model that extends a parent using VirtualColumn
|
|
FirstChildModel::create(['custom1' => 'foo model', 'foo' => 'foo']);
|
|
|
|
// Expect creating a model that extends the same parent using VirtualColumn
|
|
// Not to work correctly
|
|
$this->expectException(Exception::class);
|
|
|
|
// Try creating a model that extends the same parent
|
|
SecondChildModel::create(['custom1' => 'bar', 'bar' => 'custom property']);
|
|
}
|
|
|
|
|
|
|
|
// maybe add an explicit test that the saving() and updating() listeners don't run twice?
|
|
}
|
|
|
|
class MyModel extends Model
|
|
{
|
|
use VirtualColumn;
|
|
|
|
protected $guarded = [];
|
|
public $timestamps = false;
|
|
|
|
public static function getCustomColumns(): array
|
|
{
|
|
return [
|
|
'id',
|
|
'custom1',
|
|
'custom2',
|
|
];
|
|
}
|
|
}
|
|
|
|
class FooModel extends Model
|
|
{
|
|
use VirtualColumn;
|
|
|
|
protected $guarded = [];
|
|
public $timestamps = false;
|
|
|
|
public static function getCustomColumns(): array
|
|
{
|
|
return [
|
|
'id',
|
|
'custom1',
|
|
'custom2',
|
|
];
|
|
}
|
|
|
|
public static function getDataColumn(): string
|
|
{
|
|
return 'virtual';
|
|
}
|
|
}
|
|
|
|
class ParentModel extends Model
|
|
{
|
|
use VirtualColumn;
|
|
|
|
public $table = 'foo_models';
|
|
|
|
protected $guarded = [];
|
|
public $timestamps = false;
|
|
|
|
public static function getCustomColumns(): array
|
|
{
|
|
return [
|
|
'id',
|
|
'custom1',
|
|
'custom2',
|
|
];
|
|
}
|
|
|
|
public static function getDataColumn(): string
|
|
{
|
|
return 'virtual';
|
|
}
|
|
}
|
|
|
|
|
|
class FirstChildModel extends ParentModel
|
|
{
|
|
}
|
|
class SecondChildModel extends ParentModel
|
|
{
|
|
public $table = 'bar_models';
|
|
protected $guarded = [];
|
|
public $timestamps = false;
|
|
|
|
public static function getCustomColumns(): array
|
|
{
|
|
return [
|
|
'id',
|
|
'custom1',
|
|
];
|
|
}
|
|
|
|
public static function getDataColumn(): string
|
|
{
|
|
return 'data';
|
|
}
|
|
}
|