Skip to content

Commit

Permalink
➕ add compat for TYPO3 13
Browse files Browse the repository at this point in the history
  • Loading branch information
Kanti committed Aug 1, 2024
1 parent 59445ff commit efe7c9d
Show file tree
Hide file tree
Showing 17 changed files with 428 additions and 146 deletions.
9 changes: 8 additions & 1 deletion .github/workflows/tasks.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,15 @@ jobs:
fail-fast: false
matrix:
php: [ '8.1', '8.2', '8.3' ]
typo3: [ '11', '12' ]
typo3: [ '11', '12', '13' ]
sentry: [ false, true ]
exclude:
- php: '8.1'
typo3: '13'
sentry: true
- php: '8.1'
typo3: '13'
sentry: false
steps:
- name: Setup PHP with PECL extension
uses: shivammathur/setup-php@v2
Expand Down
2 changes: 1 addition & 1 deletion Classes/DataProcessor/TrackingDataProcessor.php
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ final class TrackingDataProcessor implements DataProcessorInterface, SingletonIn
* @param array<array-key, mixed> $processedData
* @return array<array-key, mixed>
*/
public function process(ContentObjectRenderer $cObj, array $contentObjectConfiguration, array $processorConfiguration, array $processedData)
public function process(ContentObjectRenderer $cObj, array $contentObjectConfiguration, array $processorConfiguration, array $processedData): array
{
$id = (string)$processorConfiguration['id'];
$stopWatch = $this->stopWatches[$id] ?? null;
Expand Down
19 changes: 17 additions & 2 deletions Classes/ServiceProvider.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

namespace Kanti\ServerTiming;

use Closure;
use Kanti\ServerTiming\Middleware\XClassMiddlewareDispatcher;
use Psr\Container\ContainerInterface;
use TYPO3\CMS\Backend\Http\Application as ApplicationBE;
Expand All @@ -18,7 +19,7 @@

final class ServiceProvider extends AbstractServiceProvider
{
public static function getPackagePath(): string
protected static function getPackagePath(): string
{
return __DIR__ . '/../';
}
Expand All @@ -29,7 +30,7 @@ public static function getPackageName(): string
}

/**
* @return array<string, \Closure>
* @return array<string, Closure>
*/
public function getFactories(): array
{
Expand All @@ -46,6 +47,13 @@ public static function getApplicationFE(ContainerInterface $container): Applicat
$container->get('frontend.middlewares'),
$container,
);
if (version_compare((new Typo3Version())->getBranch(), '13.0', '>=')) {
return new ApplicationFE(
$requestHandler,
$container->get(Context::class),
);
}

if (version_compare((new Typo3Version())->getBranch(), '12.0', '>=') && class_exists(BackendEntryPointResolver::class)) {
return new ApplicationFE(
$requestHandler,
Expand All @@ -69,6 +77,13 @@ public static function getApplicationBE(ContainerInterface $container): Applicat
$container->get('backend.middlewares'),
$container,
);
if (version_compare((new Typo3Version())->getBranch(), '13.0', '>=')) {
return new ApplicationBE(
$requestHandler,
$container->get(Context::class),
);
}

if (version_compare((new Typo3Version())->getBranch(), '12.0', '>=') && class_exists(BackendEntryPointResolver::class)) {
return new ApplicationBE(
$requestHandler,
Expand Down
79 changes: 39 additions & 40 deletions Classes/SqlLogging/LoggingConnection.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,43 +6,42 @@

namespace Kanti\ServerTiming\SqlLogging;

//
//use Doctrine\DBAL\Driver\Connection as ConnectionInterface;
//use Doctrine\DBAL\Driver\Middleware\AbstractConnectionMiddleware;
//use Doctrine\DBAL\Driver\Result;
//use Doctrine\DBAL\Driver\Statement as DriverStatement;
//
//if (!class_exists(AbstractConnectionMiddleware::class)) {
// return;
//}
//
//final class LoggingConnection extends AbstractConnectionMiddleware
//{
// public function __construct(ConnectionInterface $connection, private readonly DoctrineSqlLogger $logger)
// {
// parent::__construct($connection);
// }
//
// public function prepare(string $sql): DriverStatement
// {
// return new LoggingStatement(parent::prepare($sql), $this->logger, $sql);
// }
//
// public function query(string $sql): Result
// {
// $this->logger->startQuery($sql);
// $query = parent::query($sql);
// $this->logger->stopQuery();
//
// return $query;
// }
//
// public function exec(string $sql): int
// {
// $this->logger->startQuery($sql);
// $query = parent::exec($sql);
// $this->logger->stopQuery();
//
// return $query;
// }
//}
use Doctrine\DBAL\Driver\Connection as ConnectionInterface;
use Doctrine\DBAL\Driver\Middleware\AbstractConnectionMiddleware;
use Doctrine\DBAL\Driver\Result;
use Doctrine\DBAL\Driver\Statement as DriverStatement;

if (!class_exists(AbstractConnectionMiddleware::class)) {
return;
}

final class LoggingConnection extends AbstractConnectionMiddleware
{
public function __construct(ConnectionInterface $connection, private readonly DoctrineSqlLogger $logger)
{
parent::__construct($connection);
}

public function prepare(string $sql): DriverStatement
{
return new LoggingStatement(parent::prepare($sql), $this->logger, $sql);
}

public function query(string $sql): Result
{
$this->logger->startQuery($sql);
$query = parent::query($sql);
$this->logger->stopQuery();

return $query;
}

public function exec(string $sql): int
{
$this->logger->startQuery($sql);
$query = parent::exec($sql);
$this->logger->stopQuery();

return (int)$query;
}
}
40 changes: 19 additions & 21 deletions Classes/SqlLogging/LoggingDriver.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,24 +6,22 @@

namespace Kanti\ServerTiming\SqlLogging;

//
//use Doctrine\DBAL\Driver as DriverInterface;
//use Doctrine\DBAL\Driver\Middleware\AbstractConnectionMiddleware;
//use Doctrine\DBAL\Driver\Middleware\AbstractDriverMiddleware;
//
//if (!class_exists(AbstractDriverMiddleware::class)) {
// return;
//}
//
//final class LoggingDriver extends AbstractDriverMiddleware
//{
// public function __construct(DriverInterface $driver, private readonly DoctrineSqlLogger $logger)
// {
// parent::__construct($driver);
// }
//
// public function connect(array $params)
// {
// return new LoggingConnection(parent::connect($params), $this->logger);
// }
//}
use Doctrine\DBAL\Driver as DriverInterface;
use Doctrine\DBAL\Driver\Middleware\AbstractDriverMiddleware;

if (!class_exists(AbstractDriverMiddleware::class)) {
return;
}

final class LoggingDriver extends AbstractDriverMiddleware
{
public function __construct(DriverInterface $driver, private readonly DoctrineSqlLogger $logger)
{
parent::__construct($driver);
}

public function connect(array $params): DriverInterface\Connection
{
return new LoggingConnection(parent::connect($params), $this->logger);
}
}
31 changes: 15 additions & 16 deletions Classes/SqlLogging/LoggingMiddleware.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,19 +6,18 @@

namespace Kanti\ServerTiming\SqlLogging;

//
//use Doctrine\DBAL\Driver as DriverInterface;
//use Doctrine\DBAL\Driver\Middleware as MiddlewareInterface;
//use Doctrine\DBAL\Driver\Middleware\AbstractDriverMiddleware;
//
//if (!interface_exists(MiddlewareInterface::class)) {
// return;
//}
//
//final class LoggingMiddleware implements MiddlewareInterface
//{
// public function wrap(DriverInterface $driver): DriverInterface
// {
// return new LoggingDriver($driver, new DoctrineSqlLogger());
// }
//}
use Doctrine\DBAL\Driver as DriverInterface;
use Doctrine\DBAL\Driver\Middleware as MiddlewareInterface;
use Doctrine\DBAL\Driver\Middleware\AbstractDriverMiddleware;

if (!interface_exists(MiddlewareInterface::class)) {
return;
}

final class LoggingMiddleware implements MiddlewareInterface
{
public function wrap(DriverInterface $driver): DriverInterface
{
return new LoggingDriver($driver, new DoctrineSqlLogger());
}
}
49 changes: 24 additions & 25 deletions Classes/SqlLogging/LoggingStatement.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,28 +6,27 @@

namespace Kanti\ServerTiming\SqlLogging;

//
//use Doctrine\DBAL\Driver\Middleware\AbstractStatementMiddleware;
//use Doctrine\DBAL\Driver\Result as ResultInterface;
//use Doctrine\DBAL\Driver\Statement as StatementInterface;
//
//if (!class_exists(AbstractStatementMiddleware::class)) {
// return;
//}
//
//final class LoggingStatement extends AbstractStatementMiddleware
//{
// public function __construct(StatementInterface $statement, private readonly DoctrineSqlLogger $logger, private readonly string $sql)
// {
// parent::__construct($statement);
// }
//
// public function execute($params = null): ResultInterface
// {
// $this->logger->startQuery($this->sql);
// $result = parent::execute($params);
// $this->logger->stopQuery();
//
// return $result;
// }
//}
use Doctrine\DBAL\Driver\Middleware\AbstractStatementMiddleware;
use Doctrine\DBAL\Driver\Result as ResultInterface;
use Doctrine\DBAL\Driver\Statement as StatementInterface;

if (!class_exists(AbstractStatementMiddleware::class)) {
return;
}

final class LoggingStatement extends AbstractStatementMiddleware
{
public function __construct(StatementInterface $statement, private readonly DoctrineSqlLogger $logger, private readonly string $sql)
{
parent::__construct($statement);
}

public function execute($params = null): ResultInterface
{
$this->logger->startQuery($this->sql);
$result = parent::execute($params);
$this->logger->stopQuery();

return $result;
}
}
5 changes: 5 additions & 0 deletions Classes/SqlLogging/SqlLoggerCore11.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
use Kanti\ServerTiming\Dto\StopWatch;
use Kanti\ServerTiming\Utility\TimingUtility;
use TYPO3\CMS\Core\Database\ConnectionPool;
use TYPO3\CMS\Core\Information\Typo3Version;
use TYPO3\CMS\Core\Utility\GeneralUtility;

/**
Expand All @@ -20,6 +21,10 @@ final class SqlLoggerCore11
*/
public static function registerSqlLogger(): void
{
if (version_compare((new Typo3Version())->getBranch(), '12.3', '>=')) {
return;
}

$doctrineSqlLogger = new DoctrineSqlLogger();

$connectionPool = GeneralUtility::makeInstance(ConnectionPool::class);
Expand Down
6 changes: 4 additions & 2 deletions Classes/Utility/GuzzleUtility.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@

namespace Kanti\ServerTiming\Utility;

use LogicException;
use Throwable;
use Closure;
use GuzzleHttp\Exception\RequestException as GuzzleRequestException;
use GuzzleHttp\Promise\PromiseInterface;
Expand All @@ -28,7 +30,7 @@ public static function getHandler(): ?Closure
return static fn(callable $handler): Closure => static function (RequestInterface $request, array $options) use ($handler): PromiseInterface {
try {
GeneralUtility::getContainer();
} catch (\LogicException) {
} catch (LogicException) {
// container not found:
// than we are most likely in a subprocess (spatie/async)
// and we don't want to initialize the container here!
Expand All @@ -52,7 +54,7 @@ public static function getHandler(): ?Closure
$stop->info = $request->getMethod() . ' ' . $response->getStatusCode() . ' ' . $request->getUri()->__toString();
}

if ($responseOrException instanceof \Throwable) {
if ($responseOrException instanceof Throwable) {
throw $responseOrException;
}

Expand Down
33 changes: 30 additions & 3 deletions Classes/Utility/TimingUtility.php
Original file line number Diff line number Diff line change
Expand Up @@ -163,19 +163,23 @@ public function shutdown(ScriptResult $result): ?ResponseInterface
}


$headerString = implode(',', $timings);
if (!$timings) {
return $response;
}

$chunks = $this->chunkStringArray($timings, (2 ** 12) - strlen('Server-Timing: '));

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 3 ** 12 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 11 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "IncrementInteger": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 13 - strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

Check warning on line 170 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Minus": --- Original +++ New @@ @@ if (!$timings) { return $response; } - $chunks = $this->chunkStringArray($timings, 2 ** 12 - strlen('Server-Timing: ')); + $chunks = $this->chunkStringArray($timings, 2 ** 12 + strlen('Server-Timing: ')); $memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage()); if ($response) { return $response->withAddedHeader('Server-Timing', $chunks)->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);

$memoryUsage = $this->humanReadableFileSize(memory_get_peak_usage());
if ($response) {
return $response
->withAddedHeader('Server-Timing', $headerString)
->withAddedHeader('Server-Timing', $chunks)
->withAddedHeader('X-Max-Memory-Usage', $memoryUsage);
}

header('Server-Timing: ' . $headerString, false);
foreach ($chunks as $chunk) {
header('Server-Timing: ' . $chunk, false);
}

header('X-Max-Memory-Usage: ' . $memoryUsage, false);
return $response;
}
Expand Down Expand Up @@ -284,4 +288,27 @@ private function isBackendUser(): bool
{
return (bool)GeneralUtility::makeInstance(Context::class)->getPropertyFromAspect('backend.user', 'isLoggedIn');
}

/**
* @param list<string> $timings
* @return list<string>
*/
private function chunkStringArray(array $timings, int $maxLength): array
{
$result = [];
$length = 0;

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);

Check warning on line 299 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "DecrementInteger": --- Original +++ New @@ @@ private function chunkStringArray(array $timings, int $maxLength) : array { $result = []; - $length = 0; + $length = -1; $index = 0; foreach ($timings as $timing) { $length += strlen(',' . $timing);
$index = 0;
foreach ($timings as $timing) {
$length += strlen(',' . $timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: false

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.1 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.3 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "Concat": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing . ','); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen($timing); if ($length > $maxLength) { $index++; $length = strlen($timing);

Check warning on line 302 in Classes/Utility/TimingUtility.php

View workflow job for this annotation

GitHub Actions / php: 8.2 TYPO3: 11 sentry/sdk: true

Escaped Mutant for Mutator "ConcatOperandRemoval": --- Original +++ New @@ @@ $length = 0; $index = 0; foreach ($timings as $timing) { - $length += strlen(',' . $timing); + $length += strlen(','); if ($length > $maxLength) { $index++; $length = strlen($timing);
if ($length > $maxLength) {
$index++;
$length = strlen($timing);
}

$result[$index] ??= '';
$result[$index] .= ($result[$index] ? ',' : '') . $timing;
}

return $result;
}
}
Loading

0 comments on commit efe7c9d

Please sign in to comment.