You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.5 KiB
59 lines
1.5 KiB
<?php declare(strict_types=1);
|
|
/*
|
|
* This file is part of PHPUnit.
|
|
*
|
|
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
namespace PHPUnit\Logging;
|
|
|
|
use const FILE_APPEND;
|
|
use const LOCK_EX;
|
|
use const PHP_EOL;
|
|
use function explode;
|
|
use function file_put_contents;
|
|
use function implode;
|
|
use function str_repeat;
|
|
use function strlen;
|
|
use PHPUnit\Event\Event;
|
|
use PHPUnit\Event\Tracer\Tracer;
|
|
|
|
/**
|
|
* @internal This class is not covered by the backward compatibility promise for PHPUnit
|
|
*/
|
|
final class EventLogger implements Tracer
|
|
{
|
|
private readonly string $path;
|
|
private readonly bool $includeTelemetryInfo;
|
|
|
|
public function __construct(string $path, bool $includeTelemetryInfo)
|
|
{
|
|
$this->path = $path;
|
|
$this->includeTelemetryInfo = $includeTelemetryInfo;
|
|
}
|
|
|
|
public function trace(Event $event): void
|
|
{
|
|
$telemetryInfo = $this->telemetryInfo($event);
|
|
$indentation = PHP_EOL . str_repeat(' ', strlen($telemetryInfo));
|
|
$lines = explode(PHP_EOL, $event->asString());
|
|
|
|
file_put_contents(
|
|
$this->path,
|
|
$telemetryInfo . implode($indentation, $lines) . PHP_EOL,
|
|
FILE_APPEND | LOCK_EX,
|
|
);
|
|
}
|
|
|
|
private function telemetryInfo(Event $event): string
|
|
{
|
|
if (!$this->includeTelemetryInfo) {
|
|
return '';
|
|
}
|
|
|
|
return $event->telemetryInfo()->asString() . ' ';
|
|
}
|
|
}
|