PathElementFormTest.php

Same filename in other branches
  1. 8.9.x core/tests/Drupal/KernelTests/Core/Element/PathElementFormTest.php
  2. 10 core/tests/Drupal/KernelTests/Core/Element/PathElementFormTest.php
  3. 11.x core/tests/Drupal/KernelTests/Core/Element/PathElementFormTest.php

Namespace

Drupal\KernelTests\Core\Element

File

core/tests/Drupal/KernelTests/Core/Element/PathElementFormTest.php

View source
<?php

namespace Drupal\KernelTests\Core\Element;

use Drupal\Core\Form\FormInterface;
use Drupal\Core\Form\FormState;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Render\Element\PathElement;
use Drupal\Core\Url;
use Drupal\KernelTests\KernelTestBase;
use Drupal\user\Entity\Role;
use Drupal\user\Entity\User;

/**
 * Tests PathElement validation and conversion functionality.
 *
 * @group Form
 */
class PathElementFormTest extends KernelTestBase implements FormInterface {
    
    /**
     * User for testing.
     *
     * @var \Drupal\user\UserInterface
     */
    protected $testUser;
    
    /**
     * Modules to enable.
     *
     * @var array
     */
    protected static $modules = [
        'system',
        'user',
    ];
    
    /**
     * Sets up the test.
     */
    protected function setUp() : void {
        parent::setUp();
        $this->installSchema('system', [
            'sequences',
        ]);
        $this->installEntitySchema('user');
        
        /** @var \Drupal\user\RoleInterface $role */
        $role = Role::create([
            'id' => 'admin',
            'label' => 'admin',
        ]);
        $role->grantPermission('link to any page');
        $role->save();
        $this->testUser = User::create([
            'name' => 'foobar',
            'mail' => 'foobar@example.com',
        ]);
        $this->testUser
            ->addRole($role->id());
        $this->testUser
            ->save();
        \Drupal::service('current_user')->setAccount($this->testUser);
    }
    
    /**
     * {@inheritdoc}
     */
    public function getFormId() {
        return 'test_path_element';
    }
    
    /**
     * {@inheritdoc}
     */
    public function buildForm(array $form, FormStateInterface $form_state) {
        // A required validated path.
        $form['required_validate'] = [
            '#type' => 'path',
            '#required' => TRUE,
            '#title' => 'required_validate',
            '#convert_path' => PathElement::CONVERT_NONE,
        ];
        // A non validated required path.
        $form['required_non_validate'] = [
            '#type' => 'path',
            '#required' => TRUE,
            '#title' => 'required_non_validate',
            '#convert_path' => PathElement::CONVERT_NONE,
            '#validate_path' => FALSE,
        ];
        // A non required validated path.
        $form['optional_validate'] = [
            '#type' => 'path',
            '#required' => FALSE,
            '#title' => 'optional_validate',
            '#convert_path' => PathElement::CONVERT_NONE,
        ];
        // A non required converted path.
        $form['optional_validate'] = [
            '#type' => 'path',
            '#required' => FALSE,
            '#title' => 'optional_validate',
            '#convert_path' => PathElement::CONVERT_ROUTE,
        ];
        // A converted required validated path.
        $form['required_validate_route'] = [
            '#type' => 'path',
            '#required' => TRUE,
            '#title' => 'required_validate_route',
        ];
        // A converted required validated path.
        $form['required_validate_url'] = [
            '#type' => 'path',
            '#required' => TRUE,
            '#title' => 'required_validate_url',
            '#convert_path' => PathElement::CONVERT_URL,
        ];
        $form['submit'] = [
            '#type' => 'submit',
            '#value' => t('Submit'),
        ];
        return $form;
    }
    
    /**
     * {@inheritdoc}
     */
    public function submitForm(array &$form, FormStateInterface $form_state) {
    }
    
    /**
     * Form validation handler.
     *
     * @param array $form
     *   An associative array containing the structure of the form.
     * @param \Drupal\Core\Form\FormStateInterface $form_state
     *   The current state of the form.
     */
    public function validateForm(array &$form, FormStateInterface $form_state) {
    }
    
    /**
     * Tests that default handlers are added even if custom are specified.
     */
    public function testPathElement() {
        $form_state = (new FormState())->setValues([
            'required_validate' => 'user/' . $this->testUser
                ->id(),
            'required_non_validate' => 'magic-ponies',
            'required_validate_route' => 'user/' . $this->testUser
                ->id(),
            'required_validate_url' => 'user/' . $this->testUser
                ->id(),
        ]);
        $form_builder = $this->container
            ->get('form_builder');
        $form_builder->submitForm($this, $form_state);
        // Valid form state.
        $this->assertCount(0, $form_state->getErrors());
        $this->assertEquals([
            'route_name' => 'entity.user.canonical',
            'route_parameters' => [
                'user' => $this->testUser
                    ->id(),
            ],
        ], $form_state->getValue('required_validate_route'));
        
        /** @var \Drupal\Core\Url $url */
        $url = $form_state->getValue('required_validate_url');
        $this->assertInstanceOf(Url::class, $url);
        $this->assertEquals('entity.user.canonical', $url->getRouteName());
        $this->assertEquals([
            'user' => $this->testUser
                ->id(),
        ], $url->getRouteParameters());
        // Test #required.
        $form_state = (new FormState())->setValues([
            'required_non_validate' => 'magic-ponies',
            'required_validate_route' => 'user/' . $this->testUser
                ->id(),
            'required_validate_url' => 'user/' . $this->testUser
                ->id(),
        ]);
        $form_builder->submitForm($this, $form_state);
        $errors = $form_state->getErrors();
        // Should be missing 'required_validate' field.
        $this->assertCount(1, $errors);
        $this->assertEquals([
            'required_validate' => t('@name field is required.', [
                '@name' => 'required_validate',
            ]),
        ], $errors);
        // Test invalid parameters.
        $form_state = (new FormState())->setValues([
            'required_validate' => 'user/74',
            'required_non_validate' => 'magic-ponies',
            'required_validate_route' => 'user/74',
            'required_validate_url' => 'user/74',
        ]);
        $form_builder = $this->container
            ->get('form_builder');
        $form_builder->submitForm($this, $form_state);
        // Valid form state.
        $errors = $form_state->getErrors();
        $this->assertCount(3, $errors);
        $this->assertEquals([
            'required_validate' => t('This path does not exist or you do not have permission to link to %path.', [
                '%path' => 'user/74',
            ]),
            'required_validate_route' => t('This path does not exist or you do not have permission to link to %path.', [
                '%path' => 'user/74',
            ]),
            'required_validate_url' => t('This path does not exist or you do not have permission to link to %path.', [
                '%path' => 'user/74',
            ]),
        ], $errors);
    }

}

Classes

Title Deprecated Summary
PathElementFormTest Tests PathElement validation and conversion functionality.

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