class UriItemTest

Same name in this branch
  1. 11.x core/modules/field/tests/src/Kernel/Uri/UriItemTest.php \Drupal\Tests\field\Kernel\Uri\UriItemTest
Same name in other branches
  1. 9 core/modules/field/tests/src/Kernel/Uri/UriItemTest.php \Drupal\Tests\field\Kernel\Uri\UriItemTest
  2. 8.9.x core/modules/field/tests/src/Kernel/Uri/UriItemTest.php \Drupal\Tests\field\Kernel\Uri\UriItemTest
  3. 10 core/modules/field/tests/src/Kernel/Uri/UriItemTest.php \Drupal\Tests\field\Kernel\Uri\UriItemTest
  4. 10 core/tests/Drupal/Tests/Core/Field/UriItemTest.php \Drupal\Tests\Core\Field\UriItemTest

Defines a test for the UriItem field-type.

@group Field @coversDefaultClass \Drupal\Core\Field\Plugin\Field\FieldType\UriItem

Hierarchy

Expanded class hierarchy of UriItemTest

File

core/tests/Drupal/Tests/Core/Field/UriItemTest.php, line 17

Namespace

Drupal\Tests\Core\Field
View source
class UriItemTest extends UnitTestCase {
    
    /**
     * Tests generating sample values.
     *
     * @param int $max_length
     *   Maximum field length.
     *
     * @covers ::generateSampleValue
     * @dataProvider providerMaxLength
     */
    public function testGenerateSampleValue(int $max_length) : void {
        $definition = $this->prophesize(FieldDefinitionInterface::class);
        $definition->getSetting('max_length')
            ->willReturn($max_length);
        for ($i = 0; $i < 1000; $i++) {
            $sample_value = UriItem::generateSampleValue($definition->reveal());
            $this->assertLessThanOrEqual($max_length, mb_strlen($sample_value['value']));
            $this->assertStringNotContainsString(' ', $sample_value['value']);
        }
    }
    
    /**
     * Data provider for maximum-lengths.
     *
     * @return array
     *   Test cases.
     */
    public static function providerMaxLength() : array {
        return [
            '32' => [
                32,
            ],
            '255' => [
                255,
            ],
            '500' => [
                500,
            ],
            '15' => [
                15,
            ],
            '64' => [
                64,
            ],
        ];
    }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
ExpectDeprecationTrait::expectDeprecation public function Adds an expected deprecation.
ExpectDeprecationTrait::getCallableName private static function Returns a callable as a string suitable for inclusion in a message.
ExpectDeprecationTrait::setUpErrorHandler public function Sets up the test error handler.
ExpectDeprecationTrait::tearDownErrorHandler public function Tears down the test error handler.
RandomGeneratorTrait::getRandomGenerator protected function Gets the random generator for the utility methods.
RandomGeneratorTrait::randomMachineName protected function Generates a unique random string containing letters and numbers.
RandomGeneratorTrait::randomObject public function Generates a random PHP object.
RandomGeneratorTrait::randomString public function Generates a pseudo-random string of ASCII characters of codes 32 to 126.
UnitTestCase::$root protected property The app root.
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::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::setUp protected function 367
UnitTestCase::setUpBeforeClass public static function
UriItemTest::providerMaxLength public static function Data provider for maximum-lengths.
UriItemTest::testGenerateSampleValue public function Tests generating sample values.

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