2017-10-24 03:10:32 +01:00
|
|
|
<?php
|
|
|
|
|
2021-01-23 20:09:16 +00:00
|
|
|
namespace Pterodactyl\Tests\Traits;
|
2017-10-24 03:10:32 +01:00
|
|
|
|
|
|
|
use Mockery;
|
|
|
|
use Mockery\MockInterface;
|
|
|
|
use GuzzleHttp\Exception\RequestException;
|
|
|
|
|
|
|
|
trait MocksRequestException
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var \GuzzleHttp\Exception\RequestException|\Mockery\Mock
|
|
|
|
*/
|
|
|
|
private $exception;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var mixed
|
|
|
|
*/
|
|
|
|
private $exceptionResponse;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Configure the exception mock to work with the Panel's default exception
|
|
|
|
* handler actions.
|
2018-01-11 05:19:03 +00:00
|
|
|
*
|
2021-01-23 20:33:34 +00:00
|
|
|
* @param null $response
|
2017-10-24 03:10:32 +01:00
|
|
|
*/
|
2018-01-11 05:19:03 +00:00
|
|
|
protected function configureExceptionMock(string $abstract = RequestException::class, $response = null)
|
2017-10-24 03:10:32 +01:00
|
|
|
{
|
2018-01-11 05:19:03 +00:00
|
|
|
$this->getExceptionMock($abstract)->shouldReceive('getResponse')->andReturn(value($response));
|
2017-10-24 03:10:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a mocked instance of the request exception.
|
|
|
|
*/
|
2018-01-11 05:19:03 +00:00
|
|
|
protected function getExceptionMock(string $abstract = RequestException::class): MockInterface
|
2017-10-24 03:10:32 +01:00
|
|
|
{
|
2018-01-11 05:19:03 +00:00
|
|
|
return $this->exception ?? $this->exception = Mockery::mock($abstract);
|
2017-10-24 03:10:32 +01:00
|
|
|
}
|
|
|
|
}
|