mirror of
https://github.com/anthonyaxenov/atol-online.git
synced 2024-11-16 10:51:34 +00:00
AnthonyAxenov
4157ab68f5
* enum-ы теперь enum-ы, а не говно -- теперь всё переведено на них, где это было возможно * некоторые свойства классов объявлены в конструкторе * некоторые классы перемещены в корневой неймспейс * исправлен код-стайл, вычищен некоторый мусор, выправлены тесты... работы над этим продолжаются
152 lines
5.0 KiB
PHP
152 lines
5.0 KiB
PHP
<?php
|
||
|
||
/*
|
||
* Copyright (c) 2020-2021 Антон Аксенов (Anthony Axenov)
|
||
*
|
||
* This code is licensed under MIT.
|
||
* Этот код распространяется по лицензии MIT.
|
||
* https://github.com/anthonyaxenov/atol-online/blob/master/LICENSE
|
||
*/
|
||
|
||
namespace AtolOnline\Tests\Entities;
|
||
|
||
use AtolOnline\{
|
||
Entities\PayingAgent,
|
||
Exceptions\InvalidPhoneException,
|
||
Exceptions\TooLongPayingAgentOperationException,
|
||
Helpers,
|
||
Tests\BasicTestCase};
|
||
use Exception;
|
||
|
||
/**
|
||
* Набор тестов для проверки работы класса платёжного агента
|
||
*/
|
||
class PayingAgentTest extends BasicTestCase
|
||
{
|
||
/**
|
||
* Тестирует конструктор без передачи значений и корректное приведение к json
|
||
*
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::jsonSerialize
|
||
*/
|
||
public function testConstructorWithoutArgs(): void
|
||
{
|
||
$this->assertSame('[]', (string)(new PayingAgent()));
|
||
}
|
||
|
||
/**
|
||
* Тестирует конструктор с передачей значений и корректное приведение к json
|
||
*
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::jsonSerialize
|
||
* @covers \AtolOnline\Entities\PayingAgent::setOperation
|
||
* @covers \AtolOnline\Entities\PayingAgent::setPhones
|
||
* @covers \AtolOnline\Entities\PayingAgent::getOperation
|
||
* @covers \AtolOnline\Entities\PayingAgent::getPhones
|
||
* @throws InvalidPhoneException
|
||
* @throws TooLongPayingAgentOperationException
|
||
* @throws Exception
|
||
*/
|
||
public function testConstructorWithArgs(): void
|
||
{
|
||
$operation = Helpers::randomStr();
|
||
$this->assertIsAtolable(
|
||
new PayingAgent(
|
||
$operation,
|
||
['+122997365456'],
|
||
),
|
||
[
|
||
'operation' => $operation,
|
||
'phones' => ['+122997365456'],
|
||
]
|
||
);
|
||
$this->assertIsAtolable(
|
||
new PayingAgent($operation),
|
||
['operation' => $operation]
|
||
);
|
||
$this->assertIsAtolable(
|
||
new PayingAgent(phones: ['+122997365456']),
|
||
['phones' => ['+122997365456']]
|
||
);
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку операций, которые приводятся к null
|
||
*
|
||
* @param mixed $operation
|
||
* @dataProvider providerNullableStrings
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::setOperation
|
||
* @covers \AtolOnline\Entities\PayingAgent::getOperation
|
||
* @throws TooLongPayingAgentOperationException
|
||
* @throws InvalidPhoneException
|
||
*/
|
||
public function testNullableOperations(mixed $operation): void
|
||
{
|
||
$this->assertNull((new PayingAgent($operation))->getOperation());
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку невалидной операции
|
||
*
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::setOperation
|
||
* @covers \AtolOnline\Exceptions\TooLongPayingAgentOperationException
|
||
*/
|
||
public function testTooLongPayingAgentOperationException(): void
|
||
{
|
||
$this->expectException(TooLongPayingAgentOperationException::class);
|
||
(new PayingAgent())->setOperation(Helpers::randomStr(25));
|
||
}
|
||
|
||
/**
|
||
* Провайдер массивов телефонов, которые приводятся к null
|
||
*
|
||
* @return array<array>
|
||
*/
|
||
public function providerNullablePhonesArrays(): array
|
||
{
|
||
return [
|
||
[[]],
|
||
[null],
|
||
[collect()],
|
||
];
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку пустых телефонов
|
||
*
|
||
* @dataProvider providerNullablePhonesArrays
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::setPhones
|
||
* @covers \AtolOnline\Entities\PayingAgent::getPhones
|
||
* @throws InvalidPhoneException
|
||
* @throws TooLongPayingAgentOperationException
|
||
*/
|
||
public function testNullablePhones(mixed $phones): void
|
||
{
|
||
$agent = new PayingAgent(phones: $phones);
|
||
$this->assertIsCollection($agent->getPhones());
|
||
$this->assertTrue($agent->getPhones()->isEmpty());
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку невалидных телефонов
|
||
*
|
||
* @covers \AtolOnline\Entities\PayingAgent
|
||
* @covers \AtolOnline\Entities\PayingAgent::setPhones
|
||
* @covers \AtolOnline\Exceptions\InvalidPhoneException
|
||
* @throws InvalidPhoneException
|
||
*/
|
||
public function testInvalidPhoneException(): void
|
||
{
|
||
$this->expectException(InvalidPhoneException::class);
|
||
(new PayingAgent())->setPhones([
|
||
'12345678901234567', // good
|
||
'+123456789012345678', // good
|
||
'12345678901234567890', // bad
|
||
'+12345678901234567890', // bad
|
||
]);
|
||
}
|
||
}
|