Skip to content
Snippets Groups Projects
Commit 49ffcb8d authored by catch's avatar catch
Browse files

Issue #3030403 by Krzysztof Domański, ranjith_kumar_k_u, larowlan: Improve the...

Issue #3030403 by Krzysztof Domański, ranjith_kumar_k_u, larowlan: Improve the readability of the code in assertBreadcrumbParts
parent a38d5bbd
No related branches found
No related tags found
28 merge requests!54479.5.x SF update,!5014Issue #3071143: Table Render Array Example Is Incorrect,!4868Issue #1428520: Improve menu parent link selection,!4289Issue #1344552 by marcingy, Niklas Fiekas, Ravi.J, aleevas, Eduardo Morales...,!4114Issue #2707291: Disable body-level scrolling when a dialog is open as a modal,!4100Issue #3249600: Add support for PHP 8.1 Enums as allowed values for list_* data types,!3630Issue #2815301 by Chi, DanielVeza, kostyashupenko, smustgrave: Allow to create...,!3600Issue #3344629: Passing null to parameter #1 ($haystack) of type string is deprecated,!2378Issue #2875033: Optimize joins and table selection in SQL entity query implementation,!2334Issue #3228209: Add hasRole() method to AccountInterface,!2062Issue #3246454: Add weekly granularity to views date sort,!1591Issue #3199697: Add JSON:API Translation experimental module,!1484Exposed filters get values from URL when Ajax is on,!1255Issue #3238922: Refactor (if feasible) uses of the jQuery serialize function to use vanillaJS,!1162Issue #3100350: Unable to save '/' root path alias,!1105Issue #3025039: New non translatable field on translatable content throws error,!1073issue #3191727: Focus states on mobile second level navigation items fixed,!10223132456: Fix issue where views instances are emptied before an ajax request is complete,!925Issue #2339235: Remove taxonomy hard dependency on node module,!877Issue #2708101: Default value for link text is not saved,!872Draft: Issue #3221319: Race condition when creating menu links and editing content deletes menu links,!844Resolve #3036010 "Updaters",!617Issue #3043725: Provide a Entity Handler for user cancelation,!579Issue #2230909: Simple decimals fail to pass validation,!560Move callback classRemove outside of the loop,!555Issue #3202493,!485Sets the autocomplete attribute for username/password input field on login form.,!30Issue #3182188: Updates composer usage to point at ./vendor/bin/composer
...@@ -65,14 +65,10 @@ protected function assertBreadcrumb($goto, array $trail, $page_title = NULL, arr ...@@ -65,14 +65,10 @@ protected function assertBreadcrumb($goto, array $trail, $page_title = NULL, arr
protected function assertBreadcrumbParts($trail) { protected function assertBreadcrumbParts($trail) {
// Compare paths with actual breadcrumb. // Compare paths with actual breadcrumb.
$parts = $this->getBreadcrumbParts(); $parts = $this->getBreadcrumbParts();
$found = $parts;
$pass = TRUE; $pass = TRUE;
// Fail if there is no breadcrumb and we have a trail.
if (!empty($trail) && empty($parts)) { if (!empty($trail) && !empty($parts)) {
$pass = FALSE;
}
// There may be more than one breadcrumb on the page. If $trail is empty
// this test would go into an infinite loop, so we need to check that too.
while ($trail && !empty($parts)) {
foreach ($trail as $path => $title) { foreach ($trail as $path => $title) {
// If the path is empty, generate the path from the <front> route. If // If the path is empty, generate the path from the <front> route. If
// the path does not start with a leading slash, then run it through // the path does not start with a leading slash, then run it through
...@@ -91,11 +87,20 @@ protected function assertBreadcrumbParts($trail) { ...@@ -91,11 +87,20 @@ protected function assertBreadcrumbParts($trail) {
$pass = ($pass && $part['href'] === $url && $part['text'] === Html::escape($title)); $pass = ($pass && $part['href'] === $url && $part['text'] === Html::escape($title));
} }
} }
elseif (!empty($trail) && empty($parts) || empty($trail) && !empty($parts)) {
// Fail if there is no breadcrumb and we have a trail or breadcrumb
// exists but trail is empty.
$pass = FALSE;
}
// No parts must be left, or an expected "Home" will always pass. // No parts must be left, or an expected "Home" will always pass.
$pass = ($pass && empty($parts)); $pass = ($pass && empty($parts));
$this->assertTrue($pass, new FormattableMarkup('Breadcrumb %parts found on @path.', [ $this->assertTrue($pass, new FormattableMarkup('Expected breadcrumb %parts on @path but found %found.', [
'%parts' => implode(' » ', $trail), '%parts' => implode(' » ', $trail),
'%found' => implode(' » ', array_map(function (array $item) {
return $item['text'];
}, $found)),
'@path' => $this->getUrl(), '@path' => $this->getUrl(),
])); ]));
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment