Skip to content

Commit

Permalink
Test that child models extending a parent that uses VirtualColumn get…
Browse files Browse the repository at this point in the history
… encoded correctly (#16)

* Test that using different models extending the same class with VirtualColumn doesn't work correctly

* Add regression test for faulty logic

* Delete unused import

* Add migration

* Fix migrations

* Make the assertions check the intended behavior
  • Loading branch information
lukinovec authored Nov 6, 2023
1 parent 0b10890 commit 925249b
Show file tree
Hide file tree
Showing 3 changed files with 116 additions and 0 deletions.
54 changes: 54 additions & 0 deletions tests/VirtualColumnTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,26 @@ public function column_names_are_generated_correctly()
$this->assertSame($virtualColumnName, $model->getColumnForQuery('foo'));
}

/** @test */
public function models_extending_a_parent_model_using_virtualcolumn_get_encoded_correctly()
{
// Create a model that extends a parent model using VirtualColumn
// 'foo' is a custom column, 'data' is the virtual column
FooChild::create(['foo' => 'foo']);
$encodedFoo = DB::select('select * from foo_childs limit 1')[0];
// Assert that the model was encoded correctly
$this->assertNull($encodedFoo->data);
$this->assertSame($encodedFoo->foo, 'foo');

// Create another child model of the same parent
// 'bar' is a custom column, 'data' is the virtual column
BarChild::create(['bar' => 'bar']);
$encodedBar = DB::select('select * from bar_childs limit 1')[0];

$this->assertNull($encodedBar->data);
$this->assertSame($encodedBar->bar, 'bar');
}

// maybe add an explicit test that the saving() and updating() listeners don't run twice?
}

Expand Down Expand Up @@ -146,3 +166,37 @@ public static function getDataColumn(): string
return 'virtual';
}
}

class ParentModel extends Model
{
use VirtualColumn;

public $timestamps = false;
protected $guarded = [];
}


class FooChild extends ParentModel
{
public $table = 'foo_childs';

public static function getCustomColumns(): array
{
return [
'id',
'foo',
];
}
}
class BarChild extends ParentModel
{
public $table = 'bar_childs';

public static function getCustomColumns(): array
{
return [
'id',
'bar',
];
}
}
31 changes: 31 additions & 0 deletions tests/etc/migrations/2023_05_11_000001_create_bar_childs_table.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

declare(strict_types=1);

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateBarChildsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('bar_childs', function (Blueprint $table) {
$table->increments('id');

$table->string('bar')->nullable();

$table->json('data')->nullable();
});
}

public function down()
{
Schema::dropIfExists('bar_childs');
}
}
31 changes: 31 additions & 0 deletions tests/etc/migrations/2023_10_21_000001_create_foo_childs_table.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?php

declare(strict_types=1);

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateFooChildsTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('foo_childs', function (Blueprint $table) {
$table->increments('id');

$table->string('foo')->nullable();

$table->json('data')->nullable();
});
}

public function down()
{
Schema::dropIfExists('foo_childs');
}
}

0 comments on commit 925249b

Please sign in to comment.