1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
|
<?php
declare(strict_types=1);
/*
* This file is part of the Shaarli Netscape Bookmark Parser package.
*
* (c) "Matthias Morin" <mat@tangoman.io>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Shaarli\NetscapeBookmarkParser\Tests\Unit\DataConverter;
use InvalidArgumentException;
use PHPUnit\Framework\TestCase;
use Shaarli\NetscapeBookmarkParser\DataConverter\AbstractConverter;
use Shaarli\NetscapeBookmarkParser\DataConverter\DataConverterInterface;
/**
* @author "Matthias Morin" <mat@tangoman.io>
*/
class AbstractConverterTest extends TestCase
{
private const ORIGIN = [
'origin_foo' => 'foo',
'origin_bar' => 'bar',
'origin_baz' => 'baz',
];
private const DESTINATION = [
'destination_foo' => 'foo',
'destination_bar' => 'bar',
'destination_baz' => 'baz',
];
/**
* @var DataConverterInterface
*/
private $abstractConverter;
// --------------------------------------------------
// Exception
// --------------------------------------------------
public function testConvertEmptyArrayShouldRaiseException(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage('Array cannot be empty');
$this->abstractConverter->convert([]);
}
public function testReverseConvertEmptyArrayShouldRaiseException(): void
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage('Array cannot be empty');
$this->abstractConverter->reverseConvert([]);
}
// --------------------------------------------------
// Business Logic
// --------------------------------------------------
public function testConvertShouldReturnExpectedResult(): void
{
$result = $this->abstractConverter->convert(self::ORIGIN);
$this->assertSame(self::DESTINATION, $result);
}
public function testReverseConvertShouldReturnExpectedResult(): void
{
$result = $this->abstractConverter->reverseConvert(self::DESTINATION);
$this->assertSame(self::ORIGIN, $result);
}
// --------------------------------------------------
// Setup / Tear Down
// --------------------------------------------------
protected function setUp(): void
{
// create a new anonymous instance from the Abstract Class
$this->abstractConverter = new class () extends AbstractConverter {
public const MAP = [
'origin_foo' => 'destination_foo',
'origin_bar' => 'destination_bar',
'origin_baz' => 'destination_baz',
];
};
}
protected function tearDown(): void
{
$this->abstractConverter = null;
}
}
|