|
7 | 7 | use PHPUnit\Framework\TestCase; |
8 | 8 | use ReflectionClass; |
9 | 9 | use Tempest\Container\Exceptions\CannotAutowireException; |
| 10 | +use Tempest\Container\Exceptions\CannotInstantiateDependencyException; |
10 | 11 | use Tempest\Container\Exceptions\CannotResolveTaggedDependency; |
11 | 12 | use Tempest\Container\Exceptions\CircularDependencyException; |
12 | 13 | use Tempest\Container\Exceptions\InvalidCallableException; |
|
29 | 30 | use Tempest\Container\Tests\Fixtures\ContainerObjectEInitializer; |
30 | 31 | use Tempest\Container\Tests\Fixtures\DependencyWithBuiltinDependencies; |
31 | 32 | use Tempest\Container\Tests\Fixtures\DependencyWithTaggedDependency; |
| 33 | +use Tempest\Container\Tests\Fixtures\ImplementsInterfaceA; |
32 | 34 | use Tempest\Container\Tests\Fixtures\InjectA; |
33 | 35 | use Tempest\Container\Tests\Fixtures\InjectB; |
| 36 | +use Tempest\Container\Tests\Fixtures\InterfaceA; |
34 | 37 | use Tempest\Container\Tests\Fixtures\IntersectionInitializer; |
35 | 38 | use Tempest\Container\Tests\Fixtures\InvokableClass; |
36 | 39 | use Tempest\Container\Tests\Fixtures\InvokableClassWithParameters; |
@@ -390,4 +393,72 @@ public function test_inject(): void |
390 | 393 |
|
391 | 394 | $this->assertInstanceOf(InjectB::class, $a->getB()); |
392 | 395 | } |
| 396 | + |
| 397 | + public function test_unregister(): void |
| 398 | + { |
| 399 | + $container = new GenericContainer(); |
| 400 | + |
| 401 | + $container->register(InterfaceA::class, fn () => new ImplementsInterfaceA()); |
| 402 | + |
| 403 | + $this->assertInstanceOf(ImplementsInterfaceA::class, $container->get(InterfaceA::class)); |
| 404 | + |
| 405 | + $container->unregister(InterfaceA::class); |
| 406 | + |
| 407 | + $this->expectException(CannotInstantiateDependencyException::class); |
| 408 | + |
| 409 | + $container->get(InterfaceA::class); |
| 410 | + } |
| 411 | + |
| 412 | + public function test_unregister_singleton(): void |
| 413 | + { |
| 414 | + $container = new GenericContainer(); |
| 415 | + |
| 416 | + $container->singleton(InterfaceA::class, $instance = new ImplementsInterfaceA()); |
| 417 | + |
| 418 | + $this->assertInstanceOf(ImplementsInterfaceA::class, $container->get(InterfaceA::class)); |
| 419 | + $this->assertSame($instance, $container->get(InterfaceA::class)); |
| 420 | + |
| 421 | + $container->unregister(InterfaceA::class); |
| 422 | + |
| 423 | + $this->expectException(CannotInstantiateDependencyException::class); |
| 424 | + |
| 425 | + $container->get(InterfaceA::class); |
| 426 | + } |
| 427 | + |
| 428 | + public function test_has(): void |
| 429 | + { |
| 430 | + $container = new GenericContainer(); |
| 431 | + |
| 432 | + $this->assertFalse($container->has(InterfaceA::class)); |
| 433 | + |
| 434 | + $container->register(InterfaceA::class, fn () => new ImplementsInterfaceA()); |
| 435 | + |
| 436 | + $this->assertTrue($container->has(InterfaceA::class)); |
| 437 | + } |
| 438 | + |
| 439 | + public function test_has_singleton(): void |
| 440 | + { |
| 441 | + $container = new GenericContainer(); |
| 442 | + |
| 443 | + $this->assertFalse($container->has(InterfaceA::class)); |
| 444 | + |
| 445 | + $container->singleton(InterfaceA::class, new ImplementsInterfaceA()); |
| 446 | + |
| 447 | + $this->assertTrue($container->has(InterfaceA::class)); |
| 448 | + } |
| 449 | + |
| 450 | + public function test_has_tagged_singleton(): void |
| 451 | + { |
| 452 | + $container = new GenericContainer(); |
| 453 | + |
| 454 | + $this->assertFalse($container->has(TaggedDependency::class, 'web')); |
| 455 | + |
| 456 | + $container->singleton( |
| 457 | + TaggedDependency::class, |
| 458 | + new TaggedDependency('web'), |
| 459 | + tag: 'web', |
| 460 | + ); |
| 461 | + |
| 462 | + $this->assertTrue($container->has(TaggedDependency::class, 'web')); |
| 463 | + } |
393 | 464 | } |
0 commit comments