koel/tests/Feature/UserTest.php
2017-08-05 19:55:02 +01:00

71 lines
2 KiB
PHP

<?php
namespace Tests\Feature;
use App\Models\User;
class UserTest extends TestCase
{
/** @test */
public function admin_can_create_a_user()
{
// Non-admins can't do shit
$this->postAsUser('api/user', [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'qux',
])
->seeStatusCode(403);
// But admins can
$this->postAsUser('api/user', [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'qux',
], factory(User::class, 'admin')->create());
$this->seeInDatabase('users', ['name' => 'Foo']);
}
/** @test */
public function admin_can_update_a_user()
{
$user = factory(User::class)->create();
$this->putAsUser("api/user/{$user->id}", [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'qux',
], factory(User::class, 'admin')->create());
$this->seeInDatabase('users', ['name' => 'Foo', 'email' => 'bar@baz.com']);
}
/** @test */
public function admin_can_delete_a_user()
{
$user = factory(User::class)->create();
$admin = factory(User::class, 'admin')->create();
$this->deleteAsUser("api/user/{$user->id}", [], $admin)
->notSeeInDatabase('users', ['id' => $user->id]);
// A user can't delete himself
$this->deleteAsUser("api/user/{$admin->id}", [], $admin)
->seeStatusCode(403)
->seeInDatabase('users', ['id' => $admin->id]);
}
/** @test */
public function user_can_update_their_preferences()
{
$user = factory(User::class)->create();
$this->assertNull($user->getPreference('foo'));
$user->setPreference('foo', 'bar');
$this->assertEquals('bar', $user->getPreference('foo'));
$user->deletePreference('foo');
$this->assertNull($user->getPreference('foo'));
}
}