1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121
|
<?php
namespace Illuminate\Tests\Integration\Database\EloquentThroughTest;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
use Illuminate\Tests\Integration\Database\DatabaseTestCase;
class EloquentThroughTest extends DatabaseTestCase
{
protected function afterRefreshingDatabase()
{
Schema::create('posts', function (Blueprint $table) {
$table->increments('id');
$table->boolean('public');
});
Schema::create('other_commentables', function (Blueprint $table) {
$table->increments('id');
});
Schema::create('comments', function (Blueprint $table) {
$table->increments('id');
$table->string('commentable_type');
$table->integer('commentable_id');
});
Schema::create('likes', function (Blueprint $table) {
$table->increments('id');
$table->unsignedInteger('comment_id');
});
$post = tap(new Post(['public' => true]))->save();
$comment = tap((new Comment)->commentable()->associate($post))->save();
(new Like())->comment()->associate($comment)->save();
(new Like())->comment()->associate($comment)->save();
$otherCommentable = tap(new OtherCommentable())->save();
$comment2 = tap((new Comment)->commentable()->associate($otherCommentable))->save();
(new Like())->comment()->associate($comment2)->save();
}
public function test()
{
/** @var Post $post */
$post = Post::first();
$this->assertEquals(2, $post->commentLikes()->count());
}
}
class Comment extends Model
{
public $timestamps = false;
public function commentable()
{
return $this->morphTo();
}
public function likes()
{
return $this->hasMany(Like::class);
}
}
class Post extends Model
{
public $timestamps = false;
protected $guarded = [];
protected $withCount = ['comments'];
public function comments()
{
return $this->morphMany(Comment::class, 'commentable');
}
public function commentLikes()
{
return $this->through($this->comments())->has('likes');
}
public function texts()
{
return $this->hasMany(Text::class);
}
}
class OtherCommentable extends Model
{
public $timestamps = false;
public function comments()
{
return $this->morphMany(Comment::class, 'commentable');
}
}
class Text extends Model
{
public $timestamps = false;
protected $guarded = [];
public function post()
{
return $this->belongsTo(Post::class);
}
}
class Like extends Model
{
public $timestamps = false;
public function comment()
{
return $this->belongsTo(Comment::class);
}
}
|