2022-08-03 11:24:01 +02:00
|
|
|
<?php
|
|
|
|
|
2023-11-09 10:27:43 +01:00
|
|
|
namespace WerkraumMedia\Events\Tests\Functional\Import\DestinationDataTest;
|
2022-08-03 11:24:01 +02:00
|
|
|
|
|
|
|
use GuzzleHttp\Psr7\Response;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @testdox DestinationData import
|
|
|
|
*/
|
2023-07-06 12:39:47 +02:00
|
|
|
final class ImportsWithLocationsTest extends AbstractTest
|
2022-08-03 11:24:01 +02:00
|
|
|
{
|
2023-07-04 10:11:26 +02:00
|
|
|
protected function setUp(): void
|
2022-08-03 11:24:01 +02:00
|
|
|
{
|
2023-07-04 10:11:26 +02:00
|
|
|
parent::setUp();
|
2022-08-03 11:24:01 +02:00
|
|
|
|
2023-05-15 11:58:19 +02:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/Fixtures/Database/DefaultImportConfiguration.php');
|
2022-08-03 11:24:01 +02:00
|
|
|
$this->setUpConfiguration([
|
|
|
|
'restUrl = https://example.com/some-path/',
|
|
|
|
'license = example-license',
|
|
|
|
'restType = Event',
|
|
|
|
'restLimit = 3',
|
|
|
|
'restMode = next_months,12',
|
|
|
|
'restTemplate = ET2014A.json',
|
|
|
|
]);
|
2023-07-04 10:11:26 +02:00
|
|
|
}
|
2022-08-03 11:24:01 +02:00
|
|
|
|
2023-07-04 10:11:26 +02:00
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
*/
|
|
|
|
public function importsWithLocations(): void
|
|
|
|
{
|
2023-07-06 12:39:47 +02:00
|
|
|
$this->setUpResponses([
|
2022-08-03 11:24:01 +02:00
|
|
|
new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithLocations.json') ?: ''),
|
|
|
|
]);
|
2022-11-22 13:49:57 +01:00
|
|
|
$tester = $this->executeCommand();
|
2022-08-03 11:24:01 +02:00
|
|
|
|
|
|
|
self::assertSame(0, $tester->getStatusCode());
|
2023-07-06 12:39:47 +02:00
|
|
|
$this->assertPHPDataSet(__DIR__ . '/Assertions/ImportsWithLocations.php');
|
|
|
|
$this->assertEmptyLog();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A single location might be available with different ways to write latitude an longitude ("," and ".").
|
|
|
|
* This test ensures this situation is properly handled by streamlining the values.
|
|
|
|
*
|
|
|
|
* @test
|
|
|
|
*/
|
|
|
|
public function importsWithSingleLocationOnDuplicates(): void
|
|
|
|
{
|
|
|
|
$this->setUpResponses([
|
|
|
|
new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithLocationUsingDifferentLatitudeAndLongitude.json') ?: ''),
|
|
|
|
]);
|
|
|
|
$tester = $this->executeCommand();
|
|
|
|
|
|
|
|
self::assertSame(0, $tester->getStatusCode());
|
|
|
|
$this->assertPHPDataSet(__DIR__ . '/Assertions/ImportsWithSingleLocationOnDuplicates.php');
|
|
|
|
$this->assertEmptyLog();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @test
|
|
|
|
*/
|
|
|
|
public function updatesExistingLocation(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/Fixtures/Database/ExistingLocation.php');
|
|
|
|
|
|
|
|
$this->setUpResponses([
|
|
|
|
new Response(200, [], file_get_contents(__DIR__ . '/Fixtures/ResponseWithLocationWithDifferentValues.json') ?: ''),
|
|
|
|
]);
|
|
|
|
$tester = $this->executeCommand();
|
|
|
|
|
|
|
|
self::assertSame(0, $tester->getStatusCode());
|
|
|
|
$this->assertPHPDataSet(__DIR__ . '/Assertions/UpdatesExistingLocation.php');
|
2023-07-04 10:11:26 +02:00
|
|
|
$this->assertEmptyLog();
|
2022-08-03 11:24:01 +02:00
|
|
|
}
|
|
|
|
}
|