123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\EventDispatcher\Tests;
- use PHPUnit\Framework\TestCase;
- use Symfony\Component\EventDispatcher\GenericEvent;
- /**
- * Test class for Event.
- */
- class GenericEventTest extends TestCase
- {
- /**
- * @var GenericEvent
- */
- private $event;
- private $subject;
- /**
- * Prepares the environment before running a test.
- */
- protected function setUp()
- {
- $this->subject = new \stdClass();
- $this->event = new GenericEvent($this->subject, ['name' => 'Event']);
- }
- /**
- * Cleans up the environment after running a test.
- */
- protected function tearDown()
- {
- $this->subject = null;
- $this->event = null;
- }
- public function testConstruct()
- {
- $this->assertEquals($this->event, new GenericEvent($this->subject, ['name' => 'Event']));
- }
- /**
- * Tests Event->getArgs().
- */
- public function testGetArguments()
- {
- // test getting all
- $this->assertSame(['name' => 'Event'], $this->event->getArguments());
- }
- public function testSetArguments()
- {
- $result = $this->event->setArguments(['foo' => 'bar']);
- $this->assertAttributeSame(['foo' => 'bar'], 'arguments', $this->event);
- $this->assertSame($this->event, $result);
- }
- public function testSetArgument()
- {
- $result = $this->event->setArgument('foo2', 'bar2');
- $this->assertAttributeSame(['name' => 'Event', 'foo2' => 'bar2'], 'arguments', $this->event);
- $this->assertEquals($this->event, $result);
- }
- public function testGetArgument()
- {
- // test getting key
- $this->assertEquals('Event', $this->event->getArgument('name'));
- }
- /**
- * @expectedException \InvalidArgumentException
- */
- public function testGetArgException()
- {
- $this->event->getArgument('nameNotExist');
- }
- public function testOffsetGet()
- {
- // test getting key
- $this->assertEquals('Event', $this->event['name']);
- // test getting invalid arg
- $this->{method_exists($this, $_ = 'expectException') ? $_ : 'setExpectedException'}('InvalidArgumentException');
- $this->assertFalse($this->event['nameNotExist']);
- }
- public function testOffsetSet()
- {
- $this->event['foo2'] = 'bar2';
- $this->assertAttributeSame(['name' => 'Event', 'foo2' => 'bar2'], 'arguments', $this->event);
- }
- public function testOffsetUnset()
- {
- unset($this->event['name']);
- $this->assertAttributeSame([], 'arguments', $this->event);
- }
- public function testOffsetIsset()
- {
- $this->assertArrayHasKey('name', $this->event);
- $this->assertArrayNotHasKey('nameNotExist', $this->event);
- }
- public function testHasArgument()
- {
- $this->assertTrue($this->event->hasArgument('name'));
- $this->assertFalse($this->event->hasArgument('nameNotExist'));
- }
- public function testGetSubject()
- {
- $this->assertSame($this->subject, $this->event->getSubject());
- }
- public function testHasIterator()
- {
- $data = [];
- foreach ($this->event as $key => $value) {
- $data[$key] = $value;
- }
- $this->assertEquals(['name' => 'Event'], $data);
- }
- }
|