mirror of
https://github.com/anthonyaxenov/atol-online.git
synced 2024-11-16 03:50:47 +00:00
AnthonyAxenov
77481884ad
- строгая типизация - переработан класс `TestEnvParams`: - вынесен на уровень выше из под `AtolOnline\Constants` - вместо констант - две функции для получения актуальных параметров подключения по ФФД1.05 и ФФД1.2 - актуализированы `PaymentObjects` согласно #5 - исходники вынесены не уровень выше в `src` - константы теперь enum через `myclabs/php-enum` - новые константы `DocumentTypes` - классы констант финализированы - все исключения переименованы, а многие так или иначе отрефакторены (не полностью) - новые исключения `InvalidSnoException`, `InvalidPaymentAddressException` - `helpers.php` стал полноценным классом `Helpers` - удалены трейты `HasEmail`, `HasInn`, `RublesKopeksConverter` (конвертация перенесена в `Helpers`) - удалён хелпер `valid_strlen()`, вместо него теперь везде `mb_strlen()` - сущности `Client` и `Company` получили свои имплементации для `email` и `inn` - доработки в `BasicTestCase` - полное покрытие тестами: `Client`, `Company`, `Helpers` - поправлен `phpunit.xml` - везде обновлены копирайты - актуализированы и исправлены phpdoc, return types - начато введение `strict_types=1` - минимальный php теперь 8.0 - обновлены все зависимости - подключен пакет коллекций laravel для будущего использования - теперь можно `composer test` и `composer test-cov`
85 lines
2.6 KiB
PHP
85 lines
2.6 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
|
|
*/
|
|
|
|
declare(strict_types = 1);
|
|
|
|
namespace AtolOnline\Tests;
|
|
|
|
use AtolOnline\Entities\Entity;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
/**
|
|
* Class BasicTestCase
|
|
*/
|
|
class BasicTestCase extends TestCase
|
|
{
|
|
/**
|
|
* @todo требуется рефакторинг
|
|
*/
|
|
public function setUp(): void
|
|
{
|
|
//parent::setUp();
|
|
defined('ATOL_KKT_GROUP') ?: define('ATOL_KKT_GROUP', 'v4-online-atol-ru_4179');
|
|
defined('ATOL_KKT_LOGIN') ?: define('ATOL_KKT_LOGIN', 'v4-online-atol-ru');
|
|
defined('ATOL_KKT_PASS') ?: define('ATOL_KKT_PASS', 'iGFFuihss');
|
|
defined('ATOL_CALLBACK_URL') ?: define('ATOL_CALLBACK_URL', 'http://example.com/callback');
|
|
}
|
|
|
|
/**
|
|
* Тестирует является ли объект приводимым к json-строке согласно схеме АТОЛ Онлайн
|
|
*
|
|
* @param Entity $entity
|
|
* @param array $json_structure
|
|
* @covers \AtolOnline\Entities\Entity::jsonSerialize
|
|
* @covers \AtolOnline\Entities\Entity::__toString
|
|
*/
|
|
public function assertAtolable(Entity $entity, array $json_structure = []): void
|
|
{
|
|
$this->assertIsObject($entity);
|
|
$this->assertIsObject($entity->jsonSerialize());
|
|
$this->assertIsString((string)$entity);
|
|
$this->assertJson((string)$entity);
|
|
if ($json_structure) {
|
|
$this->assertEquals(json_encode($json_structure), (string)$entity);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Провайдер валидных телефонов
|
|
*
|
|
* @return array<array<string, string>>
|
|
*/
|
|
public function providerValidPhones(): array
|
|
{
|
|
return [
|
|
['+79991234567', '+79991234567'],
|
|
['79991234567', '+79991234567'],
|
|
['89991234567', '+89991234567'],
|
|
['+7 999 123 45 67', '+79991234567'],
|
|
['+7 (999) 123-45-67', '+79991234567'],
|
|
["+7 %(?9:9\"9')abc\r123\n45\t67\0", '+79991234567'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Провайдер валидных email-ов
|
|
*
|
|
* @return array<array<string>>
|
|
*/
|
|
public function providerValidEmails(): array
|
|
{
|
|
return [
|
|
['abc@mail.com'],
|
|
['abc-d@mail.com'],
|
|
['abc.def@mail.com'],
|
|
['abc.def@mail.org'],
|
|
['abc.def@mail-archive.com'],
|
|
];
|
|
}
|
|
} |