EventDispatcherTraitTest.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. /**
  3. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  4. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  5. *
  6. * Licensed under The MIT License
  7. * Redistributions of files must retain the above copyright notice.
  8. *
  9. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  10. * @link https://cakephp.org CakePHP(tm) Project
  11. * @since 3.0.0
  12. * @license https://opensource.org/licenses/mit-license.php MIT License
  13. */
  14. namespace Cake\Test\TestCase\Event;
  15. use Cake\Event\EventDispatcherTrait;
  16. use Cake\Event\EventManager;
  17. use Cake\TestSuite\TestCase;
  18. /**
  19. * EventDispatcherTrait test case
  20. */
  21. class EventDispatcherTraitTest extends TestCase
  22. {
  23. /**
  24. * @var EventDispatcherTrait
  25. */
  26. public $subject;
  27. /**
  28. * setup
  29. *
  30. * @return void
  31. */
  32. public function setUp()
  33. {
  34. parent::setUp();
  35. $this->subject = $this->getObjectForTrait('Cake\Event\EventDispatcherTrait');
  36. }
  37. /**
  38. * testIsInitiallyEmpty
  39. *
  40. * @return void
  41. */
  42. public function testIsInitiallyEmpty()
  43. {
  44. $this->assertAttributeEmpty('_eventManager', $this->subject);
  45. }
  46. /**
  47. * testEventManager
  48. *
  49. * @return void
  50. */
  51. public function testEventManager()
  52. {
  53. $eventManager = new EventManager();
  54. $this->subject->eventManager($eventManager);
  55. $this->assertSame($eventManager, $this->subject->eventManager());
  56. }
  57. /**
  58. * testGetEventManager
  59. *
  60. * @return void
  61. */
  62. public function testGetEventManager()
  63. {
  64. $this->assertInstanceOf(EventManager::class, $this->subject->getEventManager());
  65. }
  66. /**
  67. * testSetEventManager
  68. *
  69. * @return void
  70. */
  71. public function testSetEventManager()
  72. {
  73. $eventManager = new EventManager();
  74. $this->subject->setEventManager($eventManager);
  75. $this->assertSame($eventManager, $this->subject->getEventManager());
  76. }
  77. /**
  78. * testDispatchEvent
  79. *
  80. * @return void
  81. */
  82. public function testDispatchEvent()
  83. {
  84. $event = $this->subject->dispatchEvent('some.event', ['foo' => 'bar']);
  85. $this->assertInstanceOf('Cake\Event\Event', $event);
  86. $this->assertSame($this->subject, $event->getSubject());
  87. $this->assertEquals('some.event', $event->getName());
  88. $this->assertEquals(['foo' => 'bar'], $event->getData());
  89. }
  90. }