mirror of
https://github.com/anthonyaxenov/atol-online.git
synced 2024-12-22 16:25:01 +00:00
AnthonyAxenov
4157ab68f5
* enum-ы теперь enum-ы, а не говно -- теперь всё переведено на них, где это было возможно * некоторые свойства классов объявлены в конструкторе * некоторые классы перемещены в корневой неймспейс * исправлен код-стайл, вычищен некоторый мусор, выправлены тесты... работы над этим продолжаются
99 lines
3.3 KiB
PHP
99 lines
3.3 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\ReceivePaymentsOperator,
|
||
Exceptions\InvalidPhoneException,
|
||
Tests\BasicTestCase};
|
||
use Exception;
|
||
|
||
/**
|
||
* Набор тестов для проверки работы класса оператора по приёму платежей
|
||
*/
|
||
class ReceivePaymentsOperatorTest extends BasicTestCase
|
||
{
|
||
/**
|
||
* Тестирует конструктор без передачи значений и корректное приведение к json
|
||
*
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::jsonSerialize
|
||
*/
|
||
public function testConstructorWithoutArgs(): void
|
||
{
|
||
$this->assertSame('[]', (string)(new ReceivePaymentsOperator()));
|
||
}
|
||
|
||
/**
|
||
* Тестирует конструктор с передачей значений и корректное приведение к json
|
||
*
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::jsonSerialize
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::setPhones
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::getPhones
|
||
* @throws InvalidPhoneException
|
||
* @throws Exception
|
||
*/
|
||
public function testConstructorWithArgs(): void
|
||
{
|
||
$this->assertIsAtolable(new ReceivePaymentsOperator(['+122997365456']), ['phones' => ['+122997365456']]);
|
||
}
|
||
|
||
/**
|
||
* Провайдер массивов телефонов, которые приводятся к null
|
||
*
|
||
* @return array<array>
|
||
*/
|
||
public function providerNullablePhonesArrays(): array
|
||
{
|
||
return [
|
||
[[]],
|
||
[null],
|
||
[collect()],
|
||
];
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку пустых телефонов
|
||
*
|
||
* @dataProvider providerNullablePhonesArrays
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::setPhones
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::getPhones
|
||
* @throws InvalidPhoneException
|
||
*/
|
||
public function testNullablePhones(mixed $phones): void
|
||
{
|
||
$agent = new ReceivePaymentsOperator($phones);
|
||
$this->assertIsCollection($agent->getPhones());
|
||
$this->assertTrue($agent->getPhones()->isEmpty());
|
||
}
|
||
|
||
/**
|
||
* Тестирует установку невалидных телефонов
|
||
*
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator
|
||
* @covers \AtolOnline\Entities\ReceivePaymentsOperator::setPhones
|
||
* @covers \AtolOnline\Exceptions\InvalidPhoneException
|
||
* @throws InvalidPhoneException
|
||
*/
|
||
public function testInvalidPhoneException(): void
|
||
{
|
||
$this->expectException(InvalidPhoneException::class);
|
||
(new ReceivePaymentsOperator([
|
||
'12345678901234567', // good
|
||
'+123456789012345678', // good
|
||
'12345678901234567890', // bad
|
||
'+12345678901234567890', // bad
|
||
]));
|
||
}
|
||
}
|