koel/tests/Feature/UserTest.php

86 lines
2.4 KiB
PHP
Raw Normal View History

2015-12-13 04:42:28 +00:00
<?php
2017-02-14 06:53:02 +00:00
namespace Tests\Feature;
2015-12-13 04:42:28 +00:00
use App\Models\User;
use Illuminate\Support\Facades\Hash;
2015-12-13 04:42:28 +00:00
2017-08-05 16:56:11 +00:00
class UserTest extends TestCase
2015-12-13 04:42:28 +00:00
{
2019-07-22 07:03:23 +00:00
public function setUp(): void
2018-08-22 19:40:04 +00:00
{
parent::setUp();
}
2019-07-22 07:03:23 +00:00
public function testNonAdminCannotCreateUser(): void
2015-12-13 04:42:28 +00:00
{
2016-09-26 06:30:00 +00:00
$this->postAsUser('api/user', [
2018-08-22 19:40:04 +00:00
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'secret',
2020-09-06 21:20:42 +00:00
'is_admin' => false,
])->assertForbidden();
2018-08-22 19:40:04 +00:00
}
2019-07-22 07:03:23 +00:00
public function testAdminCreatesUser(): void
2018-08-22 19:40:04 +00:00
{
2016-09-26 06:30:00 +00:00
$this->postAsUser('api/user', [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'secret',
2020-09-06 21:20:42 +00:00
'is_admin' => true,
], User::factory()->admin()->create())
2022-07-07 10:45:57 +00:00
->assertSuccessful();
2015-12-13 04:42:28 +00:00
/** @var User $user */
$user = User::firstWhere('email', 'bar@baz.com');
self::assertTrue(Hash::check('secret', $user->password));
self::assertSame('Foo', $user->name);
self::assertSame('bar@baz.com', $user->email);
self::assertTrue($user->is_admin);
2015-12-13 04:42:28 +00:00
}
2019-07-22 07:03:23 +00:00
public function testAdminUpdatesUser(): void
2015-12-13 04:42:28 +00:00
{
2018-08-22 19:40:04 +00:00
/** @var User $user */
$user = User::factory()->admin()->create(['password' => 'secret']);
2018-08-22 19:40:04 +00:00
$this->putAsUser("api/user/$user->id", [
'name' => 'Foo',
'email' => 'bar@baz.com',
'password' => 'new-secret',
2020-06-13 15:19:47 +00:00
'is_admin' => false,
], User::factory()->admin()->create());
2015-12-13 04:42:28 +00:00
$user->refresh();
self::assertTrue(Hash::check('new-secret', $user->password));
self::assertSame('Foo', $user->name);
self::assertSame('bar@baz.com', $user->email);
self::assertFalse($user->is_admin);
2015-12-13 04:42:28 +00:00
}
2019-07-22 07:03:23 +00:00
public function testAdminDeletesUser(): void
2015-12-13 04:42:28 +00:00
{
2020-09-06 18:21:39 +00:00
/** @var User $user */
$user = User::factory()->create();
$admin = User::factory()->admin()->create();
2015-12-15 10:32:41 +00:00
$this->deleteAsUser("api/user/$user->id", [], $admin);
2020-09-06 18:21:39 +00:00
self::assertDatabaseMissing('users', ['id' => $user->id]);
2018-08-22 19:40:04 +00:00
}
2019-07-22 07:03:23 +00:00
public function testSeppukuNotAllowed(): void
2018-08-22 19:40:04 +00:00
{
2020-09-06 18:21:39 +00:00
/** @var User $admin */
$admin = User::factory()->admin()->create();
2015-12-13 04:42:28 +00:00
2015-12-15 10:32:41 +00:00
// A user can't delete himself
$this->deleteAsUser("api/user/$admin->id", [], $admin)
2020-09-06 18:21:39 +00:00
->assertStatus(403);
self::assertDatabaseHas('users', ['id' => $admin->id]);
2015-12-13 04:42:28 +00:00
}
}