EventTest.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. <?php
  2. /*
  3. * This file is part of the symfony package.
  4. * (c) Fabien Potencier <fabien.potencier@symfony-project.com>
  5. *
  6. * For the full copyright and license information, please view the LICENSE
  7. * file that was distributed with this source code.
  8. */
  9. require_once __DIR__.'/../../../bootstrap.php';
  10. use Symfony\Components\EventDispatcher\Event;
  11. $t = new LimeTest(16);
  12. $subject = new stdClass();
  13. $parameters = array('foo' => 'bar');
  14. $event = new Event($subject, 'name', $parameters);
  15. // ->getSubject()
  16. $t->diag('->getSubject()');
  17. $t->is($event->getSubject(), $subject, '->getSubject() returns the event subject');
  18. // ->getName()
  19. $t->diag('->getName()');
  20. $t->is($event->getName(), 'name', '->getName() returns the event name');
  21. // ->getParameters() ->setParameter() ->hasParameter() ->getParameter()
  22. $t->diag('->getParameters()');
  23. $t->is($event->getParameters(), $parameters, '->getParameters() returns the event parameters');
  24. $t->is($event->getParameter('foo'), 'bar', '->getParameter() returns the value of a parameter');
  25. $event->setParameter('foo', 'foo');
  26. $t->is($event->getParameter('foo'), 'foo', '->setParameter() changes the value of a parameter');
  27. $t->ok($event->hasParameter('foo'), '->hasParameter() returns true if the parameter is defined');
  28. unset($event['foo']);
  29. $t->ok(!$event->hasParameter('foo'), '->hasParameter() returns false if the parameter is not defined');
  30. try
  31. {
  32. $event->getParameter('foobar');
  33. $t->fail('->getParameter() throws an \InvalidArgumentException exception when the parameter does not exist');
  34. }
  35. catch (\InvalidArgumentException $e)
  36. {
  37. $t->pass('->getParameter() throws an \InvalidArgumentException exception when the parameter does not exist');
  38. }
  39. $event = new Event($subject, 'name', $parameters);
  40. // ->getReturnValue() ->setReturnValue()
  41. $t->diag('->getReturnValue() ->setReturnValue()');
  42. $event->setReturnValue('foo');
  43. $t->is($event->getReturnValue(), 'foo', '->getReturnValue() returns the return value of the event');
  44. // ->setProcessed() ->isProcessed()
  45. $t->diag('->setProcessed() ->isProcessed()');
  46. $event->setProcessed(true);
  47. $t->is($event->isProcessed(), true, '->isProcessed() returns true if the event has been processed');
  48. $event->setProcessed(false);
  49. $t->is($event->isProcessed(), false, '->setProcessed() changes the processed status');
  50. // ArrayAccess interface
  51. $t->diag('ArrayAccess interface');
  52. $t->is($event['foo'], 'bar', 'Event implements the ArrayAccess interface');
  53. $event['foo'] = 'foo';
  54. $t->is($event['foo'], 'foo', 'Event implements the ArrayAccess interface');
  55. try
  56. {
  57. $event['foobar'];
  58. $t->fail('::offsetGet() throws an \InvalidArgumentException exception when the parameter does not exist');
  59. }
  60. catch (\InvalidArgumentException $e)
  61. {
  62. $t->pass('::offsetGet() throws an \InvalidArgumentException exception when the parameter does not exist');
  63. }
  64. $t->ok(isset($event['foo']), 'Event implements the ArrayAccess interface');
  65. unset($event['foo']);
  66. $t->ok(!isset($event['foo']), 'Event implements the ArrayAccess interface');