mirror of
https://github.com/anthonyaxenov/atol-online.git
synced 2025-01-11 02:45:54 +00:00
AnthonyAxenov
92a2c6cc48
Используется тестовый API АТОЛ Онлайн. 94% покрытие AtolClient, но ещё не закончено
260 lines
8.5 KiB
PHP
260 lines
8.5 KiB
PHP
<?php
|
||
|
||
namespace AtolOnlineTests;
|
||
|
||
use AtolOnline\Api\AtolClient;
|
||
use AtolOnline\Api\KktMonitor;
|
||
use AtolOnline\Api\KktResponse;
|
||
use AtolOnline\Exceptions\AuthFailedException;
|
||
use AtolOnline\Exceptions\EmptyLoginException;
|
||
use AtolOnline\Exceptions\EmptyPasswordException;
|
||
use AtolOnline\Exceptions\TooLongLoginException;
|
||
use AtolOnline\Exceptions\TooLongPasswordException;
|
||
use AtolOnline\Helpers;
|
||
use AtolOnline\TestEnvParams;
|
||
use GuzzleHttp\Exception\GuzzleException;
|
||
|
||
/**
|
||
* Набор тестов для проверки работы API-клиента на примере монитора ККТ
|
||
*/
|
||
class KktMonitorTest extends BasicTestCase
|
||
{
|
||
/**
|
||
* Тестирует успешное создание объекта монитора без аргументов конструктора
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
*/
|
||
public function testConstructorWithoutArgs()
|
||
{
|
||
$client = new KktMonitor();
|
||
$this->assertIsObject($client);
|
||
$this->assertIsSameClass(KktMonitor::class, $client);
|
||
$this->assertExtendsClasses([AtolClient::class], $client);
|
||
}
|
||
|
||
/**
|
||
* Тестирует успешное создание объекта монитора с аргументами конструктора
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::setLogin
|
||
* @covers \AtolOnline\Api\KktMonitor::getLogin
|
||
* @covers \AtolOnline\Api\KktMonitor::setPassword
|
||
* @covers \AtolOnline\Api\KktMonitor::getPassword
|
||
*/
|
||
public function testConstructorWithArgs()
|
||
{
|
||
$client = new KktMonitor(false, 'login', 'password', []);
|
||
$this->assertIsObject($client);
|
||
$this->assertIsSameClass(KktMonitor::class, $client);
|
||
$this->assertExtendsClasses([AtolClient::class], $client);
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку и возврат логина
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::getLogin
|
||
* @covers \AtolOnline\Api\KktMonitor::setLogin
|
||
*/
|
||
public function testLogin()
|
||
{
|
||
$client = new KktMonitor(login: 'login');
|
||
$this->assertEquals('login', $client->getLogin());
|
||
|
||
$client = new KktMonitor();
|
||
$this->assertNull($client->getLogin());
|
||
|
||
$client->setLogin('login');
|
||
$this->assertEquals('login', $client->getLogin());
|
||
}
|
||
|
||
/**
|
||
* Тестирует исключение при попытке передать пустой логин в конструктор
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::setLogin
|
||
* @covers \AtolOnline\Exceptions\EmptyLoginException
|
||
*/
|
||
public function testEmptyLoginException()
|
||
{
|
||
$this->expectException(EmptyLoginException::class);
|
||
new KktMonitor(login: '');
|
||
}
|
||
|
||
/**
|
||
* Тестирует исключение при попытке передать слишком длинный логин в конструктор
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::setLogin
|
||
* @covers \AtolOnline\Exceptions\TooLongLoginException
|
||
*/
|
||
public function testTooLongLoginException()
|
||
{
|
||
$this->expectException(TooLongLoginException::class);
|
||
new KktMonitor(login: Helpers::randomStr(101));
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку и возврат пароля
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::getPassword
|
||
* @covers \AtolOnline\Api\KktMonitor::setPassword
|
||
*/
|
||
public function testPassword()
|
||
{
|
||
$client = new KktMonitor(password: 'password');
|
||
$this->assertEquals('password', $client->getPassword());
|
||
|
||
$client = new KktMonitor();
|
||
$this->assertNull($client->getPassword());
|
||
|
||
$client->setPassword('password');
|
||
$this->assertEquals('password', $client->getPassword());
|
||
}
|
||
|
||
/**
|
||
* Тестирует исключение при попытке передать пустой пароль в конструктор
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::setPassword
|
||
* @covers \AtolOnline\Exceptions\EmptyPasswordException
|
||
*/
|
||
public function testEmptyPasswordException()
|
||
{
|
||
$this->expectException(EmptyPasswordException::class);
|
||
new KktMonitor(password: '');
|
||
}
|
||
|
||
/**
|
||
* Тестирует исключение при попытке передать слишком длинный пароль в конструктор
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::setPassword
|
||
*/
|
||
public function testConstructorWithLongPassword()
|
||
{
|
||
$this->expectException(TooLongPasswordException::class);
|
||
new KktMonitor(password: Helpers::randomStr(101));
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку тестового режима
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::__construct
|
||
* @covers \AtolOnline\Api\KktMonitor::isTestMode
|
||
* @covers \AtolOnline\Api\KktMonitor::setTestMode
|
||
*/
|
||
public function testTestMode()
|
||
{
|
||
$client = new KktMonitor();
|
||
$this->assertTrue($client->isTestMode());
|
||
|
||
$client = new KktMonitor(true);
|
||
$this->assertTrue($client->isTestMode());
|
||
|
||
$client = new KktMonitor(false);
|
||
$this->assertFalse($client->isTestMode());
|
||
|
||
$client = (new KktMonitor())->setTestMode();
|
||
$this->assertTrue($client->isTestMode());
|
||
|
||
$client = (new KktMonitor())->setTestMode(true);
|
||
$this->assertTrue($client->isTestMode());
|
||
|
||
$client = (new KktMonitor())->setTestMode(false);
|
||
$this->assertFalse($client->isTestMode());
|
||
}
|
||
|
||
/**
|
||
* Возвращает объект клиента для тестирования с тестовым API АТОЛ
|
||
*
|
||
* @return AtolClient
|
||
* @throws EmptyLoginException
|
||
* @throws EmptyPasswordException
|
||
* @throws TooLongLoginException
|
||
* @throws TooLongPasswordException
|
||
*/
|
||
private function newTestClient(): AtolClient
|
||
{
|
||
$credentials = TestEnvParams::FFD105();
|
||
return (new KktMonitor(true))
|
||
->setLogin($credentials['login'])
|
||
->setPassword($credentials['password']);
|
||
}
|
||
|
||
/**
|
||
* Тестирует авторизацию
|
||
*
|
||
* @covers \AtolOnline\Api\AtolClient::getHeaders
|
||
* @covers \AtolOnline\Api\KktMonitor::sendRequest
|
||
* @covers \AtolOnline\Api\KktMonitor::getAuthEndpoint
|
||
* @covers \AtolOnline\Api\KktMonitor::doAuth
|
||
* @covers \AtolOnline\Api\KktMonitor::auth
|
||
* @throws EmptyLoginException
|
||
* @throws EmptyPasswordException
|
||
* @throws TooLongLoginException
|
||
* @throws TooLongPasswordException
|
||
* @throws AuthFailedException
|
||
* @throws GuzzleException
|
||
*/
|
||
public function testAuth()
|
||
{
|
||
$this->skipIfMonitoringIsOffline();
|
||
$result = $this->newTestClient()->auth();
|
||
$this->assertTrue($result);
|
||
}
|
||
|
||
/**
|
||
* Тестирует возврат токена после авторизации
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::setToken
|
||
* @covers \AtolOnline\Api\KktMonitor::getToken
|
||
* @throws AuthFailedException
|
||
* @throws EmptyLoginException
|
||
* @throws EmptyPasswordException
|
||
* @throws GuzzleException
|
||
* @throws TooLongLoginException
|
||
* @throws TooLongPasswordException
|
||
*/
|
||
public function testGetToken()
|
||
{
|
||
$client = new KktMonitor();
|
||
$this->assertNull($client->getToken());
|
||
|
||
$this->skipIfMonitoringIsOffline();
|
||
$client = $this->newTestClient();
|
||
$client->auth();
|
||
$this->assertIsString($client->getToken());
|
||
}
|
||
|
||
/**
|
||
* Тестирует возврат объекта последнего ответа от API
|
||
*
|
||
* @covers \AtolOnline\Api\KktMonitor::getResponse
|
||
* @throws AuthFailedException
|
||
* @throws EmptyLoginException
|
||
* @throws EmptyPasswordException
|
||
* @throws GuzzleException
|
||
* @throws TooLongLoginException
|
||
* @throws TooLongPasswordException
|
||
*/
|
||
public function testGetResponse()
|
||
{
|
||
$this->skipIfMonitoringIsOffline();
|
||
$client = $this->newTestClient();
|
||
$client->auth();
|
||
$this->assertIsSameClass(KktResponse::class, $client->getResponse());
|
||
}
|
||
|
||
|
||
public function todo_testGetAll()
|
||
{
|
||
}
|
||
|
||
public function todo_testGetOne()
|
||
{
|
||
}
|
||
|
||
}
|