2022-09-09 10:50:24 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2022 Daniel Siepmann <coding@daniel-siepmann.de>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
* 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2023-11-09 10:27:43 +01:00
|
|
|
namespace WerkraumMedia\Events\Tests\Functional\Frontend;
|
2022-09-09 10:50:24 +02:00
|
|
|
|
2023-11-27 10:04:42 +01:00
|
|
|
use PHPUnit\Framework\Attributes\Test;
|
2023-11-30 11:55:32 +01:00
|
|
|
use Psr\Http\Message\ResponseInterface;
|
2022-09-09 10:50:24 +02:00
|
|
|
use TYPO3\TestingFramework\Core\Functional\Framework\Frontend\InternalRequest;
|
2023-11-09 10:27:43 +01:00
|
|
|
use WerkraumMedia\Events\Frontend\Dates;
|
2022-09-09 10:50:24 +02:00
|
|
|
|
2024-11-06 07:54:30 +01:00
|
|
|
final class DatesTest extends AbstractFrontendTestCase
|
2022-09-09 10:50:24 +02:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Covers issue https://redmine.werkraum-media.de/issues/10075.
|
|
|
|
* Editors can disable events. Dates will still be available.
|
|
|
|
* Dates don't make any sense without an event, as they not even have a name.
|
|
|
|
*
|
|
|
|
* They therefore should not be fetched from persistence.
|
|
|
|
*/
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2022-09-09 10:50:24 +02:00
|
|
|
public function returnsOnlyDatesWithAvailableEventByDemand(): void
|
|
|
|
{
|
2023-11-27 10:04:42 +01:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/ReturnsOnlyDatesWithAvailableEventByDemand.php');
|
2022-09-09 10:50:24 +02:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$request = new InternalRequest('https://example.com/');
|
2022-09-09 10:50:24 +02:00
|
|
|
$request = $request->withPageId(1);
|
2023-11-27 10:04:42 +01:00
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
2022-09-09 10:50:24 +02:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
2023-06-07 08:56:42 +02:00
|
|
|
$html = (string)$response->getBody();
|
2022-09-09 10:50:24 +02:00
|
|
|
|
|
|
|
self::assertStringNotContainsString('Event 1 hidden', $html);
|
|
|
|
self::assertStringContainsString('Event 2 visible', $html);
|
|
|
|
}
|
2023-02-16 15:33:19 +01:00
|
|
|
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2023-02-16 15:33:19 +01:00
|
|
|
public function returnsDateAfterStart(): void
|
|
|
|
{
|
2023-11-27 10:04:42 +01:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/ReturnsDateWithinTimeSpan.php');
|
2023-02-16 15:33:19 +01:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$request = new InternalRequest('https://example.com/');
|
2023-02-16 15:33:19 +01:00
|
|
|
$request = $request->withPageId(1);
|
|
|
|
$request = $request->withQueryParameters([
|
2024-11-06 07:54:30 +01:00
|
|
|
'tx_events_datelisttest[search][start]' => '2023-02-16',
|
2023-02-16 15:33:19 +01:00
|
|
|
]);
|
2023-11-27 10:04:42 +01:00
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
2023-06-07 08:56:42 +02:00
|
|
|
$html = (string)$response->getBody();
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertStringNotContainsString('Event 1', $html);
|
|
|
|
self::assertStringNotContainsString('Event 2', $html);
|
|
|
|
self::assertStringContainsString('Event 3', $html);
|
|
|
|
self::assertStringContainsString('Event 4', $html);
|
|
|
|
self::assertStringContainsString('Event 5', $html);
|
|
|
|
self::assertStringContainsString('Event 6', $html);
|
|
|
|
self::assertStringContainsString('Event 7', $html);
|
|
|
|
self::assertStringContainsString('Event 8', $html);
|
|
|
|
self::assertStringContainsString('Event 9', $html);
|
|
|
|
}
|
|
|
|
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2023-02-16 15:33:19 +01:00
|
|
|
public function returnsDateBeforeEnd(): void
|
|
|
|
{
|
2023-11-27 10:04:42 +01:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/ReturnsDateWithinTimeSpan.php');
|
2023-02-16 15:33:19 +01:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$request = new InternalRequest('https://example.com/');
|
2023-02-16 15:33:19 +01:00
|
|
|
$request = $request->withPageId(1);
|
|
|
|
$request = $request->withQueryParameters([
|
2024-11-06 07:54:30 +01:00
|
|
|
'tx_events_datelisttest[search][end]' => '2023-02-17',
|
2023-02-16 15:33:19 +01:00
|
|
|
]);
|
2023-11-27 10:04:42 +01:00
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
2023-06-07 08:56:42 +02:00
|
|
|
$html = (string)$response->getBody();
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertStringContainsString('Event 1', $html);
|
|
|
|
self::assertStringContainsString('Event 2', $html);
|
|
|
|
self::assertStringNotContainsString('Event 3', $html);
|
|
|
|
self::assertStringNotContainsString('Event 4', $html);
|
|
|
|
self::assertStringContainsString('Event 5', $html);
|
|
|
|
self::assertStringContainsString('Event 6', $html);
|
|
|
|
self::assertStringContainsString('Event 7', $html);
|
|
|
|
self::assertStringContainsString('Event 8', $html);
|
|
|
|
self::assertStringContainsString('Event 9', $html);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Covers issue https://redmine.werkraum-media.de/issues/10350.
|
|
|
|
* A date can span multiple dates.
|
|
|
|
* The visitor might search a time frame within the spaned dates and expects the date to be shown.
|
|
|
|
*/
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2023-02-16 15:33:19 +01:00
|
|
|
public function returnsDateWithinTimeSpan(): void
|
|
|
|
{
|
2023-11-27 10:04:42 +01:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/ReturnsDateWithinTimeSpan.php');
|
2023-02-16 15:33:19 +01:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$request = new InternalRequest('https://example.com/');
|
2023-02-16 15:33:19 +01:00
|
|
|
$request = $request->withPageId(1);
|
|
|
|
$request = $request->withQueryParameters([
|
2024-11-06 07:54:30 +01:00
|
|
|
'tx_events_datelisttest[search][start]' => '2023-02-16',
|
|
|
|
'tx_events_datelisttest[search][end]' => '2023-02-17',
|
2023-02-16 15:33:19 +01:00
|
|
|
]);
|
2023-11-27 10:04:42 +01:00
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
2023-06-07 08:56:42 +02:00
|
|
|
$html = (string)$response->getBody();
|
2023-02-16 15:33:19 +01:00
|
|
|
|
|
|
|
self::assertStringNotContainsString('Event 1', $html);
|
|
|
|
self::assertStringNotContainsString('Event 2', $html);
|
|
|
|
self::assertStringNotContainsString('Event 3', $html);
|
|
|
|
self::assertStringNotContainsString('Event 4', $html);
|
|
|
|
self::assertStringContainsString('Event 5', $html);
|
|
|
|
self::assertStringContainsString('Event 6', $html);
|
|
|
|
self::assertStringContainsString('Event 7', $html);
|
|
|
|
self::assertStringContainsString('Event 8', $html);
|
|
|
|
self::assertStringContainsString('Event 9', $html);
|
|
|
|
}
|
2023-05-22 09:59:45 +02:00
|
|
|
|
2024-11-27 08:41:44 +01:00
|
|
|
#[Test]
|
|
|
|
public function returns404IfNoDateIsGiven(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/Returns404IfNoDateIsGiven.php');
|
|
|
|
|
|
|
|
$request = new InternalRequest('https://example.com/');
|
|
|
|
$request = $request->withPageId(1);
|
|
|
|
|
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
|
|
|
|
|
|
|
self::assertSame(404, $response->getStatusCode());
|
|
|
|
}
|
|
|
|
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2023-10-16 07:47:48 +02:00
|
|
|
public function returns404IfEventIsHidden(): void
|
|
|
|
{
|
2023-11-27 10:04:42 +01:00
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/Returns404IfEventIsHidden.php');
|
2023-10-16 07:47:48 +02:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$response = $this->issueDetailRequest();
|
2023-10-16 07:47:48 +02:00
|
|
|
|
|
|
|
self::assertSame(404, $response->getStatusCode());
|
|
|
|
}
|
|
|
|
|
2023-11-27 10:04:42 +01:00
|
|
|
#[Test]
|
2023-05-22 09:59:45 +02:00
|
|
|
public function returnsUpcomingDates(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/ReturnsUpcomingDates.php');
|
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$request = new InternalRequest('https://example.com/');
|
2023-05-22 09:59:45 +02:00
|
|
|
$request = $request->withPageId(1);
|
|
|
|
$request = $request->withInstructions([
|
|
|
|
$this->getTypoScriptInstruction()
|
|
|
|
->withTypoScript([
|
|
|
|
'plugin.' => [
|
|
|
|
'tx_events.' => [
|
|
|
|
'settings.' => [
|
|
|
|
'upcoming' => '1',
|
|
|
|
],
|
|
|
|
],
|
|
|
|
],
|
2023-06-07 08:56:42 +02:00
|
|
|
]),
|
2023-05-22 09:59:45 +02:00
|
|
|
]);
|
2023-11-27 10:04:42 +01:00
|
|
|
$response = $this->executeFrontendSubRequest($request);
|
2023-05-22 09:59:45 +02:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
2023-06-07 08:56:42 +02:00
|
|
|
$html = (string)$response->getBody();
|
2023-05-22 09:59:45 +02:00
|
|
|
|
|
|
|
self::assertStringNotContainsString('Event 1', $html);
|
|
|
|
self::assertStringContainsString('Event 2', $html);
|
|
|
|
}
|
2023-11-29 10:36:59 +01:00
|
|
|
|
|
|
|
#[Test]
|
|
|
|
public function addsMetaTags(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/DateMetaTags.php');
|
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$response = $this->issueDetailRequest();
|
2023-11-29 10:36:59 +01:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
|
|
|
$html = (string)$response->getBody();
|
|
|
|
|
2024-06-27 09:48:33 +02:00
|
|
|
self::assertStringContainsString('<meta name="description" content="Teaser of Event">', $html);
|
|
|
|
self::assertStringContainsString('<meta name="keywords" content="Gewölbe, Goethe, Horst Damm, Kästner, Theater">', $html);
|
2023-11-29 10:36:59 +01:00
|
|
|
}
|
2023-11-29 10:52:57 +01:00
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
#[Test]
|
|
|
|
public function addsOpenGraphTags(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/DateOpenGraphTags.php');
|
|
|
|
|
|
|
|
$response = $this->issueDetailRequest();
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
|
|
|
$html = (string)$response->getBody();
|
|
|
|
|
2024-06-27 09:48:33 +02:00
|
|
|
self::assertStringContainsString('<meta property="og:title" content="Title of Event 15.02.2023 00:00">', $html);
|
|
|
|
self::assertStringContainsString('<meta property="og:type" content="website">', $html);
|
|
|
|
self::assertStringContainsString('<meta property="og:image" content="http://example.com/fileadmin/user_uploads/example-for-event.gif">', $html);
|
2023-11-30 11:55:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#[Test]
|
|
|
|
public function addsSocialMediaTags(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/DateSocialMediaTags.php');
|
|
|
|
|
|
|
|
$response = $this->issueDetailRequest();
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
|
|
|
$html = (string)$response->getBody();
|
|
|
|
|
2024-06-27 09:48:33 +02:00
|
|
|
self::assertStringContainsString('<meta name="twitter:card" content="summary">', $html);
|
|
|
|
self::assertStringContainsString('<meta name="twitter:title" content="Title of Event 15.02.2023 00:00">', $html);
|
|
|
|
self::assertStringContainsString('<meta name="twitter:description" content="Teaser of Event">', $html);
|
|
|
|
self::assertStringContainsString('<meta name="twitter:image" content="http://example.com/fileadmin/user_uploads/example-for-event.gif">', $html);
|
2023-11-30 11:55:32 +01:00
|
|
|
}
|
|
|
|
|
2023-11-29 10:52:57 +01:00
|
|
|
#[Test]
|
|
|
|
public function altersPageTitle(): void
|
|
|
|
{
|
|
|
|
$this->importPHPDataSet(__DIR__ . '/DatesTestFixtures/DatePageTitle.php');
|
|
|
|
|
2023-11-30 11:55:32 +01:00
|
|
|
$response = $this->issueDetailRequest();
|
2023-11-29 10:52:57 +01:00
|
|
|
|
|
|
|
self::assertSame(200, $response->getStatusCode());
|
|
|
|
$html = (string)$response->getBody();
|
|
|
|
|
|
|
|
self::assertStringContainsString('<title>Title of Event 15.02.2023 00:00</title>', $html);
|
|
|
|
}
|
2023-11-30 11:55:32 +01:00
|
|
|
|
|
|
|
private function issueDetailRequest(): ResponseInterface
|
|
|
|
{
|
|
|
|
$request = new InternalRequest('https://example.com/');
|
|
|
|
$request = $request->withPageId(1);
|
2024-11-06 07:54:30 +01:00
|
|
|
$request = $request->withQueryParameter('tx_events_dateshowtest[date]', '1');
|
2023-11-30 11:55:32 +01:00
|
|
|
|
|
|
|
return $this->executeFrontendSubRequest($request);
|
|
|
|
}
|
2022-09-09 10:50:24 +02:00
|
|
|
}
|