class PluginTest

Same name and namespace in other branches
  1. 9 core/tests/Drupal/Tests/Component/Annotation/PluginTest.php \Drupal\Tests\Component\Annotation\PluginTest
  2. 10 core/tests/Drupal/Tests/Component/Annotation/PluginTest.php \Drupal\Tests\Component\Annotation\PluginTest
  3. 10 core/tests/Drupal/Tests/Component/Plugin/Attribute/PluginTest.php \Drupal\Tests\Component\Plugin\Attribute\PluginTest
  4. 11.x core/tests/Drupal/Tests/Component/Annotation/PluginTest.php \Drupal\Tests\Component\Annotation\PluginTest
  5. 11.x core/tests/Drupal/Tests/Component/Plugin/Attribute/PluginTest.php \Drupal\Tests\Component\Plugin\Attribute\PluginTest

@coversDefaultClass \Drupal\Component\Annotation\Plugin @group Annotation

Hierarchy

  • class \Drupal\Tests\Component\Annotation\PluginTest extends \PHPUnit\Framework\TestCase

Expanded class hierarchy of PluginTest

File

core/tests/Drupal/Tests/Component/Annotation/PluginTest.php, line 12

Namespace

Drupal\Tests\Component\Annotation
View source
class PluginTest extends TestCase {
    
    /**
     * @covers ::__construct
     * @covers ::parse
     * @covers ::get
     */
    public function testGet() {
        // Assert all values are accepted through constructor and default value is
        // used for non existent but defined property.
        $plugin = new PluginStub([
            1 => 'oak',
            'foo' => 'bar',
            'biz' => [
                'baz' => 'boom',
            ],
            'nestedAnnotation' => new Plugin([
                'foo' => 'bar',
            ]),
        ]);
        $this->assertEquals([
            // This property wasn't in our definition but is defined as a property on
            // our plugin class.
'defaultProperty' => 'testvalue',
            1 => 'oak',
            'foo' => 'bar',
            'biz' => [
                'baz' => 'boom',
            ],
            'nestedAnnotation' => [
                'foo' => 'bar',
            ],
        ], $plugin->get());
        // Without default properties, we get a completely empty plugin definition.
        $plugin = new Plugin([]);
        $this->assertEquals([], $plugin->get());
    }
    
    /**
     * @covers ::getProvider
     */
    public function testGetProvider() {
        $plugin = new Plugin([
            'provider' => 'example',
        ]);
        $this->assertEquals('example', $plugin->getProvider());
    }
    
    /**
     * @covers ::setProvider
     */
    public function testSetProvider() {
        $plugin = new Plugin([]);
        $plugin->setProvider('example');
        $this->assertEquals('example', $plugin->getProvider());
    }
    
    /**
     * @covers ::getId
     */
    public function testGetId() {
        $plugin = new Plugin([
            'id' => 'example',
        ]);
        $this->assertEquals('example', $plugin->getId());
    }
    
    /**
     * @covers ::getClass
     */
    public function testGetClass() {
        $plugin = new Plugin([
            'class' => 'example',
        ]);
        $this->assertEquals('example', $plugin->getClass());
    }
    
    /**
     * @covers ::setClass
     */
    public function testSetClass() {
        $plugin = new Plugin([]);
        $plugin->setClass('example');
        $this->assertEquals('example', $plugin->getClass());
    }

}

Members

Title Sort descending Modifiers Object type Summary
PluginTest::testGet public function @covers ::__construct
@covers ::parse
@covers ::get
PluginTest::testGetClass public function @covers ::getClass
PluginTest::testGetId public function @covers ::getId
PluginTest::testGetProvider public function @covers ::getProvider
PluginTest::testSetClass public function @covers ::setClass
PluginTest::testSetProvider public function @covers ::setProvider

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.