- 🇺🇸United States smustgrave
This issue is being reviewed by the kind folks in Slack, #needs-review-queue-initiative. We are working to keep the size of Needs Review queue [2700+ issues] to around 400 (1 month or less), following Review a patch or merge request → as a guide.
As a bug this will need a test case.
- Status changed to Needs review
almost 2 years ago 10:26am 20 February 2023 - 🇬🇧United Kingdom james.williams
Woah, patches 78 & 79 have taken a completely different approach to all previous patches, with no explanation or interdiff. They reference a service that isn't even in core, but looks like a contrib one (language_fallback.controller)? So we'll need updates about those please (@rzanetti?), otherwise those will have to be ignored, as yes, that approach needs tests (and more).
But returning to the patch in #69, which is otherwise the 'current' one, that one does include tests. Its tests-only patch shows failures as expected, and the fix+tests patch passes tests. That said, I haven't myself had time to review updates since comment 64, so there are outstanding concerns that might need addressing.
- Status changed to Needs work
almost 2 years ago 5:48pm 20 February 2023 - 🇺🇸United States smustgrave
Reviewing #69
+ @trigger_error('The language_manager service must be passed to AliasRepository::__construct(), it is required before Drupal 9.1.1. See https://www.drupal.org/node/3108585.', E_USER_DEPRECATED);
1. This doesn't seem like the normal template. But will also need version update.
Tests look good but would need a 2nd pair of eyes.
- 🇬🇧United Kingdom james.williams
@smustgrave Fair point. Which version should this issue be targeting? Should it really be Drupal 10.1 by now? Given the pace of this issue, I'm reluctant to spend time changing the version number in that string when it's only likely to need to change again! I've always wondered, how is that handled on other issues, do they just keep updating such strings every time a new release comes along??
- 🇺🇸United States smustgrave
Can look at other example in core for the template wording. But it would be required for Drupal 11.
- heddn Nicaragua
+++ b/core/modules/path_alias/src/AliasRepository.php (revision da61e77ac1a1354030d2e6c0251553effd47d9cc) @@ -122,20 +138,29 @@ + // hook_tag_path_alias_language_fallback_alter().
I think this should be updated to the following:
// hook_query_tag_path_alias_language_fallback_alter().
- 🇩🇪Germany J-Lee 🇩🇪🇪🇺
@james.williams have found two examples for the wording:
@trigger_error("The property $name ($service_name service) is deprecated in $class_name and will be removed before Drupal 11.0.0.", E_USER_DEPRECATED);
@trigger_error('The key-value pair "experimental: true" is deprecated in drupal:10.1.0 and will be removed before drupal:11.0.0. Use the key-value pair "lifecycle: experimental" instead. See https://www.drupal.org/node/3263585 → ', E_USER_DEPRECATED);
Maybe it helps?
- Status changed to Needs review
about 1 year ago 3:43pm 10 November 2023 - 🇬🇧United Kingdom james.williams
Thanks both. Here are updated patches based on #69, taking into account the feedback from #83 (I used an example from
\Drupal\migrate\Plugin\migrate\id_map\Sql
which was the first similar one that I found) and #86.I've also updated the change record, targeting 10.2.0 (though I don't know if that's possible).
- last update
about 1 year ago 30,512 pass, 2 fail - last update
about 1 year ago Custom Commands Failed The Needs Review Queue Bot → tested this issue. We recommend that you convert this patch to a merge request → .
Merge requests are preferred over patches. Be sure to hide the old patch files as well (converting an issue to a merge request without other improvements is not recommended and will not receive credit).
- Status changed to Needs work
about 1 year ago 4:09pm 10 November 2023 The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".
This does not mean that the patch needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.
Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues.
- 🇫🇷France nod_ Lille
bot was mistaken about the actual problem but it's a valid NW
- @jameswilliams-0 opened merge request.
- 🇬🇧United Kingdom james.williams
Can anyone help me understand/resolve the Nightwatch test failure https://git.drupalcode.org/issue/drupal-3091336/-/jobs/308229 ? I don't understand how this is something these changes could have triggered.
- 🇺🇸United States smustgrave
Have you reran it? Nightwatch has been weird this week.
- Status changed to Needs review
about 1 year ago 10:28pm 10 November 2023 - 🇬🇧United Kingdom james.williams
Oh wow, that was all that was needed. Bizarre. Took two attempts, but there now.
- Status changed to Needs work
about 1 year ago 6:48pm 11 November 2023 - 🇺🇸United States smustgrave
Hiding the patches for clarity now that the fix is in the MR.
Could the issue summary be updated though. I got it started but not as familiar with the issue to be able to speak on it.
And as far as your comment
can well imagine this isn't the "right" thing to do! The changes in PathItem.php replace blocks of code that triggered these messages, reducing them in total, ...
I don't think that's problem. That property is already there and being used, you're just using it again.
- Status changed to Needs review
about 1 year ago 8:22am 13 November 2023 - Status changed to RTBC
about 1 year ago 2:56pm 13 November 2023 - 🇺🇸United States smustgrave
All threads have been resolved and issue summary updated to match what's being proposed. Going to mark it but could the MR 5332 be updated to point to 11.x, that's the current development branch and all code has to land there first. Then to be backported. If a separate MR is opened for 11.x can you make note of what is what in the issue summary
- Merge request !5373Issue #3091336: Use a proper language fallback mechanism for path.alias_repository service → (Closed) created by james.williams
- 🇬🇧United Kingdom james.williams
Thanks! OK, so branch 3091336-alias-repo-service-fallback-d11 / MR !5373 is for the 11.x branch. I've cherry-picked the 3 commits from the already-reviewed MR !5332 (branch 3091336-path.aliasrepository-service-does), which is for the 10.2.x branch.
The branch 3091336-path.aliasrepository-service-fallback-d11x can be ignored, that was a mistake, sorry. (Can incorrect branches be hidden/deleted?)
Does the addition of the language manager argument for the alias repository need to be made required now, for that 11.x version? Or is that best done as a follow-up?
- 🇺🇸United States smustgrave
11.x is the development branch, think of it as the main. Future D10 releases, 10.3 for example, will be tagged off that.
- Status changed to Needs work
about 1 year ago 11:28pm 14 November 2023 - 🇺🇸United States xjm
Posted suggestions for miscellaneous coding standards issues on the merge request. Thanks!
- Status changed to Needs review
about 1 year ago 2:44pm 15 November 2023 - 🇬🇧United Kingdom james.williams
Thanks for that! I've committed fixes for all those bits of feedback.
- Status changed to RTBC
about 1 year ago 4:40pm 15 November 2023 - 🇺🇸United States smustgrave
Appears all threads have been addressed from @xjm
- 🇺🇸United States xjm
@smustgrave This is one of those cases where it'd be really helpful for you to do your own careful re-review rather than auto-RTBCing when "all committer feedback is addressed".
I feel weird committing this since I made so many suggestions. It got a bit out of hand. 🙂 I probably should have just given the high-level feedback of "remember your void typehints and 'the'". So another set of eyes reviewing not only that my changes were added, but that each was a correct change and made sense, would be really useful.
- Status changed to Needs review
about 1 year ago 7:44pm 8 December 2023 - 🇺🇸United States xjm
Setting back to NR to try to get some close review of my suggestions and @james.williams' fixes and that it all made sense, since no other committers have taken this up for commit in the past three weeks either.
- Status changed to Needs work
about 1 year ago 7:19pm 27 December 2023 - 🇺🇸United States smustgrave
Left a few small changes.
I requested push access but still don't seem to be able to run the test only feature. @James.williams do you have the ability to so we can all see. Else I can run locally.
- 🇬🇧United Kingdom james.williams
Thanks; I've addressed remaining feedback where I can.
What should I do about the Functional Javascript test failure, which is reporting that (at least) one additional database query has been performed in
Drupal\Tests\standard\FunctionalJavascript\StandardPerformanceTest::testAnonymous
? Is there any way to get reports/assets from Drupal CI to see which is the extra query, or does it have to be investigated locally? I had a go at trying to just spot the extra query from just tracing the code statically by eye, but I couldn't find it that way.As for the test-only failure, I've triggered the 'Test-only changes' item under the 'DEFAULT: PHP 8.2 MySQL 8' job - but should I be using the 'DEFAULT: Test-only (PHP 8.2 MySQL 8)' test job itself? They might well be triggering the same thing; I can't tell!
- Status changed to Needs review
about 1 year ago 2:38pm 4 January 2024 - 🇬🇧United Kingdom james.williams
The rebase didn't fix the counts. I've spent several hours setting up chromedriver etc to be able to run the functional javascript tests locally, and found it's because the 'path_alias_language_fallback' tag is added to the alias lookup query, when looking up the incoming path. So
hook_query_TAG_alter()
is invoked, which includes querying the 'cache_bootstrap' database table for the 'module_implements' and 'hook_info' cache entries, i.e. which modules implement which hooks, at the point of early bootstrapping. To me, that seems a reasonable addition, as that cache entry will almost certainly need looking up at some point for users on other common pages anyway? I could be wrong. (FWIW, Berdir had done some performance testing up in comment #53 and found the performance hit was very small.)On the belief that this is OK to do, I'll increase the count of allowed queries to accommodate this fix.
- 🇬🇧United Kingdom james.williams
I've now avoided the need for monolingual sites to perform the extra queries, and run the test-only job. Properly ready for review again!
- Status changed to RTBC
about 1 year ago 4:51pm 11 January 2024 - 🇺🇸United States smustgrave
There were 2 failures: 1) Drupal\Tests\path_alias\Kernel\AliasLanguageFallbackTest::testLookupByAlias The Afrikaans path alias is returned if we specify English to the alias repository and Afrikaans is a valid fallback candidate for English. Failed asserting that null matches expected '/user/1'. /builds/issue/drupal-3091336/vendor/phpunit/phpunit/src/Framework/Constraint/Equality/IsEqual.php:94 /builds/issue/drupal-3091336/core/modules/path_alias/tests/src/Kernel/AliasLanguageFallbackTest.php:71 /builds/issue/drupal-3091336/vendor/phpunit/phpunit/src/Framework/TestResult.php:728 2) Drupal\Tests\path_alias\Kernel\AliasLanguageFallbackTest::testLookupBySystemPath The Afrikaans path alias is returned if we specify English to the alias repository and Afrikaans is a valid fallback candidate for English. Failed asserting that null matches expected '/test-login-alias'. /builds/issue/drupal-3091336/vendor/phpunit/phpunit/src/Framework/Constraint/Equality/IsEqual.php:94 /builds/issue/drupal-3091336/core/modules/path_alias/tests/src/Kernel/AliasLanguageFallbackTest.php:103 /builds/issue/drupal-3091336/vendor/phpunit/phpunit/src/Framework/TestResult.php:728 FAILURES! Tests: 2, Assertions: 8, Failures: 2.
Thanks for running test-only job. Not sure why push access broke on this single issue.
Reading the threads believe all feedback has been addressed.
mei2020 → changed the visibility of the branch 3091336-path.aliasrepository-service-does to active.
- Status changed to Needs work
11 months ago 7:23am 20 February 2024 - 🇳🇿New Zealand quietone
I'm triaging RTBC issues → . I read the IS, the comment, the MR and the CR. I didn't find any unanswered questions.
@james.williams, thank you for getting this issue to RTBC. I found your comments were always helpful and explained the changes and referred to the review that requested a change.
Starting with the CR, that needs to be updated, including the title. The CR should include before and after code samples. The title is to be a statement of the change without the 'should', this is a new requirement. Searching existing change records provides some examples that should help; https://www.drupal.org/node/3387233 → , https://www.drupal.org/node/3014688 → . I've added the tag for change record updates.
I read the CR, not a code review, and I didn't see anything that I thought should change.
I think all the core gates have been completed here.
Finally, let's improve the title of this issue so it says something about the fix, not the problem. Also, what is a 'proper' mechanism anyway? :-) Maybe, "Ensure path alias repository returns the correct fallback language'?
So, just a few things.
- Status changed to Needs review
11 months ago 10:45am 20 February 2024 - 🇬🇧United Kingdom james.williams
OK, thanks @quietone - I've updated this issue's title, and the CR: https://www.drupal.org/node/3108585 →
"what is a 'proper' mechanism anyway?" - haha, fair question! I think just supporting a sane way of altering language fallbacks: via the existing
hook_language_fallback_candidates_alter()
hook (which the usual entity repository service respects, but not path.alias_repository service, until this change). - 🇬🇧United Kingdom james.williams
james.williams → changed the visibility of the branch 3091336-path.aliasrepository-service-does to hidden.
- 🇬🇧United Kingdom james.williams
james.williams → changed the visibility of the branch 3091336-path.aliasrepository-service-fallback-d11x to hidden.
- Status changed to RTBC
11 months ago 2:43pm 1 March 2024 - Status changed to Needs work
10 months ago 4:59pm 12 March 2024 The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".
This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.
Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues.
- First commit to issue fork.
- Status changed to Needs review
10 months ago 5:56pm 12 March 2024 - 🇮🇳India adwivedi008
MR at #123 seems fine but as on comparison we can see a lot of changes at the MR
Moving the issue to needs review as its previous status was RTBC over #120Let's wait for some more reviews and then move this to RTBC
RTBC+ From my side
- Status changed to Needs work
10 months ago 6:28pm 12 March 2024 The Needs Review Queue Bot → tested this issue. It fails the Drupal core commit checks. Therefore, this issue status is now "Needs work".
This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.
Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues.
- Status changed to Needs review
10 months ago 11:10am 13 March 2024 - 🇬🇧United Kingdom james.williams
Fixed the tests... changes to the baseline for phpstan had been missed from the rebase, and the extra assertion about the number of queries on user pages was no longer helpful (presumably work on core elsewhere had reduced the number of queries, which is a good sign!), so I removed it.
- Status changed to RTBC
10 months ago 2:34pm 19 March 2024 - Status changed to Needs work
10 months ago 9:09am 1 April 2024 - 🇬🇧United Kingdom catch
One comment on the MR, but also the issue summary seems very out of date with what's going on in the MR - it's changing the form handling and the changes to alias repository are different to what's in the issue summary too.
- 🇬🇧United Kingdom james.williams
Thanks; I've now updated the issue summary.
@catch I'm not sure what you meant about form handling, as there's no mention of forms in the MR - but I'm guessing perhaps you were referring to the changes in the PathItem class, so I've added a specific mention of them in the proposed resolution. Otherwise, I'm not all that sure what you feel is specifically wrong with the issue summary? Of course I can well believe there's something needing more explanation!
- Status changed to Needs review
10 months ago 3:12pm 3 April 2024 - 🇬🇧United Kingdom james.williams
Resolved that last thread, moving the special handling for path aliases into the path_alias module.
(And for any language_hierarchy users, I've pushed a fix to respect that to its 2.x branch.)
:crossed_fingers:
- Status changed to Needs work
9 months ago 9:22pm 30 April 2024 The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".
This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.
Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues.
- Status changed to Needs review
9 months ago 9:58am 1 May 2024 - 🇬🇧United Kingdom james.williams
Resolved issues in MR (resolved merge conflict + added strict typing for new class files). Tests pass, and tests-only job fails as expected. Back to needs review; everything should be answered. Really looking forward to this finally getting over the last hurdle(s). Core development is one big exercise in persistance!
- Status changed to Needs work
8 months ago 10:28pm 19 May 2024 The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work".
This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done.
Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues.
- Status changed to Needs review
8 months ago 9:34am 20 May 2024 - 🇬🇧United Kingdom james.williams
Updated MR to be mergeable again. And of course some coding standards have tightened since the last update, so added a couple of trailing commas accordingly. So many hurdles, many of which are purely down to the amount of time this has sat waiting :sob: Very much looking forward to getting this one over the line eventually, I hope.
Though of course I realise we're now at beta for 11.0... so does that mean we now need to adjust the change record & deprecation to target 11.1 & 12 instead of 10.3 & 11? :despair:
- Status changed to Needs work
8 months ago 5:25pm 29 May 2024 - 🇺🇸United States smustgrave
Left some small nitpicky stuff. But deprecation believe needs to be updated + the associated change record.
- Status changed to Needs review
8 months ago 8:19am 30 May 2024 - 🇬🇧United Kingdom james.williams
I've resolved each of those and updated the change record.
I feel like there should really be a better process for chasing deprecation versions for long-running issues like this. All too often here it's been so long between reviews (I'm not complaining about that btw), and so having to manually update the versions just to chase that game is incredibly tedious :( Are there any efforts anywhere for improving that process perhaps?
- 🇧🇪Belgium RandalV
Hi @google01,
Merge request definitely applies to 10.3.x.
The contents of this: https://git.drupalcode.org/project/drupal/-/merge_requests/5373.diff
Should be downloaded and placed in a local folder (e.g. YOUR_PROJECT/patches/core/3091336.patch), make sure there's an empty line at the end, and then add `patches/core/3091336.patch` in your composer patches list. - 🇩🇪Germany J-Lee 🇩🇪🇪🇺
I have left a suggestion so that someone with write permission can apply it directly to MR.
- Status changed to RTBC
5 months ago 12:34pm 22 August 2024 - 🇺🇸United States smustgrave
Re-reviewed from before and believe all feedback has been addressed
- Status changed to Needs review
3 months ago 4:12pm 4 November 2024 - 🇬🇧United Kingdom james.williams
Thanks @catch ... ready for review again... :doubly_crossed_fingers:
- 🇧🇷Brazil thiagomoraesp
@randalv the way to apply the diff as a patch that you suggested in #138 yes applies the patch, but the problem persists in 10.3.8
- 🇬🇧United Kingdom james.williams
@thiagomoraesp when you say the problem persists - what exactly are you seeing vs what you expect? Do you have a module implementing code>hook_language_fallback_candidates_alter() (such as https://www.drupal.org/project/language_hierarchy → ) that would actually make use of this fix? The fix on its own shouldn't trigger any immediate improvement, it only facilitates other modules implementing change.
- 🇧🇷Brazil thiagomoraesp
@james.williams we have language hierarchy, but the fallback language is not working, if try to access a french version of a content that only exists in english, it is supposed to redirect to the english version, but is not doing that.
- 🇧🇷Brazil thiagomoraesp
@james.williams updated language hierarchy and now it is working, sorry :)
- First commit to issue fork.
- 🇬🇧United Kingdom oily Greater London
I have updated the fork. I fixed a merge conflict in .phpstan-baseline.php locally and pushed the commit. However the pipeline is now failing at the PHPSTAN and PHPCS stages. It may be necessary to revert to the last-known good version of the file to get the coding standards tests to work again.
- Status changed to Needs work
15 days ago 11:13am 6 January 2025 - 🇬🇧United Kingdom james.williams
Oh dear. But thanks for trying to help. There were still merge conflicts anyway, so I tried reverting that merge commit, and then re-merging, but that's basically saved reverts to what was in 11.x rather than fully merging the changes back in from 11.x. Hard-resetting the branch to the previous commit isn't possible either. I'll see what I can do but it might be better to just spin up a new MR. Would just be a shame to lose the history.
- Merge request !10820Issue #3091336: Use a proper language fallback mechanism for path.alias_repository service → (Open) created by james.williams
- 🇬🇧United Kingdom james.williams
I've opened MR !10820 with the same changes from MR !5373 from before that attempt at updating its branch, plus some fixes for the static code checks that have tightened in the meantime and a bump for the deprecation target version.
Compare with https://git.drupalcode.org/project/drupal/-/compare/d766bbd0ec9a2a63a5c8... - which compares the commit from MR !5373 before the merge attempt, with the current HEAD of 11.x.Unfortunately the package_manager module's Build tests are now failing, which is a mystery to me. Those tests pass locally for me! The test output includes the "Failed asserting that 500 is identical to 200" message ... but how would I diagnose what is causing the 500?
The last review was from @catch on 21st October (comment 142), for a couple of code improvements, after @smustgrave had set this to RTBC. I really hope we can get this resolved ASAP, as far more time has been spent addressing issues due to having to keep up-to-date with the goalposts moving, than actually addressing the problem :'-(
- 🇬🇧United Kingdom james.williams
james.williams → changed the visibility of the branch 11.x to hidden.
- 🇬🇧United Kingdom james.williams
Ah, I've been informed those package_manager Build tests can intermittently fail (thanks @nicxvan!); and yes, having now just re-run them again, they pass. Just the tests-only checks fail now, which is as intended.
- 🇬🇧United Kingdom james.williams
@j-lee try this attached patch for 10.4, which was from a snapshot of the changes in MR !5373 from before the attempts at resolving the merge conflicts.
- 🇬🇧United Kingdom oily Greater London
@j-lee When the 11.x MR is merged the fix will be/ can be backported to other branches e.g. the 10.4 branch
- 🇬🇧United Kingdom oily Greater London
Have reviewed the code and made a couple of suggestions.
- 🇨🇦Canada alberto56
Hi all, I was using the patch at #69 with Drupal 10.1, and when I upgraded to Drupal 10.4, the patch at #69 no longer applies. I tried the patch at #158, which does apply to Drupal 10.4, but in my usecase does not fix the issue.
I am including herein a version of the patch at #69 which now applies to 10.4, in case it might be of use to anyone.
- 🇨🇦Canada alberto56
Please ignore #161 and use this patch instead. It is identical to #69 except for one line which makes it compatible with Drupal 10.4