ArgumentValidatorTest.php
Same filename in this branch
Same filename in other branches
- 9 core/modules/views/tests/src/Kernel/Plugin/ArgumentValidatorTest.php
- 9 core/modules/views/tests/modules/views_test_data/src/Plugin/views/argument_validator/ArgumentValidatorTest.php
- 9 core/modules/views_ui/tests/src/Functional/ArgumentValidatorTest.php
- 8.9.x core/modules/views/tests/src/Kernel/Plugin/ArgumentValidatorTest.php
- 8.9.x core/modules/views/tests/modules/views_test_data/src/Plugin/views/argument_validator/ArgumentValidatorTest.php
- 8.9.x core/modules/views_ui/tests/src/Functional/ArgumentValidatorTest.php
- 10 core/modules/views/tests/src/Kernel/Plugin/ArgumentValidatorTest.php
- 10 core/modules/views/tests/modules/views_test_data/src/Plugin/views/argument_validator/ArgumentValidatorTest.php
- 10 core/modules/views_ui/tests/src/Functional/ArgumentValidatorTest.php
Namespace
Drupal\Tests\views_ui\FunctionalFile
-
core/
modules/ views_ui/ tests/ src/ Functional/ ArgumentValidatorTest.php
View source
<?php
declare (strict_types=1);
namespace Drupal\Tests\views_ui\Functional;
use Drupal\views\Views;
/**
* Tests the Argument validator through the UI.
*
* @group views_ui
*/
class ArgumentValidatorTest extends UITestBase {
/**
* Views used by this test.
*
* @var array
*/
public static $testViews = [
'test_argument',
];
/**
* {@inheritdoc}
*/
protected $defaultTheme = 'stark';
/**
* Tests the 'Specify validation criteria' checkbox functionality.
*/
public function testSpecifyValidation() : void {
// Specify a validation based on Node for the 'id' argument on the default
// display and assert that this works.
$this->saveArgumentHandlerWithValidationOptions(TRUE);
$view = Views::getView('test_argument');
$handler = $view->getHandler('default', 'argument', 'id');
$this->assertTrue($handler['specify_validation'], 'Validation for this argument has been turned on.');
$this->assertEquals('entity:node', $handler['validate']['type'], 'Validation for the argument is based on the node.');
// Uncheck the 'Specify validation criteria' checkbox and expect the
// validation type to be reset back to 'none'.
$this->saveArgumentHandlerWithValidationOptions(FALSE);
$view = Views::getView('test_argument');
$handler = $view->getHandler('default', 'argument', 'id');
$this->assertFalse($handler['specify_validation'], 'Validation for this argument has been turned off.');
$this->assertEquals('none', $handler['validate']['type'], 'Validation for the argument has been reverted to Basic Validation.');
}
/**
* Saves the test_argument view with changes made to the argument handler.
*
* @param bool $specify_validation
* The form validation.
*/
protected function saveArgumentHandlerWithValidationOptions($specify_validation) : void {
$options = [
'options[validate][type]' => 'entity---node',
'options[specify_validation]' => $specify_validation,
];
$this->drupalGet('admin/structure/views/nojs/handler/test_argument/default/argument/id');
$this->submitForm($options, 'Apply');
$this->drupalGet('admin/structure/views/view/test_argument');
$this->submitForm([], 'Save');
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
ArgumentValidatorTest | Tests the Argument validator through the UI. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.