From 5147e694f4253e7633e0df6d1bcf76bb5dff7b78 Mon Sep 17 00:00:00 2001 From: Kartvaik Date: Wed, 30 Jan 2019 16:07:46 +0200 Subject: [PATCH] Create instance of enum from same enum in constructor It will prevent incorrect semantic exception message --- src/Enum.php | 6 ++++++ tests/EnumTest.php | 9 +++++++++ 2 files changed, 15 insertions(+) diff --git a/src/Enum.php b/src/Enum.php index d1bc516..aa36c42 100644 --- a/src/Enum.php +++ b/src/Enum.php @@ -40,6 +40,12 @@ abstract class Enum implements \JsonSerializable */ public function __construct($value) { + if ($value instanceof static) { + $this->value = $value->getValue(); + + return; + } + if (!$this->isValid($value)) { throw new \UnexpectedValueException("Value '$value' is not part of the enum " . \get_called_class()); } diff --git a/tests/EnumTest.php b/tests/EnumTest.php index 57f65a3..9591d73 100644 --- a/tests/EnumTest.php +++ b/tests/EnumTest.php @@ -281,6 +281,15 @@ public function testBooleanEnum() $this->assertFalse((new EnumFixture(EnumFixture::PROBLEMATIC_BOOLEAN_FALSE))->jsonSerialize()); } + public function testConstructWithSameEnumArgument() + { + $enum = new EnumFixture(EnumFixture::FOO); + + $enveloped = new EnumFixture($enum); + + $this->assertEquals($enum, $enveloped); + } + private function assertJsonEqualsJson($json1, $json2) { $this->assertJsonStringEqualsJsonString($json1, $json2);