|
2 | 2 |
|
3 | 3 | namespace Nuxtifyts\PhpDto\Tests\Unit\Support; |
4 | 4 |
|
5 | | -use Nuxtifyts\PhpDto\Serializers\BackedEnumSerializer; |
6 | | -use Nuxtifyts\PhpDto\Serializers\ScalarTypeSerializer; |
7 | | -use Nuxtifyts\PhpDto\Serializers\Serializer; |
| 5 | +use InvalidArgumentException; |
8 | 6 | use Nuxtifyts\PhpDto\Support\Arr; |
| 7 | +use PHPUnit\Framework\Attributes\Test; |
9 | 8 | use Nuxtifyts\PhpDto\Tests\Unit\UnitCase; |
| 9 | +use PHPUnit\Framework\Attributes\UsesClass; |
| 10 | +use Nuxtifyts\PhpDto\Serializers\Serializer; |
10 | 11 | use PHPUnit\Framework\Attributes\CoversClass; |
11 | 12 | use PHPUnit\Framework\Attributes\DataProvider; |
12 | | -use PHPUnit\Framework\Attributes\Test; |
| 13 | +use Nuxtifyts\PhpDto\Serializers\BackedEnumSerializer; |
| 14 | +use Nuxtifyts\PhpDto\Serializers\ScalarTypeSerializer; |
| 15 | +use Nuxtifyts\PhpDto\Tests\Dummies\Enums\YesNoBackedEnum; |
| 16 | +use Nuxtifyts\PhpDto\Tests\Dummies\Enums\ColorsBackedEnum; |
13 | 17 |
|
14 | 18 | #[CoversClass(Arr::class)] |
| 19 | +#[UsesClass(YesNoBackedEnum::class)] |
| 20 | +#[UsesClass(ColorsBackedEnum::class)] |
15 | 21 | final class ArrTest extends UnitCase |
16 | 22 | { |
17 | 23 | /** |
@@ -254,9 +260,59 @@ public static function get_arr_provider(): array |
254 | 260 | ], |
255 | 261 | null, |
256 | 262 | ], |
| 263 | + 'get backed enum or null, invalid value' => [ |
| 264 | + 'getBackedEnumOrNull', |
| 265 | + [ |
| 266 | + 'array' => ['key' => 'invalid'], |
| 267 | + 'key' => 'key', |
| 268 | + 'enumClass' => YesNoBackedEnum::class, |
| 269 | + ], |
| 270 | + null |
| 271 | + ], |
| 272 | + 'get backed enum or null, invalid value default provided' => [ |
| 273 | + 'getBackedEnumOrNull', |
| 274 | + [ |
| 275 | + 'array' => ['key' => 'invalid'], |
| 276 | + 'key' => 'key', |
| 277 | + 'enumClass' => YesNoBackedEnum::class, |
| 278 | + 'default' => YesNoBackedEnum::NO, |
| 279 | + ], |
| 280 | + YesNoBackedEnum::NO |
| 281 | + ], |
| 282 | + 'get backed enum or null, valid backed enum value' => [ |
| 283 | + 'getBackedEnumOrNull', |
| 284 | + [ |
| 285 | + 'array' => ['key' => YesNoBackedEnum::YES], |
| 286 | + 'key' => 'key', |
| 287 | + 'enumClass' => YesNoBackedEnum::class, |
| 288 | + ], |
| 289 | + YesNoBackedEnum::YES |
| 290 | + ], |
| 291 | + 'get backed enum or null, valid string value' => [ |
| 292 | + 'getBackedEnumOrNull', |
| 293 | + [ |
| 294 | + 'array' => ['key' => 'yes'], |
| 295 | + 'key' => 'key', |
| 296 | + 'enumClass' => YesNoBackedEnum::class, |
| 297 | + ], |
| 298 | + YesNoBackedEnum::YES |
| 299 | + ] |
257 | 300 | ]; |
258 | 301 | } |
259 | 302 |
|
| 303 | + #[Test] |
| 304 | + public function get_backed_enum_or_null_will_throw_an_exception_if_default_value_is_invalid(): void |
| 305 | + { |
| 306 | + self::expectException(InvalidArgumentException::class); |
| 307 | + |
| 308 | + Arr::getBackedEnumOrNull( |
| 309 | + ['key' => 'invalid'], |
| 310 | + 'key', |
| 311 | + YesNoBackedEnum::class, |
| 312 | + ColorsBackedEnum::RED |
| 313 | + ); |
| 314 | + } |
| 315 | + |
260 | 316 | /** |
261 | 317 | * @return array<string, mixed> |
262 | 318 | */ |
|
0 commit comments