class PathProcessorFrontTest
Same name in other branches
- 9 core/tests/Drupal/Tests/Core/PathProcessor/PathProcessorFrontTest.php \Drupal\Tests\Core\PathProcessor\PathProcessorFrontTest
- 10 core/tests/Drupal/Tests/Core/PathProcessor/PathProcessorFrontTest.php \Drupal\Tests\Core\PathProcessor\PathProcessorFrontTest
- 11.x core/tests/Drupal/Tests/Core/PathProcessor/PathProcessorFrontTest.php \Drupal\Tests\Core\PathProcessor\PathProcessorFrontTest
Test front page path processing.
@group PathProcessor @coversDefaultClass \Drupal\Core\PathProcessor\PathProcessorFront
Hierarchy
- class \Drupal\Tests\UnitTestCase extends \PHPUnit\Framework\TestCase uses \Drupal\Tests\PhpunitCompatibilityTrait
- class \Drupal\Tests\Core\PathProcessor\PathProcessorFrontTest extends \Drupal\Tests\UnitTestCase
Expanded class hierarchy of PathProcessorFrontTest
File
-
core/
tests/ Drupal/ Tests/ Core/ PathProcessor/ PathProcessorFrontTest.php, line 18
Namespace
Drupal\Tests\Core\PathProcessorView source
class PathProcessorFrontTest extends UnitTestCase {
/**
* Test basic inbound processing functionality.
*
* @covers ::processInbound
* @dataProvider providerProcessInbound
*/
public function testProcessInbound($frontpage_path, $path, $expected, array $expected_query = []) {
$config_factory = $this->prophesize(ConfigFactoryInterface::class);
$config = $this->prophesize(ImmutableConfig::class);
$config_factory->get('system.site')
->willReturn($config->reveal());
$config->get('page.front')
->willReturn($frontpage_path);
$processor = new PathProcessorFront($config_factory->reveal());
$request = new Request();
$this->assertEquals($expected, $processor->processInbound($path, $request));
$this->assertEquals($expected_query, $request->query
->all());
}
/**
* Inbound paths and expected results.
*/
public function providerProcessInbound() {
return [
'accessing frontpage' => [
'/node',
'/',
'/node',
],
'accessing non frontpage' => [
'/node',
'/user',
'/user',
],
'accessing frontpage with query parameters' => [
'/node?example=muh',
'/',
'/node',
[
'example' => 'muh',
],
],
];
}
/**
* Test inbound failure with broken config.
*
* @covers ::processInbound
*/
public function testProcessInboundBadConfig() {
$config_factory = $this->prophesize(ConfigFactoryInterface::class);
$config = $this->prophesize(ImmutableConfig::class);
$config_factory->get('system.site')
->willReturn($config->reveal());
$config->get('page.front')
->willReturn('');
$processor = new PathProcessorFront($config_factory->reveal());
$this->expectException(NotFoundHttpException::class);
$processor->processInbound('/', new Request());
}
/**
* Test basic outbound processing functionality.
*
* @covers ::processOutbound
* @dataProvider providerProcessOutbound
*/
public function testProcessOutbound($path, $expected) {
$config_factory = $this->prophesize(ConfigFactoryInterface::class);
$processor = new PathProcessorFront($config_factory->reveal());
$this->assertEquals($expected, $processor->processOutbound($path));
}
/**
* Outbound paths and expected results.
*/
public function providerProcessOutbound() {
return [
[
'/<front>',
'/',
],
[
'<front>',
'<front>',
],
[
'/user',
'/user',
],
];
}
}
Members
Title Sort descending | Deprecated | Modifiers | Object type | Summary | Overrides |
---|---|---|---|---|---|
PathProcessorFrontTest::providerProcessInbound | public | function | Inbound paths and expected results. | ||
PathProcessorFrontTest::providerProcessOutbound | public | function | Outbound paths and expected results. | ||
PathProcessorFrontTest::testProcessInbound | public | function | Test basic inbound processing functionality. | ||
PathProcessorFrontTest::testProcessInboundBadConfig | public | function | Test inbound failure with broken config. | ||
PathProcessorFrontTest::testProcessOutbound | public | function | Test basic outbound processing functionality. | ||
PhpunitCompatibilityTrait::getMock | Deprecated | public | function | Returns a mock object for the specified class using the available method. | |
PhpunitCompatibilityTrait::setExpectedException | Deprecated | public | function | Compatibility layer for PHPUnit 6 to support PHPUnit 4 code. | |
UnitTestCase::$randomGenerator | protected | property | The random generator. | ||
UnitTestCase::$root | protected | property | The app root. | 1 | |
UnitTestCase::assertArrayEquals | protected | function | Asserts if two arrays are equal by sorting them first. | ||
UnitTestCase::getBlockMockWithMachineName | Deprecated | protected | function | Mocks a block with a block plugin. | 1 |
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 | 340 |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.