koel/tests/Feature/InteractionTest.php
2019-07-22 09:03:23 +02:00

110 lines
2.7 KiB
PHP

<?php
namespace Tests\Feature;
use App\Events\SongLikeToggled;
use App\Models\Song;
use App\Models\User;
use Exception;
class InteractionTest extends TestCase
{
/**
* @throws Exception
*/
public function setUp(): void
{
parent::setUp();
$this->createSampleMediaSet();
}
/** @test */
public function play_count_is_increased(): void
{
$this->withoutEvents();
$user = factory(User::class)->create();
$song = Song::orderBy('id')->first();
$this->postAsUser('api/interaction/play', ['song' => $song->id], $user);
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'play_count' => 1,
]);
// Try again
$this->postAsUser('api/interaction/play', ['song' => $song->id], $user);
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'play_count' => 2,
]);
}
/**
* @test
*
* @throws Exception
*/
public function user_can_like_and_unlike_a_song(): void
{
$this->expectsEvents(SongLikeToggled::class);
$user = factory(User::class)->create();
$song = Song::orderBy('id')->first();
$this->postAsUser('api/interaction/like', ['song' => $song->id], $user);
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'liked' => 1,
]);
// Try again
$this->postAsUser('api/interaction/like', ['song' => $song->id], $user);
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'liked' => 0,
]);
}
/**
* @test
*
* @throws Exception
*/
public function user_can_like_and_unlike_songs_in_batch(): void
{
$this->expectsEvents(SongLikeToggled::class);
$user = factory(User::class)->create();
$songs = Song::orderBy('id')->take(2)->get();
$songIds = array_pluck($songs->toArray(), 'id');
$this->postAsUser('api/interaction/batch/like', ['songs' => $songIds], $user);
foreach ($songs as $song) {
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'liked' => 1,
]);
}
$this->postAsUser('api/interaction/batch/unlike', ['songs' => $songIds], $user);
foreach ($songs as $song) {
$this->seeInDatabase('interactions', [
'user_id' => $user->id,
'song_id' => $song->id,
'liked' => 0,
]);
}
}
}