Berkarar/tests/unit/plugins/database/MorphManyModelTest.php

172 lines
6.9 KiB
PHP

<?php
use Database\Tester\Models\Author;
use Database\Tester\Models\Tag;
use Database\Tester\Models\Post;
use Database\Tester\Models\EventLog;
use October\Rain\Database\Collection;
class MorphManyModelTest extends PluginTestCase
{
public function setUp() : void
{
parent::setUp();
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Author.php';
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Post.php';
include_once base_path().'/tests/fixtures/plugins/database/tester/models/EventLog.php';
include_once base_path().'/tests/fixtures/plugins/database/tester/models/Tag.php';
$this->runPluginRefreshCommand('Database.Tester');
}
public function testSetRelationValue()
{
Model::unguard();
$author = Author::create(['name' => 'Stevie', 'email' => 'stevie@email.tld']);
$event1 = EventLog::create(['action' => "user-created"]);
$event2 = EventLog::create(['action' => "user-updated"]);
$event3 = EventLog::create(['action' => "user-deleted"]);
$event4 = EventLog::make(['action' => "user-restored"]);
Model::reguard();
// Set by Model object
$author->event_log = new Collection([$event1, $event2]);
$author->save();
$this->assertEquals($author->id, $event1->related_id);
$this->assertEquals($author->id, $event2->related_id);
$this->assertEquals('Database\Tester\Models\Author', $event1->related_type);
$this->assertEquals('Database\Tester\Models\Author', $event2->related_type);
$this->assertEquals([
'user-created',
'user-updated'
], $author->event_log->lists('action'));
// Set by primary key
$eventId = $event3->id;
$author->event_log = $eventId;
$author->save();
$event3 = EventLog::find($eventId);
$this->assertEquals($author->id, $event3->related_id);
$this->assertEquals('Database\Tester\Models\Author', $event3->related_type);
$this->assertEquals([
'user-deleted'
], $author->event_log->lists('action'));
// Nullify
$author->event_log = null;
$author->save();
$event3 = EventLog::find($eventId);
$this->assertNull($event3->related_type);
$this->assertNull($event3->related_id);
$this->assertNull($event3->related);
// Deferred in memory
$author->event_log = $event4;
$this->assertEquals($author->id, $event4->related_id);
$this->assertEquals('Database\Tester\Models\Author', $event4->related_type);
$this->assertEquals([
'user-restored'
], $author->event_log->lists('action'));
}
public function testGetRelationValue()
{
Model::unguard();
$author = Author::create(['name' => 'Stevie']);
$event1 = EventLog::create(['action' => "user-created", 'related_id' => $author->id, 'related_type' => 'Database\Tester\Models\Author']);
$event2 = EventLog::create(['action' => "user-updated", 'related_id' => $author->id, 'related_type' => 'Database\Tester\Models\Author']);
Model::reguard();
$this->assertEquals([$event1->id, $event2->id], $author->getRelationValue('event_log'));
}
public function testDeferredBinding()
{
$sessionKey = uniqid('session_key', true);
Model::unguard();
$author = Author::create(['name' => 'Stevie']);
$event = EventLog::create(['action' => "user-created"]);
$post = Post::create(['title' => 'Hello world!']);
$tagForAuthor = Tag::create(['name' => 'ForAuthor']);
$tagForPost = Tag::create(['name' => 'ForPost']);
Model::reguard();
$eventId = $event->id;
// Deferred add
$author->event_log()->add($event, $sessionKey);
$this->assertNull($event->related_id);
$this->assertEmpty($author->event_log);
$this->assertEquals(0, $author->event_log()->count());
$this->assertEquals(1, $author->event_log()->withDeferred($sessionKey)->count());
$author->tags()->add($tagForAuthor, $sessionKey, ['added_by' => 99]);
$this->assertEmpty($author->tags);
$this->assertEquals(0, $author->tags()->count());
$this->assertEquals(1, $author->tags()->withDeferred($sessionKey)->count());
$tagForPost->posts()->add($post, $sessionKey, ['added_by' => 88]);
$this->assertEmpty($tagForPost->posts);
$this->assertEquals(0, $tagForPost->posts()->count());
$this->assertEquals(1, $tagForPost->posts()->withDeferred($sessionKey)->count());
// Commit deferred
$author->save(null, $sessionKey);
$event = EventLog::find($eventId);
$this->assertEquals(1, $author->event_log()->count());
$this->assertEquals($author->id, $event->related_id);
$this->assertEquals([
'user-created'
], $author->event_log->lists('action'));
$this->assertEquals(1, $author->tags()->count());
$this->assertEquals([$tagForAuthor->id], $author->tags->lists('id'));
$this->assertEquals(99, $author->tags->first()->pivot->added_by);
$tagForPost->save(null, $sessionKey);
$this->assertEquals(1, $tagForPost->posts()->count());
$this->assertEquals([$post->id], $tagForPost->posts->lists('id'));
$this->assertEquals(88, $tagForPost->posts->first()->pivot->added_by);
// New session
$sessionKey = uniqid('session_key', true);
// Deferred remove
$author->event_log()->remove($event, $sessionKey);
$this->assertEquals(1, $author->event_log()->count());
$this->assertEquals(0, $author->event_log()->withDeferred($sessionKey)->count());
$this->assertEquals($author->id, $event->related_id);
$this->assertEquals([
'user-created'
], $author->event_log->lists('action'));
$author->tags()->remove($tagForAuthor, $sessionKey);
$this->assertEquals(1, $author->tags()->count());
$this->assertEquals(0, $author->tags()->withDeferred($sessionKey)->count());
$this->assertEquals([$tagForAuthor->id], $author->tags->lists('id'));
$this->assertEquals(99, $author->tags->first()->pivot->added_by);
$tagForPost->posts()->remove($post, $sessionKey);
$this->assertEquals(1, $tagForPost->posts()->count());
$this->assertEquals(0, $tagForPost->posts()->withDeferred($sessionKey)->count());
$this->assertEquals([$post->id], $tagForPost->posts->lists('id'));
$this->assertEquals(88, $tagForPost->posts->first()->pivot->added_by);
// Commit deferred (model is deleted as per definition)
$author->save(null, $sessionKey);
$event = EventLog::find($eventId);
$this->assertEquals(0, $author->event_log()->count());
$this->assertNull($event);
$this->assertEmpty($author->event_log);
$this->assertEmpty(0, $author->tags);
$this->assertEmpty(0, $tagForPost->posts);
}
}