157 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Tests\Unit\Http\Middleware\Server;
 | 
						|
 | 
						|
use Mockery as m;
 | 
						|
use Pterodactyl\Models\Server;
 | 
						|
use Pterodactyl\Models\Subuser;
 | 
						|
use Pterodactyl\Exceptions\DisplayException;
 | 
						|
use Pterodactyl\Exceptions\PterodactylException;
 | 
						|
use Tests\Unit\Http\Middleware\MiddlewareTestCase;
 | 
						|
use Pterodactyl\Contracts\Extensions\HashidsInterface;
 | 
						|
use Pterodactyl\Http\Middleware\Server\SubuserBelongsToServer;
 | 
						|
use Pterodactyl\Contracts\Repository\SubuserRepositoryInterface;
 | 
						|
 | 
						|
class SubuserBelongsToServerTest extends MiddlewareTestCase
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Contracts\Extensions\HashidsInterface|\Mockery\Mock
 | 
						|
     */
 | 
						|
    private $hashids;
 | 
						|
 | 
						|
    /**
 | 
						|
     * @var \Pterodactyl\Contracts\Repository\SubuserRepositoryInterface|\Mockery\Mock
 | 
						|
     */
 | 
						|
    private $repository;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Setup tests.
 | 
						|
     */
 | 
						|
    public function setUp()
 | 
						|
    {
 | 
						|
        parent::setUp();
 | 
						|
 | 
						|
        $this->hashids = m::mock(HashidsInterface::class);
 | 
						|
        $this->repository = m::mock(SubuserRepositoryInterface::class);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test a successful middleware instance.
 | 
						|
     */
 | 
						|
    public function testSuccessfulMiddleware()
 | 
						|
    {
 | 
						|
        $model = factory(Server::class)->make();
 | 
						|
        $subuser = factory(Subuser::class)->make([
 | 
						|
            'server_id' => $model->id,
 | 
						|
        ]);
 | 
						|
        $this->setRequestAttribute('server', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('route->parameter')->with('subuser', 0)->once()->andReturn('abc123');
 | 
						|
        $this->hashids->shouldReceive('decodeFirst')->with('abc123', 0)->once()->andReturn($subuser->id);
 | 
						|
        $this->repository->shouldReceive('find')->with($subuser->id)->once()->andReturn($subuser);
 | 
						|
 | 
						|
        $this->request->shouldReceive('method')->withNoArgs()->once()->andReturn('GET');
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
        $this->assertRequestHasAttribute('subuser');
 | 
						|
        $this->assertRequestAttributeEquals($subuser, 'subuser');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that a user can edit a user other than themselves.
 | 
						|
     */
 | 
						|
    public function testSuccessfulMiddlewareWhenPatchRequest()
 | 
						|
    {
 | 
						|
        $this->setRequestUser();
 | 
						|
        $model = factory(Server::class)->make();
 | 
						|
        $subuser = factory(Subuser::class)->make([
 | 
						|
            'server_id' => $model->id,
 | 
						|
        ]);
 | 
						|
        $this->setRequestAttribute('server', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('route->parameter')->with('subuser', 0)->once()->andReturn('abc123');
 | 
						|
        $this->hashids->shouldReceive('decodeFirst')->with('abc123', 0)->once()->andReturn($subuser->id);
 | 
						|
        $this->repository->shouldReceive('find')->with($subuser->id)->once()->andReturn($subuser);
 | 
						|
 | 
						|
        $this->request->shouldReceive('method')->withNoArgs()->once()->andReturn('PATCH');
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
        $this->assertRequestHasAttribute('subuser');
 | 
						|
        $this->assertRequestAttributeEquals($subuser, 'subuser');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that an exception is thrown if a user attempts to edit themself.
 | 
						|
     */
 | 
						|
    public function testExceptionIsThrownIfUserTriesToEditSelf()
 | 
						|
    {
 | 
						|
        $user = $this->setRequestUser();
 | 
						|
        $model = factory(Server::class)->make();
 | 
						|
        $subuser = factory(Subuser::class)->make([
 | 
						|
            'server_id' => $model->id,
 | 
						|
            'user_id' => $user->id,
 | 
						|
        ]);
 | 
						|
        $this->setRequestAttribute('server', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('route->parameter')->with('subuser', 0)->once()->andReturn('abc123');
 | 
						|
        $this->hashids->shouldReceive('decodeFirst')->with('abc123', 0)->once()->andReturn($subuser->id);
 | 
						|
        $this->repository->shouldReceive('find')->with($subuser->id)->once()->andReturn($subuser);
 | 
						|
 | 
						|
        $this->request->shouldReceive('method')->withNoArgs()->once()->andReturn('PATCH');
 | 
						|
 | 
						|
        try {
 | 
						|
            $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
        } catch (PterodactylException $exception) {
 | 
						|
            $this->assertInstanceOf(DisplayException::class, $exception);
 | 
						|
            $this->assertEquals(trans('exceptions.subusers.editing_self'), $exception->getMessage());
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that an exception is thrown if a subuser server does not match the
 | 
						|
     * request server.
 | 
						|
     *
 | 
						|
     * @expectedException \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
 | 
						|
     */
 | 
						|
    public function testExceptionIsThrownIfSubuserServerDoesNotMatchRequestServer()
 | 
						|
    {
 | 
						|
        $model = factory(Server::class)->make();
 | 
						|
        $subuser = factory(Subuser::class)->make();
 | 
						|
        $this->setRequestAttribute('server', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('route->parameter')->with('subuser', 0)->once()->andReturn('abc123');
 | 
						|
        $this->hashids->shouldReceive('decodeFirst')->with('abc123', 0)->once()->andReturn($subuser->id);
 | 
						|
        $this->repository->shouldReceive('find')->with($subuser->id)->once()->andReturn($subuser);
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that an exception is thrown if no subuser is found.
 | 
						|
     *
 | 
						|
     * @expectedException \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
 | 
						|
     */
 | 
						|
    public function testExceptionIsThrownIfNoSubuserIsFound()
 | 
						|
    {
 | 
						|
        $model = factory(Server::class)->make();
 | 
						|
        $subuser = factory(Subuser::class)->make();
 | 
						|
        $this->setRequestAttribute('server', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('route->parameter')->with('subuser', 0)->once()->andReturn('abc123');
 | 
						|
        $this->hashids->shouldReceive('decodeFirst')->with('abc123', 0)->once()->andReturn($subuser->id);
 | 
						|
        $this->repository->shouldReceive('find')->with($subuser->id)->once()->andReturnNull();
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Return an instance of the middleware using mocked dependencies.
 | 
						|
     *
 | 
						|
     * @return \Pterodactyl\Http\Middleware\Server\SubuserBelongsToServer
 | 
						|
     */
 | 
						|
    private function getMiddleware(): SubuserBelongsToServer
 | 
						|
    {
 | 
						|
        return new SubuserBelongsToServer($this->hashids, $this->repository);
 | 
						|
    }
 | 
						|
}
 |