mirror of
https://github.com/werkraum-media/abtest.git
synced 2024-11-23 15:56:11 +01:00
First refactoring
This got extracted from integrating Matomo tracking. We migrate to an event in order to remove Singleton instance. The event transports info and foreign code can react. We streamline architecture and split logic from integration.
This commit is contained in:
parent
604110e737
commit
7ace7e2625
10 changed files with 211 additions and 114 deletions
|
@ -23,9 +23,7 @@ declare(strict_types=1);
|
||||||
|
|
||||||
namespace WerkraumMedia\ABTest;
|
namespace WerkraumMedia\ABTest;
|
||||||
|
|
||||||
use TYPO3\CMS\Core\SingletonInterface;
|
class Cookie
|
||||||
|
|
||||||
class Cookie implements SingletonInterface
|
|
||||||
{
|
{
|
||||||
/**
|
/**
|
||||||
* @var int
|
* @var int
|
||||||
|
|
48
Classes/Events/SwitchedToVariant.php
Normal file
48
Classes/Events/SwitchedToVariant.php
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2023 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace WerkraumMedia\ABTest\Events;
|
||||||
|
|
||||||
|
final class SwitchedToVariant
|
||||||
|
{
|
||||||
|
private array $originalPage;
|
||||||
|
private array $variantPage;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
array $originalPage,
|
||||||
|
array $variantPage
|
||||||
|
) {
|
||||||
|
$this->originalPage = $originalPage;
|
||||||
|
$this->variantPage = $variantPage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getOriginalPage(): array
|
||||||
|
{
|
||||||
|
return $this->originalPage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getVariantPage(): array
|
||||||
|
{
|
||||||
|
return $this->variantPage;
|
||||||
|
}
|
||||||
|
}
|
50
Classes/Hook/TypoScriptFrontendController.php
Normal file
50
Classes/Hook/TypoScriptFrontendController.php
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2023 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace WerkraumMedia\ABTest\Hook;
|
||||||
|
|
||||||
|
use TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController as Typo3TypoScriptFrontendController;
|
||||||
|
use WerkraumMedia\ABTest\Switcher;
|
||||||
|
|
||||||
|
class TypoScriptFrontendController
|
||||||
|
{
|
||||||
|
private Switcher $switcher;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
Switcher $switcher
|
||||||
|
) {
|
||||||
|
$this->switcher = $switcher;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function determineIdPostProc(
|
||||||
|
array $params,
|
||||||
|
Typo3TypoScriptFrontendController $frontendController
|
||||||
|
): void {
|
||||||
|
$this->switcher->switch($frontendController);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function register(): void
|
||||||
|
{
|
||||||
|
$GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['tslib/class.tslib_fe.php']['determineId-PostProc'][self::class] = self::class . '->determineIdPostProc';
|
||||||
|
}
|
||||||
|
}
|
|
@ -29,6 +29,7 @@ use Psr\Http\Server\MiddlewareInterface;
|
||||||
use Psr\Http\Server\RequestHandlerInterface;
|
use Psr\Http\Server\RequestHandlerInterface;
|
||||||
use Symfony\Component\HttpFoundation\Cookie as SymfonyCookie;
|
use Symfony\Component\HttpFoundation\Cookie as SymfonyCookie;
|
||||||
use WerkraumMedia\ABTest\Cookie;
|
use WerkraumMedia\ABTest\Cookie;
|
||||||
|
use WerkraumMedia\ABTest\Events\SwitchedToVariant;
|
||||||
|
|
||||||
class SetCookie implements MiddlewareInterface
|
class SetCookie implements MiddlewareInterface
|
||||||
{
|
{
|
||||||
|
@ -43,6 +44,14 @@ class SetCookie implements MiddlewareInterface
|
||||||
$this->cookie = $cookie;
|
$this->cookie = $cookie;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function handleVariant(SwitchedToVariant $event): void
|
||||||
|
{
|
||||||
|
$targetPage = $event->getVariantPage();
|
||||||
|
$this->cookie->setRequestedPage((int)$event->getOriginalPage()['uid']);
|
||||||
|
$this->cookie->setActualPage((int)$targetPage['uid']);
|
||||||
|
$this->cookie->setLifetime((int)$targetPage['tx_abtest_cookie_time']);
|
||||||
|
}
|
||||||
|
|
||||||
public function process(
|
public function process(
|
||||||
ServerRequestInterface $request,
|
ServerRequestInterface $request,
|
||||||
RequestHandlerInterface $handler
|
RequestHandlerInterface $handler
|
||||||
|
|
|
@ -24,9 +24,10 @@ declare(strict_types=1);
|
||||||
namespace WerkraumMedia\ABTest;
|
namespace WerkraumMedia\ABTest;
|
||||||
|
|
||||||
use DeviceDetector\DeviceDetector;
|
use DeviceDetector\DeviceDetector;
|
||||||
|
use TYPO3\CMS\Core\EventDispatcher\EventDispatcher;
|
||||||
use TYPO3\CMS\Core\Http\ServerRequest;
|
use TYPO3\CMS\Core\Http\ServerRequest;
|
||||||
use TYPO3\CMS\Core\Site\Entity\Site;
|
|
||||||
use TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController;
|
use TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController;
|
||||||
|
use WerkraumMedia\ABTest\Events\SwitchedToVariant;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will decide whether to switch to another variant.
|
* Will decide whether to switch to another variant.
|
||||||
|
@ -35,31 +36,28 @@ class Switcher
|
||||||
{
|
{
|
||||||
private PageRepository $pageRepository;
|
private PageRepository $pageRepository;
|
||||||
|
|
||||||
private Cookie $cookie;
|
private EventDispatcher $eventDispatcher;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
PageRepository $pageRepository,
|
PageRepository $pageRepository,
|
||||||
Cookie $cookie
|
EventDispatcher $eventDispatcher
|
||||||
) {
|
) {
|
||||||
$this->pageRepository = $pageRepository;
|
$this->pageRepository = $pageRepository;
|
||||||
$this->cookie = $cookie;
|
$this->eventDispatcher = $eventDispatcher;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function determineContentId(
|
public function switch(TypoScriptFrontendController $frontendController): void
|
||||||
array $params,
|
{
|
||||||
TypoScriptFrontendController $frontendController
|
|
||||||
): void {
|
|
||||||
if ($this->isRequestByBot()) {
|
if ($this->isRequestByBot()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$currentPageId = $frontendController->id;
|
$currentPageId = $frontendController->id;
|
||||||
if (is_numeric($currentPageId) === false) {
|
if (is_numeric($currentPageId) === false) {
|
||||||
$currentPageId = $this->getRootPageId();
|
return;
|
||||||
} else {
|
|
||||||
$currentPageId = (int)$currentPageId;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$currentPageId = (int)$currentPageId;
|
||||||
if ($currentPageId === 0) {
|
if ($currentPageId === 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -85,9 +83,10 @@ class Switcher
|
||||||
$this->pageRepository->updateCounter((int)$targetPage['uid'], ++$targetPage['tx_abtest_counter']);
|
$this->pageRepository->updateCounter((int)$targetPage['uid'], ++$targetPage['tx_abtest_counter']);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->cookie->setRequestedPage($currentPageId);
|
$this->eventDispatcher->dispatch(new SwitchedToVariant(
|
||||||
$this->cookie->setActualPage($targetPage['uid']);
|
$currentPagePropertiesArray,
|
||||||
$this->cookie->setLifetime($targetPage['tx_abtest_cookie_time']);
|
$targetPage
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function isRequestByBot(): bool
|
private function isRequestByBot(): bool
|
||||||
|
@ -103,19 +102,6 @@ class Switcher
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns 0 if no site could be fetched.
|
|
||||||
*/
|
|
||||||
private function getRootPageId(): int
|
|
||||||
{
|
|
||||||
$site = $this->getRequest()->getAttribute('site');
|
|
||||||
if (!$site instanceof Site) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $site->getRootPageId();
|
|
||||||
}
|
|
||||||
|
|
||||||
private function getRequest(): ServerRequest
|
private function getRequest(): ServerRequest
|
||||||
{
|
{
|
||||||
return $GLOBALS['TYPO3_REQUEST'];
|
return $GLOBALS['TYPO3_REQUEST'];
|
||||||
|
@ -141,9 +127,4 @@ class Switcher
|
||||||
|
|
||||||
return $page;
|
return $page;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function register(): void
|
|
||||||
{
|
|
||||||
$GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['tslib/class.tslib_fe.php']['determineId-PostProc'][self::class] = self::class . '->determineContentId';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,9 @@ declare(strict_types=1);
|
||||||
namespace DanielSiepmann\Configuration;
|
namespace DanielSiepmann\Configuration;
|
||||||
|
|
||||||
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
|
||||||
use WerkraumMedia\ABTest\Switcher;
|
use WerkraumMedia\ABTest\Events\SwitchedToVariant;
|
||||||
|
use WerkraumMedia\ABTest\Hook\TypoScriptFrontendController;
|
||||||
|
use WerkraumMedia\ABTest\Middleware\SetCookie;
|
||||||
use WerkraumMedia\ABTest\TCA\VariantFilter;
|
use WerkraumMedia\ABTest\TCA\VariantFilter;
|
||||||
|
|
||||||
return static function (ContainerConfigurator $containerConfigurator) {
|
return static function (ContainerConfigurator $containerConfigurator) {
|
||||||
|
@ -18,6 +20,10 @@ return static function (ContainerConfigurator $containerConfigurator) {
|
||||||
|
|
||||||
$services->load('WerkraumMedia\\ABTest\\', '../Classes/');
|
$services->load('WerkraumMedia\\ABTest\\', '../Classes/');
|
||||||
|
|
||||||
$services->set(Switcher::class)->public();
|
$services->set(TypoScriptFrontendController::class)->public();
|
||||||
$services->set(VariantFilter::class)->public();
|
$services->set(VariantFilter::class)->public();
|
||||||
|
$services->set(SetCookie::class)->tag('event.listener', [
|
||||||
|
'method' => 'handleVariant',
|
||||||
|
'event' => SwitchedToVariant::class,
|
||||||
|
]);
|
||||||
};
|
};
|
||||||
|
|
|
@ -21,3 +21,8 @@ Additional header information may be specified both for the original version as
|
||||||
|
|
||||||
![Demo](https://raw.githubusercontent.com/werkraum-media/abtest/master/Documentation/Images/demo.gif)
|
![Demo](https://raw.githubusercontent.com/werkraum-media/abtest/master/Documentation/Images/demo.gif)
|
||||||
|
|
||||||
|
### Known issues
|
||||||
|
|
||||||
|
This extension currently does not support typeNum.
|
||||||
|
|
||||||
|
It always checks requested page for a variant.
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
"pages",,,,,,,,,,,,,,
|
"pages"
|
||||||
,"uid","pid","slug","title",tx_abtest_variant,hidden,tx_abtest_cookie_time,,,,,,,
|
,"uid","pid","slug","title",tx_abtest_variant,hidden,tx_abtest_cookie_time
|
||||||
,1,0,"/","Page 1 Title (No Variant)",0,0,604800,,,,,,,
|
,1,0,"/","Page 1 Title (No Variant)",0,0,604800
|
||||||
,2,1,"/page-2","Page 2 Title (Variant A)",3,0,604800,,,,,,,
|
,2,1,"/page-2","Page 2 Title (Variant A)",3,0,604800
|
||||||
,3,1,"/page-3","Page 3 Title (Variant B)",0,0,604800,,,,,,,
|
,3,1,"/page-3","Page 3 Title (Variant B)",0,0,604800
|
||||||
,4,1,"/page-4","Page 4 Title (Variant A)",5,0,2419200,,,,,,,
|
,4,1,"/page-4","Page 4 Title (Variant A)",5,0,2419200
|
||||||
,5,1,"/page-5","Page 5 Title (Variant B)",0,1,604800,,,,,,,
|
,5,1,"/page-5","Page 5 Title (Variant B)",0,1,604800
|
||||||
"sys_template",,,,,,,,,,,,,,
|
"sys_template"
|
||||||
,"uid","pid","root","clear","constants","config",,,,,,,,
|
,"uid","pid","root","clear","constants","config"
|
||||||
,1,1,1,3,"databasePlatform = mysql","<INCLUDE_TYPOSCRIPT: source=""FILE:EXT:abtest/Tests/Fixtures/FrontendRendering.typoscript"">",,,,,,,,
|
,1,1,1,3,"databasePlatform = mysql","<INCLUDE_TYPOSCRIPT: source=""FILE:EXT:abtest/Tests/Fixtures/FrontendRendering.typoscript"">"
|
||||||
|
|
Can't render this file because it contains an unexpected character in line 2 and column 2.
|
|
@ -54,12 +54,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
{
|
{
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(1);
|
$request = $request->withPageId(1);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertSame('', $result->getHeaderLine('Set-Cookie'));
|
self::assertSame('', $response->getHeaderLine('Set-Cookie'));
|
||||||
self::assertStringContainsString('Page 1 Title (No Variant)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 1 Title (No Variant)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCounterOfPage(1, 0);
|
$this->assertCounterOfPage(1, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,12 +70,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
{
|
{
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCookie($result, 'ab-2', '2');
|
$this->assertCookie($response, 'ab-2', '2');
|
||||||
$this->assertCounterOfPage(2, 1);
|
$this->assertCounterOfPage(2, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -88,12 +88,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
|
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 3 Title (Variant B)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 3 Title (Variant B)', $response->getBody()->__toString());
|
||||||
$this->assertCookie($result, 'ab-2', '3');
|
$this->assertCookie($response, 'ab-2', '3');
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCounterOfPage(2, 1);
|
$this->assertCounterOfPage(2, 1);
|
||||||
$this->assertCounterOfPage(3, 1);
|
$this->assertCounterOfPage(3, 1);
|
||||||
}
|
}
|
||||||
|
@ -108,12 +108,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-2=2');
|
$request = $request->withAddedHeader('Cookie', 'ab-2=2');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsCached($result);
|
$this->assertPageIsCached($response);
|
||||||
$this->assertCookie($result, 'ab-2', '2');
|
$this->assertCookie($response, 'ab-2', '2');
|
||||||
// 1 from first visit, but not 2 as 2nd visit is via cookie.
|
// 1 from first visit, but not 2 as 2nd visit is via cookie.
|
||||||
$this->assertCounterOfPage(2, 1, 'Opening from cookie should not increase counter.');
|
$this->assertCounterOfPage(2, 1, 'Opening from cookie should not increase counter.');
|
||||||
$this->assertCounterOfPage(3, 0, 'Opening from cookie should not increase counter.');
|
$this->assertCounterOfPage(3, 0, 'Opening from cookie should not increase counter.');
|
||||||
|
@ -127,12 +127,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('User-Agent', 'Storebot-Google');
|
$request = $request->withAddedHeader('User-Agent', 'Storebot-Google');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCookieWasNotSet($result);
|
$this->assertCookieWasNotSet($response);
|
||||||
$this->assertCounterOfPage(2, 0);
|
$this->assertCounterOfPage(2, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,12 +144,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(4);
|
$request = $request->withPageId(4);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-4=5');
|
$request = $request->withAddedHeader('Cookie', 'ab-4=5');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 4 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 4 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCookie($result, 'ab-4', '4');
|
$this->assertCookie($response, 'ab-4', '4');
|
||||||
$this->assertCounterOfPage(4, 1);
|
$this->assertCounterOfPage(4, 1);
|
||||||
$this->assertCounterOfPage(5, 0);
|
$this->assertCounterOfPage(5, 0);
|
||||||
}
|
}
|
||||||
|
@ -162,12 +162,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-2=5');
|
$request = $request->withAddedHeader('Cookie', 'ab-2=5');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCookie($result, 'ab-2', '2');
|
$this->assertCookie($response, 'ab-2', '2');
|
||||||
$this->assertCounterOfPage(2, 1);
|
$this->assertCounterOfPage(2, 1);
|
||||||
$this->assertCounterOfPage(5, 0);
|
$this->assertCounterOfPage(5, 0);
|
||||||
}
|
}
|
||||||
|
@ -182,12 +182,12 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-2=5');
|
$request = $request->withAddedHeader('Cookie', 'ab-2=5');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
self::assertStringContainsString('Page 3 Title (Variant B)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 3 Title (Variant B)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
$this->assertCookie($result, 'ab-2', '3');
|
$this->assertCookie($response, 'ab-2', '3');
|
||||||
$this->assertCounterOfPage(2, 1);
|
$this->assertCounterOfPage(2, 1);
|
||||||
$this->assertCounterOfPage(3, 1);
|
$this->assertCounterOfPage(3, 1);
|
||||||
}
|
}
|
||||||
|
@ -199,10 +199,10 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
{
|
{
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
$cookie = Cookie::fromString($result->getHeaderLine('Set-Cookie'));
|
$cookie = Cookie::fromString($response->getHeaderLine('Set-Cookie'));
|
||||||
self::assertSame(604800, $cookie->getMaxAge());
|
self::assertSame(604800, $cookie->getMaxAge());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -213,10 +213,10 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
{
|
{
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(4);
|
$request = $request->withPageId(4);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
|
|
||||||
self::assertSame(200, $result->getStatusCode());
|
self::assertSame(200, $response->getStatusCode());
|
||||||
$cookie = Cookie::fromString($result->getHeaderLine('Set-Cookie'));
|
$cookie = Cookie::fromString($response->getHeaderLine('Set-Cookie'));
|
||||||
self::assertSame(2419200, $cookie->getMaxAge());
|
self::assertSame(2419200, $cookie->getMaxAge());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,29 +232,29 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
{
|
{
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
|
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-2=2');
|
$request = $request->withAddedHeader('Cookie', 'ab-2=2');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
self::assertStringContainsString('Page 2 Title (Variant A)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 2 Title (Variant A)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsCached($result);
|
$this->assertPageIsCached($response);
|
||||||
|
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
self::assertStringContainsString('Page 3 Title (Variant B)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 3 Title (Variant B)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsNotCached($result);
|
$this->assertPageIsNotCached($response);
|
||||||
|
|
||||||
$request = new InternalRequest();
|
$request = new InternalRequest();
|
||||||
$request = $request->withPageId(2);
|
$request = $request->withPageId(2);
|
||||||
$request = $request->withAddedHeader('Cookie', 'ab-2=3');
|
$request = $request->withAddedHeader('Cookie', 'ab-2=3');
|
||||||
$result = $this->executeFrontendRequest($request);
|
$response = $this->executeFrontendRequest($request);
|
||||||
self::assertStringContainsString('Page 3 Title (Variant B)', $result->getBody()->__toString());
|
self::assertStringContainsString('Page 3 Title (Variant B)', $response->getBody()->__toString());
|
||||||
$this->assertPageIsCached($result);
|
$this->assertPageIsCached($response);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function assertCounterOfPage(
|
private function assertCounterOfPage(
|
||||||
|
@ -276,11 +276,11 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
}
|
}
|
||||||
|
|
||||||
private function assertCookie(
|
private function assertCookie(
|
||||||
InternalResponse $result,
|
InternalResponse $response,
|
||||||
string $name,
|
string $name,
|
||||||
string $value
|
string $value
|
||||||
): void {
|
): void {
|
||||||
$cookie = Cookie::fromString($result->getHeaderLine('Set-Cookie'));
|
$cookie = Cookie::fromString($response->getHeaderLine('Set-Cookie'));
|
||||||
self::assertSame($name, $cookie->getName());
|
self::assertSame($name, $cookie->getName());
|
||||||
self::assertSame($value, $cookie->getValue());
|
self::assertSame($value, $cookie->getValue());
|
||||||
self::assertSame('/', $cookie->getPath());
|
self::assertSame('/', $cookie->getPath());
|
||||||
|
@ -288,22 +288,22 @@ class FrontendRenderingTest extends FunctionalTestCase
|
||||||
self::assertNull($cookie->getDomain());
|
self::assertNull($cookie->getDomain());
|
||||||
}
|
}
|
||||||
|
|
||||||
private function assertCookieWasNotSet(InternalResponse $result): void
|
private function assertCookieWasNotSet(InternalResponse $response): void
|
||||||
{
|
{
|
||||||
self::assertSame(
|
self::assertSame(
|
||||||
'',
|
'',
|
||||||
$result->getHeaderLine('Set-Cookie'),
|
$response->getHeaderLine('Set-Cookie'),
|
||||||
'Cookie was set but was not expected to be set.'
|
'Cookie was set but was not expected to be set.'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function assertPageIsNotCached(InternalResponse $result): void
|
private function assertPageIsNotCached(InternalResponse $response): void
|
||||||
{
|
{
|
||||||
self::assertSame('', $result->getHeaderLine('X-TYPO3-Debug-Cache'));
|
self::assertSame('', $response->getHeaderLine('X-TYPO3-Debug-Cache'));
|
||||||
}
|
}
|
||||||
|
|
||||||
private function assertPageIsCached(InternalResponse $result): void
|
private function assertPageIsCached(InternalResponse $response): void
|
||||||
{
|
{
|
||||||
self::assertStringStartsWith('Cached page generated', $result->getHeaderLine('X-TYPO3-Debug-Cache'));
|
self::assertStringStartsWith('Cached page generated', $response->getHeaderLine('X-TYPO3-Debug-Cache'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,4 +2,4 @@
|
||||||
|
|
||||||
defined('TYPO3_MODE') or die();
|
defined('TYPO3_MODE') or die();
|
||||||
|
|
||||||
\WerkraumMedia\ABTest\Switcher::register();
|
\WerkraumMedia\ABTest\Hook\TypoScriptFrontendController::register();
|
||||||
|
|
Loading…
Reference in a new issue