| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- <?php
- namespace Nekonomokochan\Tests\Logger;
- use Nekonomokochan\PhpJsonLogger\LoggerBuilder;
- use PHPUnit\Framework\TestCase;
- /**
- * Class InfoTest
- *
- * @package Nekonomokochan\Tests\Logger
- * @see \Nekonomokochan\PhpJsonLogger\Logger::info
- */
- class InfoTest extends TestCase
- {
- /**
- * @var string
- */
- private $outputFileBaseName;
- /**
- * @var string
- */
- private $outputFileName;
- /**
- * Delete the log file used last time to test the contents of the log file
- */
- public function setUp()
- {
- parent::setUp();
- $this->outputFileBaseName = '/tmp/info-log-test.log';
- $this->outputFileName = '/tmp/info-log-test-' . date('Y-m-d') . '.log';
- if (file_exists($this->outputFileName)) {
- unlink($this->outputFileName);
- }
- }
- /**
- * @test
- */
- public function outputInfoLog()
- {
- $context = [
- 'title' => 'Test',
- 'price' => 4000,
- 'list' => [1, 2, 3],
- 'user' => [
- 'id' => 100,
- 'name' => 'keitakn',
- ],
- ];
- $loggerBuilder = new LoggerBuilder();
- $loggerBuilder->setFileName($this->outputFileBaseName);
- $logger = $loggerBuilder->build();
- $logger->info('🐱', $context);
- $resultJson = file_get_contents($this->outputFileName);
- $resultArray = json_decode($resultJson, true);
- echo "\n ---- Output Log Begin ---- \n";
- echo json_encode($resultArray, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT);
- echo "\n ---- Output Log End ---- \n";
- $expectedLog = [
- 'log_level' => 'INFO',
- 'message' => '🐱',
- 'channel' => 'PhpJsonLogger',
- 'trace_id' => $logger->getTraceId(),
- 'file' => __FILE__,
- 'line' => 57,
- 'context' => $context,
- 'remote_ip_address' => '127.0.0.1',
- 'server_ip_address' => '127.0.0.1',
- 'user_agent' => 'unknown',
- 'datetime' => $resultArray['datetime'],
- 'timezone' => date_default_timezone_get(),
- 'process_time' => $resultArray['process_time'],
- ];
- $this->assertSame('PhpJsonLogger', $logger->getChannel());
- $this->assertSame($expectedLog, $resultArray);
- }
- }
|