class TagsTest

Same name and namespace in other branches
  1. 8.9.x core/tests/Drupal/Tests/Core/Common/TagsTest.php \Drupal\Tests\Core\Common\TagsTest
  2. 10 core/tests/Drupal/Tests/Core/Common/TagsTest.php \Drupal\Tests\Core\Common\TagsTest
  3. 11.x core/tests/Drupal/Tests/Core/Common/TagsTest.php \Drupal\Tests\Core\Common\TagsTest

Tests explosion and implosion of autocomplete tags.

@group Common

Hierarchy

Expanded class hierarchy of TagsTest

File

core/tests/Drupal/Tests/Core/Common/TagsTest.php, line 13

Namespace

Drupal\Tests\Core\Common
View source
class TagsTest extends UnitTestCase {
    protected $validTags = [
        'Drupal' => 'Drupal',
        'Drupal with some spaces' => 'Drupal with some spaces',
        '"Legendary Drupal mascot of doom: ""Druplicon"""' => 'Legendary Drupal mascot of doom: "Druplicon"',
        '"Drupal, although it rhymes with sloopal, is as awesome as a troopal!"' => 'Drupal, although it rhymes with sloopal, is as awesome as a troopal!',
    ];
    
    /**
     * Explodes a series of tags.
     */
    public function explodeTags() {
        $string = implode(', ', array_keys($this->validTags));
        $tags = Tags::explode($string);
        $this->assertTags($tags);
    }
    
    /**
     * Implodes a series of tags.
     */
    public function testImplodeTags() {
        $tags = array_values($this->validTags);
        // Let's explode and implode to our heart's content.
        for ($i = 0; $i < 10; $i++) {
            $string = Tags::implode($tags);
            $tags = Tags::explode($string);
        }
        $this->assertTags($tags);
    }
    
    /**
     * Helper function: asserts that the ending array of tags is what we wanted.
     *
     * @internal
     */
    protected function assertTags(array $tags) : void {
        $original = $this->validTags;
        foreach ($tags as $tag) {
            $key = array_search($tag, $original);
            $this->assertTrue((bool) $key, $tag, sprintf('Make sure tag %s shows up in the final tags array (originally %s)', $tag, $key));
            unset($original[$key]);
        }
        foreach ($original as $leftover) {
            $this->fail(sprintf('Leftover tag %s was left over.', $leftover));
        }
    }

}

Members

Title Sort descending Deprecated Modifiers Object type Summary Overrides
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
TagsTest::$validTags protected property
TagsTest::assertTags protected function Helper function: asserts that the ending array of tags is what we wanted.
TagsTest::explodeTags public function Explodes a series of tags.
TagsTest::testImplodeTags public function Implodes a series of tags.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals Deprecated protected function Asserts if two arrays are equal by sorting them first.
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.
UnitTestCase::setUp protected function 338
UnitTestCase::setUpBeforeClass public static function

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