Skip to content

Commit

Permalink
Merge pull request #1234 from ivoba/fix-DateInterval-milliseconds
Browse files Browse the repository at this point in the history
added support for milliseconds in DateInterval deserialization
  • Loading branch information
goetas authored Jul 12, 2020
2 parents 88be308 + ef8c948 commit 224f380
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 0 deletions.
6 changes: 6 additions & 0 deletions src/Handler/DateHandler.php
Original file line number Diff line number Diff line change
Expand Up @@ -256,7 +256,13 @@ private function parseDateInterval(string $data): \DateInterval
{
$dateInterval = null;
try {
$f = 0.0;
if (preg_match('~\.\d+~', $data, $match)) {
$data = str_replace($match[0], '', $data);
$f = (float) $match[0];
}
$dateInterval = new \DateInterval($data);
$dateInterval->f= $f;
} catch (\Throwable $e) {
throw new RuntimeException(sprintf('Invalid dateinterval "%s", expected ISO 8601 format', $data), 0, $e);
}
Expand Down
29 changes: 29 additions & 0 deletions tests/Handler/DateHandlerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
use JMS\Serializer\Handler\DateHandler;
use JMS\Serializer\JsonDeserializationVisitor;
use JMS\Serializer\SerializationContext;
use JMS\Serializer\Visitor\DeserializationVisitorInterface;
use JMS\Serializer\Visitor\SerializationVisitorInterface;
use PHPUnit\Framework\TestCase;

Expand Down Expand Up @@ -55,6 +56,34 @@ public function testSerializeDate(array $params)
$this->handler->serializeDateTime($visitor, $datetime, $type, $context);
}

/**
* @param string $dateInterval
* @param \DateTime $expected
*
* @dataProvider getDeserializeDateInterval
*/
public function testDeserializeDateInterval($dateInterval, $expected)
{
$context = $this->getMockBuilder(SerializationContext::class)->getMock();

$visitor = $this->getMockBuilder(DeserializationVisitorInterface::class)->getMock();
$visitor->method('visitString')->with('2017-06-18');

$deserialized = $this->handler->deserializeDateIntervalFromJson($visitor, $dateInterval, [], $context);
if (isset($deserialized->f)) {
$this->assertEquals($expected['f'], $deserialized->f);
}
$this->assertEquals($expected['s'], $deserialized->s);
}

public function getDeserializeDateInterval()
{
return [
['P0Y0M0DT3H5M7.520S', ['s' => 7, 'f' => 0.52]],
['P0Y0M0DT3H5M7S', ['s' => 7, 'f' => 0]],
];
}

public function testTimePartGetsRemoved()
{
$visitor = new JsonDeserializationVisitor();
Expand Down

0 comments on commit 224f380

Please sign in to comment.