- Issue created by @znerol
Drupal 9.2.0-alpha1 โ will be released the week of May 3, 2021, which means new developments and disruptive changes should now be targeted for the 9.3.x-dev branch. For more information see the Drupal core minor version schedule โ and the Allowed changes during the Drupal core release cycle โ .
Drupal 9.1.0-alpha1 โ will be released the week of October 19, 2020, which means new developments and disruptive changes should now be targeted for the 9.2.x-dev branch. For more information see the Drupal 9 minor version schedule โ and the Allowed changes during the Drupal 9 release cycle โ .
Drupal 8.9.0-beta1 โ was released on March 20, 2020. 8.9.x is the final, long-term support (LTS) minor release of Drupal 8, which means new developments and disruptive changes should now be targeted against the 9.1.x-dev branch. For more information see the Drupal 8 and 9 minor version schedule โ and the Allowed changes during the Drupal 8 and 9 release cycles โ .
Drupal core is moving towards using a โmainโ branch. As an interim step, a new 11.x branch has been opened โ , as Drupal.org infrastructure cannot currently fully support a branch named
main
. New developments and disruptive changes should now be targeted for the11.x
branch, which currently accepts only minor-version allowed changes. For more information, see the Drupal core minor version schedule โ and the Allowed changes during the Drupal core release cycle โ .Drupal 9.5.0-beta2 โ and Drupal 10.0.0-beta2 โ were released on September 29, 2022, which means new developments and disruptive changes should now be targeted for the 10.1.x-dev branch. For more information see the Drupal core minor version schedule โ and the Allowed changes during the Drupal core release cycle โ .
Drupal 9.4.0-alpha1 โ was released on May 6, 2022, which means new developments and disruptive changes should now be targeted for the 9.5.x-dev branch. For more information see the Drupal core minor version schedule โ and the Allowed changes during the Drupal core release cycle โ .
Drupal 9.3.0-rc1 โ was released on November 26, 2021, which means new developments and disruptive changes should now be targeted for the 9.4.x-dev branch. For more information see the Drupal core minor version schedule โ and the Allowed changes during the Drupal core release cycle โ .
- Merge request !4407Issue #3109970: Convert uses of $_SESSION in forms and batch โ (Closed) created by znerol
- last update
over 1 year ago 29,771 pass, 4 fail - Status changed to Needs review
over 1 year ago 5:28pm 19 July 2023 - last update
over 1 year ago 29,818 pass, 2 fail - Status changed to Needs work
over 1 year ago 10:12pm 19 July 2023 - ๐จ๐ญSwitzerland znerol
Test fails in BigPipe, this is going to be a long day...
- last update
over 1 year ago 29,822 pass, 2 fail - ๐จ๐ญSwitzerland znerol
So, CSRF
$seed
isnull
in the test runner. BT:array ( 0 => array ( 'file' => './core/lib/Drupal/Core/Access/CsrfTokenGenerator.php', 'line' => 65, 'function' => 'unknown', ), 1 => array ( 'file' => './core/modules/big_pipe/tests/modules/big_pipe_test/src/BigPipePlaceholderTestCases.php', 'line' => 154, 'function' => 'get', 'class' => 'Drupal\\Core\\Access\\CsrfTokenGenerator', 'type' => '->', ), 2 => array ( 'file' => './core/modules/big_pipe/tests/src/Functional/BigPipeTest.php', 'line' => 437, 'function' => 'cases', 'class' => 'Drupal\\big_pipe_test\\BigPipePlaceholderTestCases', 'type' => '::', ), 3 => array ( 'file' => './core/modules/big_pipe/tests/src/Functional/BigPipeTest.php', 'line' => 165, 'function' => 'getTestCases', 'class' => 'Drupal\\Tests\\big_pipe\\Functional\\BigPipeTest', 'type' => '->', ), ...
This means that before the changes in
batch.inc
andFormBuilder.php
, the session (contents / session id) was shared between the test runner and the test site. After eliminating references to the$_SESSION
global in production code, this is not the case anymore. - last update
over 1 year ago 29,802 pass, 1 fail - ๐จ๐ญSwitzerland znerol
So, there is what happens. This is an excerpt of BigPipeTest::testBigPipe():
$this->setCsrfTokenSeedInTestEnvironment(); $cases = $this->getTestCases();
The first line extracts the CSRF token seed generated in the child site from the session record in the database table. Then it sets the CSRF seed via
session_manager.metadata_bag
service in the test runner.The call in the second line ends up in BigPipePlaceholderTestCases::cases() where test data and expectations are constructed.
Among other things this function calls into the
form_builder
service in order to construct theDrupal\big_pipe_test\Form\BigPipeTestForm
. Also it calls into RouteProcessorCsrf::renderPlaceholderCsrfToken in order to generate the token. That token is compared to the results retrieved from the child site.With the changes in the MR, the call into the session service via
FormBuilder.php
implicitly starts a session. That in turn will initialize the session metadata bag, and as a result the CSRF seed will be empty.One very simple way to work around this problem is to simply swap the test case construction in
BigPipePlaceholderTestCases::cases()
.Note that this scenario isn't likely to cause problems in production. This is because the session is initialized unconditionally in the session middleware. Hence, access to the session from places like the
FormBuilder
will not trigger implicit initialization. - ๐ซ๐ทFrance andypost
Note that this scenario isn't likely to cause problems in production
Not sure as contrib/custom code probably can cause session initialization, for example masquerade module but it needs to check manually
- ๐จ๐ญSwitzerland znerol
Not sure as contrib/custom code probably can cause session initialization, for example masquerade module but it needs to check manually
True. Core code can cause session initialization as well. But that only may lead to problems if all of the following conditions are met:
- The request did not go through the Session middleware and hence didn't get initialized.
- Something tries to set a value before a session initialization was caused by random core/contrib/custom code.
- Something tries to use that value after a session initialization was caused by random core/contrib/custom code.
- last update
over 1 year ago 29,826 pass - Status changed to Needs review
over 1 year ago 3:17pm 20 July 2023 - last update
over 1 year ago 29,826 pass - Status changed to RTBC
over 1 year ago 5:59pm 20 July 2023 - ๐ณ๐ฑNetherlands daffie
The pointed issue is RTBC so how to solve chicken/egg problem?
If the other issue lands before this one, then the MR from this issue needs to be updated. Or the other way around.
All changes look good to me.
The MR does what the IS states.
For me it is RTBC. - last update
over 1 year ago 29,879 pass - last update
over 1 year ago 29,877 pass - last update
over 1 year ago 29,882 pass - last update
over 1 year ago 29,886 pass - last update
over 1 year ago 29,908 pass - last update
over 1 year ago 29,942 pass, 2 fail - last update
over 1 year ago 29,946 pass - last update
over 1 year ago 29,953 pass - last update
over 1 year ago 29,943 pass, 2 fail - last update
over 1 year ago 29,958 pass - last update
over 1 year ago 29,958 pass 48:02 44:35 Running- last update
over 1 year ago 29,959 pass - last update
over 1 year ago 30,044 pass - last update
over 1 year ago 30,049 pass - last update
over 1 year ago 30,056 pass - Status changed to Needs work
over 1 year ago 8:11am 22 August 2023 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Needs work for one small comment addition to ensure we understand that there is a reason the BigPipe test cases have been flipped.
Also, AFAICT ๐ Add the session to the request in KernelTestBase, BrowserTestBase, and drush Fixed would ideally land first, because there are only
@todo
s HERE referencing the other issue, not the other way around. - Status changed to Needs review
about 1 year ago 1:43am 28 December 2023 - ๐ซ๐ทFrance andypost
Rebased and removed TODOs about commited ๐ Add the session to the request in KernelTestBase, BrowserTestBase, and drush Fixed
- ๐ซ๐ทFrance andypost
Views tests still needs some love and consistency in ๐ Use $this->request in ViewsExecutable::getExposedInput() consistently Needs review
- Status changed to RTBC
about 1 year ago 9:11am 28 December 2023 - ๐ณ๐ฑNetherlands daffie
All the code changes look good to me.
For me it is RTBC. - last update
about 1 year ago 30,762 pass, 13 fail - last update
about 1 year ago 30,764 pass, 13 fail 33:04 30:58 Running- last update
about 1 year ago Build Successful 48:04 34:20 Running- last update
about 1 year ago Build Successful - Status changed to Needs work
about 1 year ago 1:41am 8 January 2024 - ๐ฎ๐ณIndia prashant.c Dharamshala
Prashant.c โ made their first commit to this issueโs fork.
- Status changed to Needs review
about 1 year ago 6:38am 8 January 2024 - Status changed to Needs work
about 1 year ago 8:48am 8 January 2024 - Status changed to Needs review
about 1 year ago 10:01am 8 January 2024 - Status changed to RTBC
about 1 year ago 10:14am 8 January 2024 - Status changed to Needs work
about 1 year ago 10:35am 8 January 2024 - ๐บ๐ธUnited States dww
Whoops. ๐ in that case, Letโs open the follow up and add the @todo comment pointing it to it as part of this issue.
- ๐จ๐ญSwitzerland znerol
Opened the follow-up ๐ Remove calls to Request::hasSession() Active .
- Status changed to Needs review
about 1 year ago 12:40pm 8 January 2024 - Status changed to RTBC
about 1 year ago 2:12pm 8 January 2024 - ๐ณ๐ฑNetherlands daffie
The requested TODO has been added to the correct issue.
Back to RTBC. - last update
about 1 year ago Build Successful - ๐ณ๐ฟNew Zealand quietone
This issue created a followup with an @todo in the MR, I am adding that issue as a related item.
I did not find any unanswered questions. I updated credit.
- Status changed to Needs work
11 months ago 5:22pm 26 February 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
11 months ago 7:10pm 26 February 2024 - Status changed to RTBC
11 months ago 8:09pm 26 February 2024 - ๐บ๐ธUnited States smustgrave
Restoring status from #34 as reroll seems fine.
- Status changed to Needs review
11 months ago 11:20am 4 March 2024 - Status changed to Needs work
11 months ago 8:38am 8 March 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Making it more clear that this needs input from somebody working on the MR for this to proceed.
- Status changed to Needs review
11 months ago 1:24pm 8 March 2024 - ๐ซ๐ทFrance andypost
The reordering explained in #16 maybe comment should be paraphrased somehow but the thing is that session now living in both testing and tester sites.
So the session started in test via CSRF seed now should go before its usage
- ๐จ๐ญSwitzerland znerol
Let's try to keep the order of test cases. Instead, ensure that a session is started before storing the CSRF value in the session bag on the test runner.
- ๐บ๐ธUnited States smustgrave
So question, could this change be a breaking change for contrib modules? Saw that some core modules had to be updated
- ๐จ๐ญSwitzerland znerol
Good question.
The following command lists changes in production code. The one in
LanguageNegotiationSession
could be pushed to ๐ Remove calls to Request::hasSession() Active . But since the comment needs to be updated to point to the correct issue anyway, it doesn't hurt to fix it right here I think.% COLUMNS=999 git diff `git merge-base HEAD 11.x` --stat | grep -vi test core/includes/batch.inc | 16 ++++++++++------ core/includes/form.inc | 14 +++++++++----- core/lib/Drupal/Core/Form/FormBuilder.php | 8 +++++--- core/modules/language/src/Plugin/LanguageNegotiation/LanguageNegotiationSession.php | 4 +---
The rest of the changes are in tests, those are mostly necessary due to ๐ Add the session to the request in KernelTestBase, BrowserTestBase, and drush Fixed . Plus the CSRF fix in BigPipe.
% COLUMNS=999 git diff f8a2ccac36a8402ec404e4b7c421e073fcf0d052 --stat | grep -i test core/modules/big_pipe/tests/src/Functional/BigPipeTest.php | 15 +++++++++++++++ core/modules/user/tests/src/Kernel/UserAccountFormPasswordResetTest.php | 9 +-------- core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php | 4 ++++ core/tests/Drupal/Tests/Core/Form/FormTestBase.php | 3 +++
- ๐จ๐ญSwitzerland znerol
With the current MR we are down to zero references to the
$_SESSION
superglobal (except where it is required inSessionManager
andSessionTestController
).% git grep -l '$_SESSION' core/lib/Drupal/Core/Session/SessionManager.php core/modules/system/tests/modules/session_test/src/Controller/SessionTestController.php
- Status changed to RTBC
10 months ago 7:46pm 15 March 2024 - ๐บ๐ธUnited States smustgrave
Makes sense I think? The replacement seems fine I was just concerned about failing tests abruptly in contrib but think you answered. Rest looks fine.
- ๐ฌ๐งUnited Kingdom alexpott ๐ช๐บ๐
Committed and pushed 9334d6f100 to 11.x and 173217df7e to 10.3.x. Thanks!
-
alexpott โ
committed 173217df on 10.3.x
Issue #3109970 by znerol, andypost, Prashant.c, daffie, Wim Leers, dww,...
-
alexpott โ
committed 173217df on 10.3.x
- Status changed to Fixed
10 months ago 9:48am 18 March 2024 -
alexpott โ
committed 9334d6f1 on 11.x
Issue #3109970 by znerol, andypost, Prashant.c, daffie, Wim Leers, dww,...
-
alexpott โ
committed 9334d6f1 on 11.x
Automatically closed - issue fixed for 2 weeks with no activity.