class MenuTreeParametersTest in Drupal 8
Same name and namespace in other branches
- 9 core/tests/Drupal/Tests/Core/Menu/MenuTreeParametersTest.php \Drupal\Tests\Core\Menu\MenuTreeParametersTest
- 10 core/tests/Drupal/Tests/Core/Menu/MenuTreeParametersTest.php \Drupal\Tests\Core\Menu\MenuTreeParametersTest
Tests the menu link tree parameters value object.
@group Menu
@coversDefaultClass \Drupal\Core\Menu\MenuTreeParameters
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses PhpunitCompatibilityTrait
- class \Drupal\Tests\Core\Menu\MenuTreeParametersTest
Expanded class hierarchy of MenuTreeParametersTest
File
- core/
tests/ Drupal/ Tests/ Core/ Menu/ MenuTreeParametersTest.php, line 15
Namespace
Drupal\Tests\Core\MenuView source
class MenuTreeParametersTest extends UnitTestCase {
/**
* Provides test data for testSetMinDepth().
*/
public function providerTestSetMinDepth() {
$data = [];
// Valid values at the extremes and in the middle.
$data[] = [
1,
1,
];
$data[] = [
2,
2,
];
$data[] = [
9,
9,
];
// Invalid values are mapped to the closest valid value.
$data[] = [
-10000,
1,
];
$data[] = [
0,
1,
];
// … except for those invalid values that reach beyond the maximum depth,
// because MenuTreeParameters is a value object and hence cannot depend
// on anything; to know the actual maximum depth, it'd have to depend on the
// MenuTreeStorage service.
$data[] = [
10,
10,
];
$data[] = [
100000,
100000,
];
return $data;
}
/**
* Tests setMinDepth().
*
* @covers ::setMinDepth
* @dataProvider providerTestSetMinDepth
*/
public function testSetMinDepth($min_depth, $expected) {
$parameters = new MenuTreeParameters();
$parameters
->setMinDepth($min_depth);
$this
->assertEquals($expected, $parameters->minDepth);
}
/**
* Tests addExpandedParents().
*
* @covers ::addExpandedParents
*/
public function testAddExpanded() {
$parameters = new MenuTreeParameters();
// Verify default value.
$this
->assertEquals([], $parameters->expandedParents);
// Add actual menu link plugin IDs to be expanded.
$parameters
->addExpandedParents([
'foo',
'bar',
'baz',
]);
$this
->assertEquals([
'foo',
'bar',
'baz',
], $parameters->expandedParents);
// Add additional menu link plugin IDs; they should be merged, not replacing
// the old ones.
$parameters
->addExpandedParents([
'qux',
'quux',
]);
$this
->assertEquals([
'foo',
'bar',
'baz',
'qux',
'quux',
], $parameters->expandedParents);
// Add pre-existing menu link plugin IDs; they should not be added again;
// this is a set.
$parameters
->addExpandedParents([
'bar',
'quux',
]);
$this
->assertEquals([
'foo',
'bar',
'baz',
'qux',
'quux',
], $parameters->expandedParents);
}
/**
* Tests addCondition().
*
* @covers ::addCondition
*/
public function testAddCondition() {
$parameters = new MenuTreeParameters();
// Verify default value.
$this
->assertEquals([], $parameters->conditions);
// Add a condition.
$parameters
->addCondition('expanded', 1);
$this
->assertEquals([
'expanded' => 1,
], $parameters->conditions);
// Add another condition.
$parameters
->addCondition('has_children', 0);
$this
->assertEquals([
'expanded' => 1,
'has_children' => 0,
], $parameters->conditions);
// Add a condition with an operator.
$parameters
->addCondition('provider', [
'module1',
'module2',
], 'IN');
$this
->assertEquals([
'expanded' => 1,
'has_children' => 0,
'provider' => [
[
'module1',
'module2',
],
'IN',
],
], $parameters->conditions);
// Add another condition with an operator.
$parameters
->addCondition('id', 1337, '<');
$this
->assertEquals([
'expanded' => 1,
'has_children' => 0,
'provider' => [
[
'module1',
'module2',
],
'IN',
],
'id' => [
1337,
'<',
],
], $parameters->conditions);
// It's impossible to add two conditions on the same field; in that case,
// the old condition will be overwritten.
$parameters
->addCondition('provider', 'other_module');
$this
->assertEquals([
'expanded' => 1,
'has_children' => 0,
'provider' => 'other_module',
'id' => [
1337,
'<',
],
], $parameters->conditions);
}
/**
* Tests onlyEnabledLinks().
*
* @covers ::onlyEnabledLinks
*/
public function testOnlyEnabledLinks() {
$parameters = new MenuTreeParameters();
$parameters
->onlyEnabledLinks();
$this
->assertEquals(1, $parameters->conditions['enabled']);
}
/**
* Tests setTopLevelOnly().
*
* @covers ::setTopLevelOnly
*/
public function testSetTopLevelOnly() {
$parameters = new MenuTreeParameters();
$parameters
->setTopLevelOnly();
$this
->assertEquals(1, $parameters->maxDepth);
}
/**
* Tests excludeRoot().
*
* @covers ::excludeRoot
*/
public function testExcludeRoot() {
$parameters = new MenuTreeParameters();
$parameters
->excludeRoot();
$this
->assertEquals(1, $parameters->minDepth);
}
/**
* @covers ::serialize
* @covers ::unserialize
*/
public function testSerialize() {
$parameters = new MenuTreeParameters();
$parameters
->setRoot(1);
$parameters
->setMinDepth('2');
$parameters
->setMaxDepth('9');
$parameters
->addExpandedParents([
'',
'foo',
]);
$parameters
->setActiveTrail([
'',
'bar',
]);
$after_serialize = unserialize(serialize($parameters));
$this
->assertSame('1', $after_serialize->root);
$this
->assertSame(2, $after_serialize->minDepth);
$this
->assertSame(9, $after_serialize->maxDepth);
$this
->assertSame([
'',
'foo',
], $after_serialize->expandedParents);
$this
->assertSame([
'bar',
], $after_serialize->activeTrail);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MenuTreeParametersTest:: |
public | function | Provides test data for testSetMinDepth(). | |
MenuTreeParametersTest:: |
public | function | Tests addCondition(). | |
MenuTreeParametersTest:: |
public | function | Tests addExpandedParents(). | |
MenuTreeParametersTest:: |
public | function | Tests excludeRoot(). | |
MenuTreeParametersTest:: |
public | function | Tests onlyEnabledLinks(). | |
MenuTreeParametersTest:: |
public | function | @covers ::serialize @covers ::unserialize | |
MenuTreeParametersTest:: |
public | function | Tests setMinDepth(). | |
MenuTreeParametersTest:: |
public | function | Tests setTopLevelOnly(). | |
PhpunitCompatibilityTrait:: |
public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait:: |
public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
UnitTestCase:: |
protected | property | The random generator. | |
UnitTestCase:: |
protected | property | The app root. | 1 |
UnitTestCase:: |
protected | function | Asserts if two arrays are equal by sorting them first. | |
UnitTestCase:: |
protected | function | Mocks a block with a block plugin. | 1 |
UnitTestCase:: |
protected | function | Returns a stub class resolver. | |
UnitTestCase:: |
public | function | Returns a stub config factory that behaves according to the passed array. | |
UnitTestCase:: |
public | function | Returns a stub config storage that returns the supplied configuration. | |
UnitTestCase:: |
protected | function | Sets up a container with a cache tags invalidator. | |
UnitTestCase:: |
protected | function | Gets the random generator for the utility methods. | |
UnitTestCase:: |
public | function | Returns a stub translation manager that just returns the passed string. | |
UnitTestCase:: |
public | function | Generates a unique random string containing letters and numbers. | |
UnitTestCase:: |
protected | function | 340 |