parent
39fc16ddfc
commit
518dee7730
|
|
@ -39,6 +39,9 @@ class Author extends Model
|
|||
'event_log' => ['Database\Tester\Models\EventLog', 'name' => 'related', 'delete' => true, 'softDelete' => true],
|
||||
];
|
||||
|
||||
public $morphOne = [
|
||||
'meta' => ['Database\Tester\Models\Meta', 'name' => 'taggable'],
|
||||
];
|
||||
}
|
||||
|
||||
class SoftDeleteAuthor extends Author
|
||||
|
|
|
|||
|
|
@ -0,0 +1,24 @@
|
|||
<?php namespace Database\Tester\Models;
|
||||
|
||||
use Model;
|
||||
|
||||
class Meta extends Model
|
||||
{
|
||||
public $table = 'database_tester_meta';
|
||||
|
||||
public $timestamps = false;
|
||||
|
||||
public $morphTo = [
|
||||
'taggable' => []
|
||||
];
|
||||
|
||||
public $fillable = [
|
||||
'meta_title',
|
||||
'meta_description',
|
||||
'meta_keywords',
|
||||
'canonical_url',
|
||||
'redirect_url',
|
||||
'robot_index',
|
||||
'robot_follow'
|
||||
];
|
||||
}
|
||||
|
|
@ -31,6 +31,9 @@ class Post extends Model
|
|||
'event_log' => ['Database\Tester\Models\EventLog', 'name' => 'related', 'delete' => true, 'softDelete' => true],
|
||||
];
|
||||
|
||||
public $morphOne = [
|
||||
'meta' => ['Database\Tester\Models\Meta', 'name' => 'taggable'],
|
||||
];
|
||||
}
|
||||
|
||||
class NullablePost extends Post
|
||||
|
|
|
|||
|
|
@ -0,0 +1,32 @@
|
|||
<?php namespace Database\Tester\Updates;
|
||||
|
||||
use Schema;
|
||||
use October\Rain\Database\Updates\Migration;
|
||||
|
||||
class CreateMetaTable extends Migration
|
||||
{
|
||||
|
||||
public function up()
|
||||
{
|
||||
Schema::create('database_tester_meta', function($table)
|
||||
{
|
||||
$table->engine = 'InnoDB';
|
||||
$table->increments('id')->unsigned();
|
||||
$table->integer('taggable_id')->unsigned()->index()->nullable();
|
||||
$table->string('taggable_type')->nullable();
|
||||
$table->string('meta_title')->nullable();
|
||||
$table->string('meta_description')->nullable();
|
||||
$table->string('meta_keywords')->nullable();
|
||||
$table->string('canonical_url')->nullable();
|
||||
$table->string('redirect_url')->nullable();
|
||||
$table->string('robot_index')->nullable();
|
||||
$table->string('robot_follow')->nullable();
|
||||
});
|
||||
}
|
||||
|
||||
public function down()
|
||||
{
|
||||
Schema::dropIfExists('database_tester_meta');
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -8,3 +8,4 @@
|
|||
- create_roles_table.php
|
||||
- create_users_table.php
|
||||
- create_event_log_table.php
|
||||
- create_meta_table.php
|
||||
|
|
|
|||
|
|
@ -104,4 +104,4 @@ class HasOneModelTest extends PluginTestCase
|
|||
$this->assertNull($phone->author_id);
|
||||
$this->assertNull($author->phone);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -0,0 +1,156 @@
|
|||
<?php
|
||||
|
||||
use Database\Tester\Models\Author;
|
||||
use Database\Tester\Models\Post;
|
||||
use Database\Tester\Models\Meta;
|
||||
|
||||
class MorphOneModelTest extends PluginTestCase
|
||||
{
|
||||
public function setUp()
|
||||
{
|
||||
parent::setUp();
|
||||
|
||||
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Author.php';
|
||||
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Phone.php';
|
||||
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Post.php';
|
||||
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Meta.php';
|
||||
|
||||
$this->runPluginRefreshCommand('Database.Tester');
|
||||
}
|
||||
|
||||
public function testSetRelationValue()
|
||||
{
|
||||
Model::unguard();
|
||||
$post = Post::create(['title' => "First post", 'description' => "Yay!!"]);
|
||||
$author = Author::create(['name' => 'Stevie', 'email' => 'stevie@email.tld']);
|
||||
$meta1 = Meta::create([
|
||||
'meta_title' => 'Question',
|
||||
'meta_description' => 'Industry',
|
||||
'meta_keywords' => 'major',
|
||||
'canonical_url' => 'http://google.com/search/jobs',
|
||||
'redirect_url' => 'http://google.com',
|
||||
'robot_index' => 'index',
|
||||
'robot_follow' => 'follow',
|
||||
]);
|
||||
$meta2 = Meta::create([
|
||||
'meta_title' => 'Comment',
|
||||
'meta_description' => 'Social',
|
||||
'meta_keywords' => 'startup',
|
||||
'canonical_url' => 'http://facebook.com/search/users',
|
||||
'redirect_url' => 'http://facebook.com',
|
||||
'robot_index' => 'index',
|
||||
'robot_follow' => 'follow',
|
||||
]);
|
||||
$meta3 = Meta::make([
|
||||
'meta_title' => 'Answer',
|
||||
'meta_description' => 'Employment',
|
||||
'meta_keywords' => 'minor',
|
||||
'canonical_url' => 'http://yahoo.com/search/stats',
|
||||
'redirect_url' => 'http://yahoo.com',
|
||||
'robot_index' => 'index',
|
||||
'robot_follow' => 'follow',
|
||||
]);
|
||||
Model::reguard();
|
||||
|
||||
// Set by Model object
|
||||
$post->meta = $meta1;
|
||||
$post->save();
|
||||
$this->assertEquals($post->id, $meta1->taggable_id);
|
||||
$this->assertEquals(get_class($post), $meta1->taggable_type);
|
||||
$this->assertEquals('Question', $post->meta->meta_title);
|
||||
|
||||
// Set by primary key
|
||||
$metaId = $meta2->id;
|
||||
$author->meta = $metaId;
|
||||
$author->save();
|
||||
$meta2 = Meta::find($metaId);
|
||||
$this->assertEquals($author->id, $meta2->taggable_id);
|
||||
$this->assertEquals(get_class($author), $meta2->taggable_type);
|
||||
$this->assertEquals('Comment', $author->meta->meta_title);
|
||||
|
||||
// Nullify
|
||||
$author->meta = null;
|
||||
$author->save();
|
||||
$meta = Meta::find($metaId);
|
||||
$this->assertNull($meta->taggable_type);
|
||||
$this->assertNull($meta->taggable_id);
|
||||
$this->assertNull($meta->taggable);
|
||||
|
||||
// Deferred in memory
|
||||
$author->meta = $meta3;
|
||||
$this->assertEquals('Answer', $author->meta->meta_title);
|
||||
$this->assertEquals($author->id, $meta3->taggable_id);
|
||||
}
|
||||
|
||||
public function testGetRelationValue()
|
||||
{
|
||||
Model::unguard();
|
||||
$author = Author::create(['name' => 'Stevie']);
|
||||
$meta = Meta::create([
|
||||
'taggable_id' => $author->id,
|
||||
'taggable_type' => get_class($author),
|
||||
'meta_title' => 'Question',
|
||||
'meta_description' => 'Industry',
|
||||
'meta_keywords' => 'major',
|
||||
'canonical_url' => 'http://google.com/search/jobs',
|
||||
'redirect_url' => 'http://google.com',
|
||||
'robot_index' => 'index',
|
||||
'robot_follow' => 'follow',
|
||||
]);
|
||||
Model::reguard();
|
||||
|
||||
$this->assertEquals($meta->id, $author->getRelationValue('meta'));
|
||||
}
|
||||
|
||||
public function testDeferredBinding()
|
||||
{
|
||||
$sessionKey = uniqid('session_key', true);
|
||||
|
||||
Model::unguard();
|
||||
$author = Author::create(['name' => 'Stevie']);
|
||||
$meta = Meta::create([
|
||||
'meta_title' => 'Comment',
|
||||
'meta_description' => 'Social',
|
||||
'meta_keywords' => 'startup',
|
||||
'canonical_url' => 'http://facebook.com/search/users',
|
||||
'redirect_url' => 'http://facebook.com',
|
||||
'robot_index' => 'index',
|
||||
'robot_follow' => 'follow',
|
||||
]);
|
||||
Model::reguard();
|
||||
|
||||
$metaId = $meta->id;
|
||||
|
||||
// Deferred add
|
||||
$author->meta()->add($meta, $sessionKey);
|
||||
$this->assertNull($meta->taggable_id);
|
||||
$this->assertNull($author->meta);
|
||||
|
||||
$this->assertEquals(0, $author->meta()->count());
|
||||
$this->assertEquals(1, $author->meta()->withDeferred($sessionKey)->count());
|
||||
|
||||
// Commit deferred
|
||||
$author->save(null, $sessionKey);
|
||||
$meta = Meta::find($metaId);
|
||||
$this->assertEquals(1, $author->meta()->count());
|
||||
$this->assertEquals($author->id, $meta->taggable_id);
|
||||
$this->assertEquals('Comment', $author->meta->meta_title);
|
||||
|
||||
// New session
|
||||
$sessionKey = uniqid('session_key', true);
|
||||
|
||||
// Deferred remove
|
||||
$author->meta()->remove($meta, $sessionKey);
|
||||
$this->assertEquals(1, $author->meta()->count());
|
||||
$this->assertEquals(0, $author->meta()->withDeferred($sessionKey)->count());
|
||||
$this->assertEquals($author->id, $meta->taggable_id);
|
||||
$this->assertEquals('Comment', $author->meta->meta_title);
|
||||
|
||||
// Commit deferred
|
||||
$author->save(null, $sessionKey);
|
||||
$meta = Meta::find($metaId);
|
||||
$this->assertEquals(0, $author->meta()->count());
|
||||
$this->assertNull($meta->taggable_id);
|
||||
$this->assertNull($author->meta);
|
||||
}
|
||||
}
|
||||
Loading…
Reference in New Issue