Initial commit

This commit is contained in:
2025-10-05 13:55:28 +02:00
commit 68d521677a
767 changed files with 46947 additions and 0 deletions
@@ -0,0 +1,37 @@
<?php
declare(strict_types=1);
namespace Tests\Unit\Aggregator\Domain\Model\ValueObject;
use App\Aggregator\Domain\Model\ValueObject\Crawling\PageRange;
use App\SharedKernel\Domain\Exception\InvalidArgument;
use PHPUnit\Framework\TestCase;
/**
* Class PageRangeTest.
*
* @author bernard-ng <bernard@devscast.tech>
*/
final class PageRangeTest extends TestCase
{
public function testItShouldCreatePageRange(): void
{
$pageRange = PageRange::from('1:10');
$this->assertEquals(1, $pageRange->start);
$this->assertEquals(10, $pageRange->end);
}
public function testEndPageShouldBeGreaterThanStartPage(): void
{
$this->expectException(InvalidArgument::class);
PageRange::from('10:1');
}
public function testNonNegativePages(): void
{
$this->expectException(InvalidArgument::class);
PageRange::from('-1:-10');
}
}
@@ -0,0 +1,63 @@
<?php
declare(strict_types=1);
namespace Tests\Unit\Aggregator\Domain\Service;
use App\Aggregator\Domain\Service\Crawling\DateParser;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\TestCase;
/**
* Class DateParserTest.
*
* @author bernard-ng <bernard@devscast.tech>
*/
final class DateParserTest extends TestCase
{
private DateParser $dateParser;
#[\Override]
protected function setUp(): void
{
$this->dateParser = new DateParser();
}
#[DataProvider('validDateProvider')]
public function testCreateTimeStampWithValidDates(
string $date,
?string $format,
?string $pattern,
?string $replacement,
string $expected
): void {
$result = $this->dateParser->createTimeStamp($date, $format, $pattern, $replacement);
$this->assertEquals($expected, $result);
}
#[DataProvider('invalidDateProvider')]
public function testCreateTimeStampWithInvalidDates(
string $date,
?string $format,
?string $pattern,
?string $replacement
): void {
$currentTimestamp = new \DateTime('midnight')->format('U');
$result = $this->dateParser->createTimeStamp($date, $format, $pattern, $replacement);
$this->assertEquals($currentTimestamp, $result);
}
public static function validDateProvider(): \Generator
{
yield ['2004-02-12T15:19:21', 'c', null, null, '1076599161'];
yield ['08/10/2024 - 00:00', 'Y-m-d H:i', '/(\d{2})\/(\d{2})\/(\d{4}) - (\d{2}:\d{2})/', '$3-$2-$1 $4', '1728345600'];
yield ['mar 08/10/2024 - 00:00', 'Y-m-d H:i', '/\w{3} (\d{2})\/(\d{2})\/(\d{4}) - (\d{2}:\d{2})/', '$3-$2-$1 $4', '1728345600'];
yield ['Mardi 8 octobre 2024 - 00:00', 'Y-m-d H:i', '/(\d{1}) (\d{1,2}) (\d{2}) (\d{4}) - (\d{2}:\d{2})/', '$4-$3-$2 $5', '1728345600'];
yield ['8.10.2024 00:00', 'd.m.Y H:i', null, null, '1728345600'];
}
public static function invalidDateProvider(): \Generator
{
yield ['invalid date string', null, null, null];
}
}
@@ -0,0 +1,35 @@
<?php
declare(strict_types=1);
namespace Tests\Unit\SharedKernel\Domain\Model\ValueObject;
use App\SharedKernel\Domain\Exception\InvalidArgument;
use App\SharedKernel\Domain\Model\ValueObject\DateRange;
use PHPUnit\Framework\TestCase;
/**
* Class DateRangeTest.
*
* @author bernard-ng <bernard@devscast.tech>
*/
final class DateRangeTest extends TestCase
{
public function testItShouldCreateDateRange(): void
{
$dateRange = DateRange::from(
'2021-10-01 00:00:00--2021-10-10 00:00:00',
'Y-m-d H:i:s',
'--'
);
$this->assertEquals(1633046400, $dateRange->start);
$this->assertEquals(1633824000, $dateRange->end);
}
public function testEndShouldBeGreaterThanStart(): void
{
$this->expectException(InvalidArgument::class);
DateRange::from('2021-10-10:2021-10-01');
}
}