1
0
mirror of https://github.com/Seldaek/monolog.git synced 2025-08-09 06:36:46 +02:00

Fixes microsecond timezone support, fixes #832

This commit is contained in:
Jordi Boggiano
2016-09-18 18:44:44 +02:00
parent ec945b60d4
commit 89683faff3
2 changed files with 59 additions and 2 deletions

View File

@@ -494,6 +494,56 @@ class LoggerTest extends \PHPUnit_Framework_TestCase
);
}
/**
* @covers Monolog\Logger::setTimezone
* @covers Monolog\DateTimeImmutable::__construct
*/
public function testTimezoneIsRespectedInUTC()
{
foreach ([true, false] as $microseconds) {
$logger = new Logger('foo');
$logger->useMicrosecondTimestamps($microseconds);
$tz = new \DateTimeZone('America/New_York');
$logger->setTimezone($tz);
$handler = new TestHandler;
$logger->pushHandler($handler);
$dt = new \DateTime('now', $tz);
$logger->info('test');
list($record) = $handler->getRecords();
$this->assertEquals($tz, $record['datetime']->getTimezone());
$this->assertEquals($dt->format('Y/m/d H:i'), $record['datetime']->format('Y/m/d H:i'), 'Time should match timezone with microseconds set to: '.var_export($microseconds, true));
}
}
/**
* @covers Monolog\Logger::setTimezone
* @covers Monolog\DateTimeImmutable::__construct
*/
public function testTimezoneIsRespectedInOtherTimezone()
{
date_default_timezone_set('CET');
foreach ([true, false] as $microseconds) {
$logger = new Logger('foo');
$logger->useMicrosecondTimestamps($microseconds);
$tz = new \DateTimeZone('America/New_York');
$logger->setTimezone($tz);
$handler = new TestHandler;
$logger->pushHandler($handler);
$dt = new \DateTime('now', $tz);
$logger->info('test');
list($record) = $handler->getRecords();
$this->assertEquals($tz, $record['datetime']->getTimezone());
$this->assertEquals($dt->format('Y/m/d H:i'), $record['datetime']->format('Y/m/d H:i'), 'Time should match timezone with microseconds set to: '.var_export($microseconds, true));
}
}
public function tearDown()
{
date_default_timezone_set('UTC');
}
/**
* @dataProvider useMicrosecondTimestampsProvider
* @covers Monolog\Logger::useMicrosecondTimestamps