6409fffdad
closes #722
146 lines
5.8 KiB
PHP
146 lines
5.8 KiB
PHP
<?php
|
|
/**
|
|
* Pterodactyl - Panel
|
|
* Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com>.
|
|
*
|
|
* This software is licensed under the terms of the MIT license.
|
|
* https://opensource.org/licenses/MIT
|
|
*/
|
|
|
|
namespace Tests\Unit\Services\Subusers;
|
|
|
|
use Mockery as m;
|
|
use Tests\TestCase;
|
|
use Pterodactyl\Models\User;
|
|
use Pterodactyl\Models\Server;
|
|
use Pterodactyl\Models\Subuser;
|
|
use Tests\Traits\MocksRequestException;
|
|
use GuzzleHttp\Exception\RequestException;
|
|
use Illuminate\Database\ConnectionInterface;
|
|
use Pterodactyl\Exceptions\PterodactylException;
|
|
use Pterodactyl\Services\Subusers\SubuserUpdateService;
|
|
use Pterodactyl\Services\Subusers\PermissionCreationService;
|
|
use Pterodactyl\Services\DaemonKeys\DaemonKeyProviderService;
|
|
use Pterodactyl\Contracts\Repository\SubuserRepositoryInterface;
|
|
use Pterodactyl\Contracts\Repository\PermissionRepositoryInterface;
|
|
use Pterodactyl\Exceptions\Http\Connection\DaemonConnectionException;
|
|
use Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface as DaemonServerRepositoryInterface;
|
|
|
|
class SubuserUpdateServiceTest extends TestCase
|
|
{
|
|
use MocksRequestException;
|
|
|
|
/**
|
|
* @var \Illuminate\Database\ConnectionInterface|\Mockery\Mock
|
|
*/
|
|
private $connection;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Contracts\Repository\Daemon\ServerRepositoryInterface|\Mockery\Mock
|
|
*/
|
|
private $daemonRepository;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Services\DaemonKeys\DaemonKeyProviderService|\Mockery\Mock
|
|
*/
|
|
private $keyProviderService;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Contracts\Repository\PermissionRepositoryInterface|\Mockery\Mock
|
|
*/
|
|
private $permissionRepository;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Services\Subusers\PermissionCreationService|\Mockery\Mock
|
|
*/
|
|
private $permissionService;
|
|
|
|
/**
|
|
* @var \Pterodactyl\Contracts\Repository\SubuserRepositoryInterface|\Mockery\Mock
|
|
*/
|
|
private $repository;
|
|
|
|
/**
|
|
* Setup tests.
|
|
*/
|
|
public function setUp()
|
|
{
|
|
parent::setUp();
|
|
|
|
$this->connection = m::mock(ConnectionInterface::class);
|
|
$this->daemonRepository = m::mock(DaemonServerRepositoryInterface::class);
|
|
$this->keyProviderService = m::mock(DaemonKeyProviderService::class);
|
|
$this->permissionRepository = m::mock(PermissionRepositoryInterface::class);
|
|
$this->permissionService = m::mock(PermissionCreationService::class);
|
|
$this->repository = m::mock(SubuserRepositoryInterface::class);
|
|
}
|
|
|
|
/**
|
|
* Test that permissions are updated in the database.
|
|
*/
|
|
public function testPermissionsAreUpdated()
|
|
{
|
|
$subuser = factory(Subuser::class)->make();
|
|
$subuser->setRelation('server', factory(Server::class)->make());
|
|
$subuser->setRelation('user', factory(User::class)->make());
|
|
|
|
$this->repository->shouldReceive('loadServerAndUserRelations')->with($subuser)->once()->andReturn($subuser);
|
|
$this->connection->shouldReceive('beginTransaction')->withNoArgs()->once()->andReturnNull();
|
|
$this->permissionRepository->shouldReceive('deleteWhere')->with([['subuser_id', '=', $subuser->id]])->once()->andReturnNull();
|
|
$this->permissionService->shouldReceive('handle')->with($subuser->id, ['some-permission'])->once()->andReturnNull();
|
|
|
|
$this->keyProviderService->shouldReceive('handle')->with($subuser->server, $subuser->user, false)->once()->andReturn('test123');
|
|
$this->daemonRepository->shouldReceive('setNode')->with($subuser->server->node_id)->once()->andReturnSelf();
|
|
$this->daemonRepository->shouldReceive('revokeAccessKey')->with('test123')->once()->andReturnNull();
|
|
|
|
$this->connection->shouldReceive('commit')->withNoArgs()->once()->andReturnNull();
|
|
|
|
$this->getService()->handle($subuser, ['some-permission']);
|
|
$this->assertTrue(true);
|
|
}
|
|
|
|
/**
|
|
* Test that an exception is thrown if the daemon connection fails.
|
|
*/
|
|
public function testExceptionIsThrownIfDaemonConnectionFails()
|
|
{
|
|
$this->configureExceptionMock();
|
|
|
|
$subuser = factory(Subuser::class)->make();
|
|
$subuser->setRelation('server', factory(Server::class)->make());
|
|
$subuser->setRelation('user', factory(User::class)->make());
|
|
|
|
$this->repository->shouldReceive('loadServerAndUserRelations')->with($subuser)->once()->andReturn($subuser);
|
|
$this->connection->shouldReceive('beginTransaction')->withNoArgs()->once()->andReturnNull();
|
|
$this->permissionRepository->shouldReceive('deleteWhere')->with([['subuser_id', '=', $subuser->id]])->once()->andReturnNull();
|
|
$this->permissionService->shouldReceive('handle')->with($subuser->id, [])->once()->andReturnNull();
|
|
|
|
$this->keyProviderService->shouldReceive('handle')->with($subuser->server, $subuser->user, false)->once()->andReturn('test123');
|
|
$this->daemonRepository->shouldReceive('setNode')->with($subuser->server->node_id)->once()->andThrow($this->getExceptionMock());
|
|
$this->connection->shouldReceive('rollBack')->withNoArgs()->once()->andReturnNull();
|
|
|
|
try {
|
|
$this->getService()->handle($subuser, []);
|
|
} catch (PterodactylException $exception) {
|
|
$this->assertInstanceOf(DaemonConnectionException::class, $exception);
|
|
$this->assertInstanceOf(RequestException::class, $exception->getPrevious());
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return an instance of the service with mocked dependencies for testing.
|
|
*
|
|
* @return \Pterodactyl\Services\Subusers\SubuserUpdateService
|
|
*/
|
|
private function getService(): SubuserUpdateService
|
|
{
|
|
return new SubuserUpdateService(
|
|
$this->connection,
|
|
$this->keyProviderService,
|
|
$this->daemonRepository,
|
|
$this->permissionService,
|
|
$this->permissionRepository,
|
|
$this->repository
|
|
);
|
|
}
|
|
}
|