2024-03-30 16:49:25 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Integration\KoelPlus\Services;
|
|
|
|
|
|
|
|
use App\Models\User;
|
|
|
|
use App\Services\UserService;
|
2024-03-31 17:19:03 +00:00
|
|
|
use App\Values\SSOUser;
|
2024-03-30 16:49:25 +00:00
|
|
|
use Illuminate\Support\Facades\Hash;
|
|
|
|
use Laravel\Socialite\Two\User as SocialiteUser;
|
|
|
|
use Mockery;
|
|
|
|
use Tests\PlusTestCase;
|
|
|
|
|
|
|
|
use function Tests\create_user;
|
|
|
|
|
|
|
|
class UserServiceTest extends PlusTestCase
|
|
|
|
{
|
|
|
|
private UserService $service;
|
|
|
|
|
|
|
|
public function setUp(): void
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->service = app(UserService::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCreateUserViaSSOProvider(): void
|
|
|
|
{
|
|
|
|
$user = $this->service->createUser(
|
|
|
|
name: 'Bruce Dickinson',
|
|
|
|
email: 'bruce@dickison.com',
|
|
|
|
plainTextPassword: '',
|
|
|
|
isAdmin: false,
|
|
|
|
avatar: 'https://lh3.googleusercontent.com/a/vatar',
|
|
|
|
ssoId: '123',
|
|
|
|
ssoProvider: 'Google'
|
|
|
|
);
|
|
|
|
|
|
|
|
self::assertModelExists($user);
|
|
|
|
self::assertSame('Google', $user->sso_provider);
|
|
|
|
self::assertSame('123', $user->sso_id);
|
|
|
|
self::assertSame('https://lh3.googleusercontent.com/a/vatar', $user->avatar);
|
|
|
|
}
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
public function testCreateUserFromSSO(): void
|
2024-03-30 16:49:25 +00:00
|
|
|
{
|
|
|
|
self::assertDatabaseMissing(User::class, ['email' => 'bruce@iron.com']);
|
|
|
|
|
|
|
|
$socialiteUser = Mockery::mock(SocialiteUser::class, [
|
|
|
|
'getId' => '123',
|
|
|
|
'getEmail' => 'bruce@iron.com',
|
|
|
|
'getName' => 'Bruce Dickinson',
|
|
|
|
'getAvatar' => 'https://lh3.googleusercontent.com/a/vatar',
|
|
|
|
]);
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
$user = $this->service->createOrUpdateUserFromSSO(SSOUser::fromSocialite($socialiteUser, 'Google'));
|
2024-03-30 16:49:25 +00:00
|
|
|
|
|
|
|
self::assertModelExists($user);
|
|
|
|
|
|
|
|
self::assertSame('Google', $user->sso_provider);
|
|
|
|
self::assertSame('Bruce Dickinson', $user->name);
|
|
|
|
self::assertSame('bruce@iron.com', $user->email);
|
|
|
|
self::assertSame('123', $user->sso_id);
|
|
|
|
self::assertSame('https://lh3.googleusercontent.com/a/vatar', $user->avatar);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUpdateUserFromSSOId(): void
|
|
|
|
{
|
|
|
|
$user = create_user([
|
|
|
|
'email' => 'bruce@iron.com',
|
2024-03-31 17:19:03 +00:00
|
|
|
'name' => 'Bruce Dickinson',
|
2024-03-30 16:49:25 +00:00
|
|
|
'sso_id' => '123',
|
|
|
|
'sso_provider' => 'Google',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$socialiteUser = Mockery::mock(SocialiteUser::class, [
|
|
|
|
'getId' => '123',
|
|
|
|
'getEmail' => 'steve@iron.com',
|
|
|
|
'getName' => 'Steve Harris',
|
|
|
|
'getAvatar' => 'https://lh3.googleusercontent.com/a/vatar',
|
|
|
|
]);
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
$this->service->createOrUpdateUserFromSSO(SSOUser::fromSocialite($socialiteUser, 'Google'));
|
2024-03-30 16:49:25 +00:00
|
|
|
$user->refresh();
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
self::assertSame('Bruce Dickinson', $user->name); // Name should not be updated
|
2024-03-30 16:49:25 +00:00
|
|
|
self::assertSame('https://lh3.googleusercontent.com/a/vatar', $user->avatar);
|
2024-03-31 17:19:03 +00:00
|
|
|
self::assertSame('bruce@iron.com', $user->email); // Email should not be updated
|
2024-03-30 16:49:25 +00:00
|
|
|
self::assertSame('Google', $user->sso_provider);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUpdateUserFromSSOEmail(): void
|
|
|
|
{
|
2024-03-31 17:19:03 +00:00
|
|
|
$user = create_user([
|
|
|
|
'email' => 'bruce@iron.com',
|
|
|
|
'name' => 'Bruce Dickinson',
|
|
|
|
]);
|
2024-03-30 16:49:25 +00:00
|
|
|
|
|
|
|
$socialiteUser = Mockery::mock(SocialiteUser::class, [
|
|
|
|
'getId' => '123',
|
|
|
|
'getEmail' => 'bruce@iron.com',
|
2024-03-31 17:19:03 +00:00
|
|
|
'getName' => 'Steve Harris',
|
2024-03-30 16:49:25 +00:00
|
|
|
'getAvatar' => 'https://lh3.googleusercontent.com/a/vatar',
|
2024-03-31 17:19:03 +00:00
|
|
|
|
2024-03-30 16:49:25 +00:00
|
|
|
]);
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
$this->service->createOrUpdateUserFromSSO(SSOUser::fromSocialite($socialiteUser, 'Google'));
|
2024-03-30 16:49:25 +00:00
|
|
|
$user->refresh();
|
|
|
|
|
2024-03-31 17:19:03 +00:00
|
|
|
self::assertSame('Bruce Dickinson', $user->name); // Name should not be updated
|
2024-03-30 16:49:25 +00:00
|
|
|
self::assertSame('https://lh3.googleusercontent.com/a/vatar', $user->avatar);
|
|
|
|
self::assertSame('Google', $user->sso_provider);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUpdateSSOUserCannotChangeProfileDetails(): void
|
|
|
|
{
|
|
|
|
$user = create_user([
|
|
|
|
'email' => 'bruce@iron.com',
|
|
|
|
'name' => 'Bruce Dickinson',
|
|
|
|
'sso_provider' => 'Google',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$this->service->updateUser(
|
|
|
|
user: $user,
|
|
|
|
name: 'Steve Harris',
|
|
|
|
email: 'steve@iron.com',
|
|
|
|
password: 'TheTrooper',
|
|
|
|
isAdmin: true,
|
|
|
|
);
|
|
|
|
|
|
|
|
$user->refresh();
|
|
|
|
|
|
|
|
self::assertSame('bruce@iron.com', $user->email);
|
|
|
|
self::assertFalse(Hash::check('TheTrooper', $user->password));
|
|
|
|
self::assertTrue($user->is_admin);
|
|
|
|
}
|
|
|
|
}
|