diff --git a/.gitattributes b/.gitattributes
index 76ea8feeb1195cfdce9ee82e6a524b46d2e9a02f..e7b792f8407c7c95dd9a5f34646643adb4fa7a37 100644
--- a/.gitattributes
+++ b/.gitattributes
@@ -42,6 +42,9 @@
 *.xml     text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tab-in-indent,tabwidth=2
 *.yml     text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tab-in-indent,tabwidth=2
 
+# PHPStan's baseline uses tabs instead of spaces.
+core/.phpstan-baseline.php text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tabwidth=2 diff=php linguist-language=php
+
 # Define binary file attributes.
 # - Do not treat them as text.
 # - Include binary diff in patches instead of "binary files differ."
diff --git a/composer.json b/composer.json
index f524b607c25b5767d86f9986c8c3aa3e9610b0df..4b8b5cdc62c30b95e2b919594c60b3e58ad54650 100644
--- a/composer.json
+++ b/composer.json
@@ -105,8 +105,8 @@
         "drupal/cache_control_override": "^2.0",
         "drupal/ckeditor_indentblock": "^1.0",
         "drupal/config_ignore": "^3.0",
-        "drupal/core-composer-scaffold": "10.2.3",
-        "drupal/core-recommended": "10.2.3",
+        "drupal/core-composer-scaffold": "10.2.5",
+        "drupal/core-recommended": "10.2.5",
         "drupal/crop": "2.3",
         "drupal/ctools": "^4.0",
         "drupal/decorative_image_widget": "^1.0",
diff --git a/composer.lock b/composer.lock
index e9bc03b3297b8daec23a454a56ce986ef466d270..4d929151110be94a35a4fcae897b7a79a3938312 100644
--- a/composer.lock
+++ b/composer.lock
@@ -4,7 +4,7 @@
         "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
         "This file is @generated automatically"
     ],
-    "content-hash": "6b876dc6e77bf69fec234ae9fde8196b",
+    "content-hash": "ef0f4f18866f56138919ea142f834442",
     "packages": [
         {
             "name": "asm89/stack-cors",
@@ -2195,16 +2195,16 @@
         },
         {
             "name": "drupal/core",
-            "version": "10.2.3",
+            "version": "10.2.5",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core.git",
-                "reference": "cc8c7952f7013795b735f5c15290e76937163bb7"
+                "reference": "dddd242b74f40df892a7f16a48245c3b76d9b003"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/drupal/core/zipball/cc8c7952f7013795b735f5c15290e76937163bb7",
-                "reference": "cc8c7952f7013795b735f5c15290e76937163bb7",
+                "url": "https://api.github.com/repos/drupal/core/zipball/dddd242b74f40df892a7f16a48245c3b76d9b003",
+                "reference": "dddd242b74f40df892a7f16a48245c3b76d9b003",
                 "shasum": ""
             },
             "require": {
@@ -2352,13 +2352,13 @@
             ],
             "description": "Drupal is an open source content management platform powering millions of websites and applications.",
             "support": {
-                "source": "https://github.com/drupal/core/tree/10.2.3"
+                "source": "https://github.com/drupal/core/tree/10.2.5"
             },
-            "time": "2024-02-07T22:44:48+00:00"
+            "time": "2024-04-03T07:19:20+00:00"
         },
         {
             "name": "drupal/core-composer-scaffold",
-            "version": "10.2.3",
+            "version": "10.2.5",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core-composer-scaffold.git",
@@ -2402,22 +2402,22 @@
                 "drupal"
             ],
             "support": {
-                "source": "https://github.com/drupal/core-composer-scaffold/tree/10.2.3"
+                "source": "https://github.com/drupal/core-composer-scaffold/tree/10.2.5"
             },
             "time": "2024-01-26T14:59:30+00:00"
         },
         {
             "name": "drupal/core-recommended",
-            "version": "10.2.3",
+            "version": "10.2.5",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core-recommended.git",
-                "reference": "ee5d148455ca5792108a1fd007ae162ea2ffe859"
+                "reference": "bd7fe9e734a82762814d9c31255cd362d9c044f1"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/drupal/core-recommended/zipball/ee5d148455ca5792108a1fd007ae162ea2ffe859",
-                "reference": "ee5d148455ca5792108a1fd007ae162ea2ffe859",
+                "url": "https://api.github.com/repos/drupal/core-recommended/zipball/bd7fe9e734a82762814d9c31255cd362d9c044f1",
+                "reference": "bd7fe9e734a82762814d9c31255cd362d9c044f1",
                 "shasum": ""
             },
             "require": {
@@ -2426,7 +2426,7 @@
                 "doctrine/annotations": "~1.14.3",
                 "doctrine/deprecations": "~1.1.2",
                 "doctrine/lexer": "~2.1.0",
-                "drupal/core": "10.2.3",
+                "drupal/core": "10.2.5",
                 "egulias/email-validator": "~4.0.2",
                 "guzzlehttp/guzzle": "~7.8.1",
                 "guzzlehttp/promises": "~2.0.2",
@@ -2487,9 +2487,9 @@
             ],
             "description": "Core and its dependencies with known-compatible minor versions. Require this project INSTEAD OF drupal/core.",
             "support": {
-                "source": "https://github.com/drupal/core-recommended/tree/10.2.3"
+                "source": "https://github.com/drupal/core-recommended/tree/10.2.5"
             },
-            "time": "2024-02-07T22:44:48+00:00"
+            "time": "2024-04-03T07:19:20+00:00"
         },
         {
             "name": "drupal/crop",
diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php
index f23a83ca7ed369d6ef2e9478b700e6eecb0cab5f..b0b4c629c882adb0ab85eb16096868813a85ded4 100644
--- a/vendor/composer/autoload_classmap.php
+++ b/vendor/composer/autoload_classmap.php
@@ -1838,6 +1838,8 @@
     'Drupal\\Core\\Language\\LanguageManager' => $baseDir . '/web/core/lib/Drupal/Core/Language/LanguageManager.php',
     'Drupal\\Core\\Language\\LanguageManagerInterface' => $baseDir . '/web/core/lib/Drupal/Core/Language/LanguageManagerInterface.php',
     'Drupal\\Core\\Layout\\Annotation\\Layout' => $baseDir . '/web/core/lib/Drupal/Core/Layout/Annotation/Layout.php',
+    'Drupal\\Core\\Layout\\Icon\\IconBuilderInterface' => $baseDir . '/web/core/lib/Drupal/Core/Layout/Icon/IconBuilderInterface.php',
+    'Drupal\\Core\\Layout\\Icon\\SvgIconBuilder' => $baseDir . '/web/core/lib/Drupal/Core/Layout/Icon/SvgIconBuilder.php',
     'Drupal\\Core\\Layout\\LayoutDefault' => $baseDir . '/web/core/lib/Drupal/Core/Layout/LayoutDefault.php',
     'Drupal\\Core\\Layout\\LayoutDefinition' => $baseDir . '/web/core/lib/Drupal/Core/Layout/LayoutDefinition.php',
     'Drupal\\Core\\Layout\\LayoutInterface' => $baseDir . '/web/core/lib/Drupal/Core/Layout/LayoutInterface.php',
@@ -2035,6 +2037,7 @@
     'Drupal\\Core\\Queue\\Memory' => $baseDir . '/web/core/lib/Drupal/Core/Queue/Memory.php',
     'Drupal\\Core\\Queue\\QueueDatabaseFactory' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php',
     'Drupal\\Core\\Queue\\QueueFactory' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueFactory.php',
+    'Drupal\\Core\\Queue\\QueueFactoryInterface' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php',
     'Drupal\\Core\\Queue\\QueueGarbageCollectionInterface' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueGarbageCollectionInterface.php',
     'Drupal\\Core\\Queue\\QueueInterface' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueInterface.php',
     'Drupal\\Core\\Queue\\QueueWorkerBase' => $baseDir . '/web/core/lib/Drupal/Core/Queue/QueueWorkerBase.php',
diff --git a/vendor/composer/autoload_static.php b/vendor/composer/autoload_static.php
index 4178a3fe5cf413c07391ecc027061a69289d2f45..106c890ea6f5dd4d0b854c54692361c9a2b58c98 100644
--- a/vendor/composer/autoload_static.php
+++ b/vendor/composer/autoload_static.php
@@ -2494,6 +2494,8 @@ class ComposerStaticInit5c689ffcd54b9e495ed983fdce09b530
         'Drupal\\Core\\Language\\LanguageManager' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Language/LanguageManager.php',
         'Drupal\\Core\\Language\\LanguageManagerInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Language/LanguageManagerInterface.php',
         'Drupal\\Core\\Layout\\Annotation\\Layout' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/Annotation/Layout.php',
+        'Drupal\\Core\\Layout\\Icon\\IconBuilderInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/Icon/IconBuilderInterface.php',
+        'Drupal\\Core\\Layout\\Icon\\SvgIconBuilder' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/Icon/SvgIconBuilder.php',
         'Drupal\\Core\\Layout\\LayoutDefault' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/LayoutDefault.php',
         'Drupal\\Core\\Layout\\LayoutDefinition' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/LayoutDefinition.php',
         'Drupal\\Core\\Layout\\LayoutInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Layout/LayoutInterface.php',
@@ -2691,6 +2693,7 @@ class ComposerStaticInit5c689ffcd54b9e495ed983fdce09b530
         'Drupal\\Core\\Queue\\Memory' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/Memory.php',
         'Drupal\\Core\\Queue\\QueueDatabaseFactory' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php',
         'Drupal\\Core\\Queue\\QueueFactory' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueFactory.php',
+        'Drupal\\Core\\Queue\\QueueFactoryInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php',
         'Drupal\\Core\\Queue\\QueueGarbageCollectionInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueGarbageCollectionInterface.php',
         'Drupal\\Core\\Queue\\QueueInterface' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueInterface.php',
         'Drupal\\Core\\Queue\\QueueWorkerBase' => __DIR__ . '/../..' . '/web/core/lib/Drupal/Core/Queue/QueueWorkerBase.php',
diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json
index 42ebef38dd3b19b1795a0965da1f60934112692b..d05426d28367a2217b75589dffa122dcd082a95d 100644
--- a/vendor/composer/installed.json
+++ b/vendor/composer/installed.json
@@ -2302,17 +2302,17 @@
         },
         {
             "name": "drupal/core",
-            "version": "10.2.3",
-            "version_normalized": "10.2.3.0",
+            "version": "10.2.5",
+            "version_normalized": "10.2.5.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core.git",
-                "reference": "cc8c7952f7013795b735f5c15290e76937163bb7"
+                "reference": "dddd242b74f40df892a7f16a48245c3b76d9b003"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/drupal/core/zipball/cc8c7952f7013795b735f5c15290e76937163bb7",
-                "reference": "cc8c7952f7013795b735f5c15290e76937163bb7",
+                "url": "https://api.github.com/repos/drupal/core/zipball/dddd242b74f40df892a7f16a48245c3b76d9b003",
+                "reference": "dddd242b74f40df892a7f16a48245c3b76d9b003",
                 "shasum": ""
             },
             "require": {
@@ -2392,7 +2392,7 @@
             "suggest": {
                 "ext-zip": "Needed to extend the plugin.manager.archiver service capability with the handling of files in the ZIP format."
             },
-            "time": "2024-02-07T22:44:48+00:00",
+            "time": "2024-04-03T07:19:20+00:00",
             "type": "drupal-core",
             "extra": {
                 "drupal-scaffold": {
@@ -2466,14 +2466,14 @@
             ],
             "description": "Drupal is an open source content management platform powering millions of websites and applications.",
             "support": {
-                "source": "https://github.com/drupal/core/tree/10.2.3"
+                "source": "https://github.com/drupal/core/tree/10.2.5"
             },
             "install-path": "../../web/core"
         },
         {
             "name": "drupal/core-composer-scaffold",
-            "version": "10.2.3",
-            "version_normalized": "10.2.3.0",
+            "version": "10.2.5",
+            "version_normalized": "10.2.5.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core-composer-scaffold.git",
@@ -2519,23 +2519,23 @@
                 "drupal"
             ],
             "support": {
-                "source": "https://github.com/drupal/core-composer-scaffold/tree/10.2.3"
+                "source": "https://github.com/drupal/core-composer-scaffold/tree/10.2.5"
             },
             "install-path": "../drupal/core-composer-scaffold"
         },
         {
             "name": "drupal/core-recommended",
-            "version": "10.2.3",
-            "version_normalized": "10.2.3.0",
+            "version": "10.2.5",
+            "version_normalized": "10.2.5.0",
             "source": {
                 "type": "git",
                 "url": "https://github.com/drupal/core-recommended.git",
-                "reference": "ee5d148455ca5792108a1fd007ae162ea2ffe859"
+                "reference": "bd7fe9e734a82762814d9c31255cd362d9c044f1"
             },
             "dist": {
                 "type": "zip",
-                "url": "https://api.github.com/repos/drupal/core-recommended/zipball/ee5d148455ca5792108a1fd007ae162ea2ffe859",
-                "reference": "ee5d148455ca5792108a1fd007ae162ea2ffe859",
+                "url": "https://api.github.com/repos/drupal/core-recommended/zipball/bd7fe9e734a82762814d9c31255cd362d9c044f1",
+                "reference": "bd7fe9e734a82762814d9c31255cd362d9c044f1",
                 "shasum": ""
             },
             "require": {
@@ -2544,7 +2544,7 @@
                 "doctrine/annotations": "~1.14.3",
                 "doctrine/deprecations": "~1.1.2",
                 "doctrine/lexer": "~2.1.0",
-                "drupal/core": "10.2.3",
+                "drupal/core": "10.2.5",
                 "egulias/email-validator": "~4.0.2",
                 "guzzlehttp/guzzle": "~7.8.1",
                 "guzzlehttp/promises": "~2.0.2",
@@ -2598,7 +2598,7 @@
             "conflict": {
                 "webflo/drupal-core-strict": "*"
             },
-            "time": "2024-02-07T22:44:48+00:00",
+            "time": "2024-04-03T07:19:20+00:00",
             "type": "metapackage",
             "notification-url": "https://packagist.org/downloads/",
             "license": [
@@ -2606,7 +2606,7 @@
             ],
             "description": "Core and its dependencies with known-compatible minor versions. Require this project INSTEAD OF drupal/core.",
             "support": {
-                "source": "https://github.com/drupal/core-recommended/tree/10.2.3"
+                "source": "https://github.com/drupal/core-recommended/tree/10.2.5"
             },
             "install-path": null
         },
diff --git a/vendor/composer/installed.php b/vendor/composer/installed.php
index 61b123d80cee0f5dd6cec6388939d710174484e4..9a2199916a44263e8064aec3dbe9912f94a2121e 100644
--- a/vendor/composer/installed.php
+++ b/vendor/composer/installed.php
@@ -3,7 +3,7 @@
         'name' => 'osu-asc-webservices/d8-upstream',
         'pretty_version' => 'dev-main',
         'version' => 'dev-main',
-        'reference' => '3a85a933c520fb8c58e28fac4988495772aa8c3c',
+        'reference' => 'e4e576ca0d7244166e344ea9a55253d730460bf4',
         'type' => 'project',
         'install_path' => __DIR__ . '/../../',
         'aliases' => array(),
@@ -359,9 +359,9 @@
             'dev_requirement' => false,
         ),
         'drupal/core' => array(
-            'pretty_version' => '10.2.3',
-            'version' => '10.2.3.0',
-            'reference' => 'cc8c7952f7013795b735f5c15290e76937163bb7',
+            'pretty_version' => '10.2.5',
+            'version' => '10.2.5.0',
+            'reference' => 'dddd242b74f40df892a7f16a48245c3b76d9b003',
             'type' => 'drupal-core',
             'install_path' => __DIR__ . '/../../web/core',
             'aliases' => array(),
@@ -370,24 +370,24 @@
         'drupal/core-annotation' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-assertion' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-class-finder' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-composer-scaffold' => array(
-            'pretty_version' => '10.2.3',
-            'version' => '10.2.3.0',
+            'pretty_version' => '10.2.5',
+            'version' => '10.2.5.0',
             'reference' => '63effa1bc644e80a269e8b4415e627491d26fd3f',
             'type' => 'composer-plugin',
             'install_path' => __DIR__ . '/../drupal/core-composer-scaffold',
@@ -397,97 +397,97 @@
         'drupal/core-datetime' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-dependency-injection' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-diff' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-discovery' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-event-dispatcher' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-file-cache' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-file-security' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-filesystem' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-front-matter' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-gettext' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-graph' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-http-foundation' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-php-storage' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-plugin' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-proxy-builder' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-recommended' => array(
-            'pretty_version' => '10.2.3',
-            'version' => '10.2.3.0',
-            'reference' => 'ee5d148455ca5792108a1fd007ae162ea2ffe859',
+            'pretty_version' => '10.2.5',
+            'version' => '10.2.5.0',
+            'reference' => 'bd7fe9e734a82762814d9c31255cd362d9c044f1',
             'type' => 'metapackage',
             'install_path' => NULL,
             'aliases' => array(),
@@ -496,37 +496,37 @@
         'drupal/core-render' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-serialization' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-transliteration' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-utility' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-uuid' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/core-version' => array(
             'dev_requirement' => false,
             'replaced' => array(
-                0 => '10.2.3',
+                0 => '10.2.5',
             ),
         ),
         'drupal/crop' => array(
@@ -1402,7 +1402,7 @@
         'osu-asc-webservices/d8-upstream' => array(
             'pretty_version' => 'dev-main',
             'version' => 'dev-main',
-            'reference' => '3a85a933c520fb8c58e28fac4988495772aa8c3c',
+            'reference' => 'e4e576ca0d7244166e344ea9a55253d730460bf4',
             'type' => 'project',
             'install_path' => __DIR__ . '/../../',
             'aliases' => array(),
diff --git a/web/core/.cspell.json b/web/core/.cspell.json
index 1cba7aee114e656730f621f91c5312cdf9943eb4..78c3c99b605d5364a711ad75f13659e5a8a7e018 100644
--- a/web/core/.cspell.json
+++ b/web/core/.cspell.json
@@ -68,7 +68,8 @@
       "grey",
       "hte",
       "ist",
-      "please"
+      "please",
+      "queuing"
     ],
     "overrides": [
       {
diff --git a/web/core/.phpstan-baseline.php b/web/core/.phpstan-baseline.php
new file mode 100644
index 0000000000000000000000000000000000000000..fd7b759bd98865cded1f5c208b2510436503ed42
--- /dev/null
+++ b/web/core/.phpstan-baseline.php
@@ -0,0 +1,3446 @@
+<?php declare(strict_types = 1);
+
+$ignoreErrors = [];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$data_path in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/../composer/Plugin/Scaffold/Operations/AppendOp.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$app_root might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/assets/scaffold/files/default.settings.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$site_path might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/assets/scaffold/files/default.settings.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$new_set_index might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/form.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method getFromDriverName\\(\\) of class Drupal\\\\Core\\\\Extension\\\\DatabaseDriverList\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+  DatabaseDriverList\\:\\:get\\(\\) instead, passing a database driver namespace\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/install.core.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Function install_config_download_translations\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/install.core.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Function install_download_translation\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/install.core.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/theme.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$custom_theme might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/includes/theme.maintenance.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method registerLoader\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
+This method is deprecated and will be removed in
+            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Annotation/Plugin/Discovery/AnnotatedClassDiscovery.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Component\\\\Datetime\\\\DateTimePlus\\:\\:getTimeZone\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Datetime/DateTimePlus.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Datetime/DateTimePlus.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\Component\\\\DependencyInjection\\\\ServiceIdHashTrait in class Drupal\\\\Component\\\\DependencyInjection\\\\Container\\:
+in drupal\\:9\\.5\\.1 and is removed from drupal\\:11\\.0\\.0\\. Use the
+  \'Drupal\\\\Component\\\\DependencyInjection\\\\ReverseContainer\' service instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/DependencyInjection/Container.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$x0 might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$xi in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$y0 might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$yi in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$in_seq\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$lcs\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$seq\\.$#',
+	'count' => 7,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xchanged\\.$#',
+	'count' => 6,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xind\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xv\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$ychanged\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$yind\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$yv\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$k might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$seps might not be defined\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/lib/Drupal/Component/Diff/Engine/DiffEngine.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$cache_backend_class\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/FileCache/NullFileCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$cache_backend_configuration\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/FileCache/NullFileCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$collection\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/FileCache/NullFileCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$prefix\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/FileCache/NullFileCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Component\\\\Gettext\\\\PoMemoryWriter\\:\\:getHeader\\(\\) should return Drupal\\\\Component\\\\Gettext\\\\PoHeader but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Gettext/PoMemoryWriter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Component\\\\Gettext\\\\PoMemoryWriter\\:\\:getLangcode\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Gettext/PoMemoryWriter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$log_vars might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Component/Gettext/PoStreamReader.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$permission might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Access/AccessResult.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Access\\\\CheckProvider implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Access/CheckProvider.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Access\\\\CheckProvider\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Access/CheckProvider.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Access\\\\CsrfRequestHeaderAccessCheck\\:\\:applies\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Access/CsrfRequestHeaderAccessCheck.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Executable\\\\ExecutableInterface\\:\\:execute\\(\\) invoked with 1 parameter, 0 required\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Action/ActionBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Action/ActionManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Action/ActionManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Archiver\\\\ArchiverManager\\:\\:getInstance\\(\\) should return object\\|false but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Archiver/ArchiverManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$group_keys might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Asset/CssCollectionGrouper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$group_keys might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Asset/JsCollectionGrouper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Asset/JsCollectionRenderer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Block/BlockManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Block/BlockManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/ApcuBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Cache\\\\CacheFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/CacheFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\CacheFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/CacheFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\CacheTagsInvalidator\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/CacheTagsInvalidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\ChainedFastBackendFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/ChainedFastBackendFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/DatabaseBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/MemoryBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Core\\\\Cache\\\\NullBackend has an unused parameter \\$bin\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/NullBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Cache/PhpBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Condition/ConditionManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Condition/ConditionManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Core/Config/DatabaseStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Config/Entity/Query/Condition.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$theme_list might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Config/ExtensionInstallStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Config\\\\TypedConfigManager\\:\\:replaceVariable\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Config/TypedConfigManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_NULL of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_STATEMENT of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$statement might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Delete.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Database\\\\Query\\\\Delete\\:\\:execute\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Delete.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Insert.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Merge.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Database\\\\Query\\\\Merge\\:\\:__toString\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Merge.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_STATEMENT of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Select.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Truncate.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Update.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Upsert.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$affected_rows might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Database/Query/Upsert.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Datetime/DateHelper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\DependencyInjection\\\\ClassResolver implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DependencyInjection/ClassResolver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\DependencyInjection\\\\ClassResolver\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DependencyInjection/ClassResolver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\Component\\\\DependencyInjection\\\\ServiceIdHashTrait in class Drupal\\\\Core\\\\DependencyInjection\\\\ContainerBuilder\\:
+in drupal\\:9\\.5\\.1 and is removed from drupal\\:11\\.0\\.0\\. Use the
+  \'Drupal\\\\Component\\\\DependencyInjection\\\\ReverseContainer\' service instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DependencyInjection/ContainerBuilder.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method closing\\(\\) of class Drupal\\\\Component\\\\Diff\\\\WordLevelDiff\\:
+in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method orig\\(\\) of class Drupal\\\\Component\\\\Diff\\\\WordLevelDiff\\:
+in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Diff/DiffFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\DrupalKernel\\:\\:discoverServiceProviders\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DrupalKernel.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$container might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/DrupalKernel.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$container_definition might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DrupalKernel.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Interface Drupal\\\\Core\\\\DrupalKernelInterface extends deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/DrupalKernelInterface.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityConfirmFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/ContentEntityConfirmFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:doLoadMultiple\\(\\) should return array\\<Drupal\\\\Core\\\\Entity\\\\EntityInterface\\> but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/ContentEntityNullStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:doSave\\(\\) should return bool\\|int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/ContentEntityNullStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:has\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/ContentEntityNullStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$current_affected in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/ContentEntityStorageBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\Controller\\\\EntityController\\:\\:deleteTitle\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Controller/EntityController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$candidate_ids might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Entity/EntityFormDisplay.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$string in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityAutocompleteMatcher.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\Entity\\\\EntityBase\\:\\:\\$id\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\EntityConfirmFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityConfirmFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\Entity\\\\EntityDisplayBase\\:\\:\\$_serializedKeys\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityDisplayBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Entity\\\\EntityTypeManager implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityTypeManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Entity\\\\EntityTypeManager\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/EntityTypeManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\KeyValueStore\\\\KeyValueContentEntityStorage\\:\\:createTranslation\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/KeyValueStore/KeyValueContentEntityStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\KeyValueStore\\\\KeyValueContentEntityStorage\\:\\:createWithSampleValues\\(\\) should return Drupal\\\\Core\\\\Entity\\\\FieldableEntityInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/KeyValueStore/KeyValueContentEntityStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$selected_bundles might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Plugin/Validation/Constraint/ReferenceAccessConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Plugin/Validation/Constraint/ValidReferenceConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Entity\\\\Query\\\\QueryBase\\:\\:getClass\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Query/QueryBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$next_index_prefix might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Query/Sql/Tables.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$relationship_specifier might not be defined\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Query/Sql/Tables.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$revision_query might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$initial_storage_value in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Entity/Sql/SqlContentEntityStorageSchema.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\EventSubscriber\\\\KernelDestructionSubscriber implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/EventSubscriber/KernelDestructionSubscriber.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\EventSubscriber\\\\KernelDestructionSubscriber\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/EventSubscriber/KernelDestructionSubscriber.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method getFromDriverName\\(\\) of class Drupal\\\\Core\\\\Extension\\\\DatabaseDriverList\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+  DatabaseDriverList\\:\\:get\\(\\) instead, passing a database driver namespace\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Extension/DatabaseDriverList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$minor_version might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Extension/ExtensionVersion.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$callback in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldDefinition.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Field\\\\FieldItemBase\\:\\:generateSampleValue\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldItemBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Field\\\\FieldItemBase\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldItemBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Field\\\\FieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$values might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldTypePluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/FieldTypePluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/Plugin/Field/FieldFormatter/TimestampFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/Plugin/Field/FieldType/ChangedItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/Plugin/Field/FieldType/CreatedItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Field\\\\Plugin\\\\Field\\\\FieldType\\\\EntityReferenceItem\\:\\:generateSampleValue\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\Field\\\\Plugin\\\\Field\\\\FieldType\\\\NumericItemBase\\:\\:\\$value\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Field/Plugin/Field/FieldType/NumericItemBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\FTPExtension\\:\\:\\$connection\\.$#',
+	'count' => 19,
+	'path' => __DIR__ . '/lib/Drupal/Core/FileTransfer/FTPExtension.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\FileTransfer\\:\\:\\$chroot\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/lib/Drupal/Core/FileTransfer/FileTransfer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\FileTransfer\\\\FileTransfer\\:\\:__get\\(\\) should return bool\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/FileTransfer/FileTransfer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\SSH\\:\\:\\$connection\\.$#',
+	'count' => 9,
+	'path' => __DIR__ . '/lib/Drupal/Core/FileTransfer/SSH.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Core/Flood/DatabaseBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Form\\\\FormBuilder\\:\\:setInvalidTokenError\\(\\) should return \\$this\\(Drupal\\\\Core\\\\Form\\\\FormBuilder\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormBuilder.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$form_id in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormBuilder.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$form in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Form\\\\FormValidator\\:\\:setInvalidTokenError\\(\\) should return \\$this\\(Drupal\\\\Core\\\\Form\\\\FormValidator\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$is_empty_multiple might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$is_empty_null might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$is_empty_string might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Form/FormValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/KeyValueStore/KeyValueDatabaseExpirableFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\KeyValueStore\\\\NullStorageExpirable\\:\\:setIfNotExists\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/KeyValueStore/NullStorageExpirable.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\KeyValueStore\\\\NullStorageExpirable\\:\\:setWithExpireIfNotExists\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/KeyValueStore/NullStorageExpirable.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Lock\\\\NullLockBackend\\:\\:wait\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Lock/NullLockBackend.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Logger\\\\LoggerChannelFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Logger/LoggerChannelFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Logger\\\\LoggerChannelFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Logger/LoggerChannelFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$parent in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/Form/MenuLinkDefaultForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Menu\\\\MenuLinkManager\\:\\:getInstance\\(\\) should return object\\|false but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/MenuLinkManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Menu\\\\MenuLinkManager\\:\\:menuNameInUse\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/MenuLinkManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/MenuLinkManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
+in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
+  replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/MenuTreeStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Menu/MenuTreeStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Plugin/DefaultPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Core\\\\Queue\\\\Memory has an unused parameter \\$name\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Queue/Memory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Queue\\\\QueueFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Queue/QueueFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Queue\\\\QueueFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Queue/QueueFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$sort in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Render/Element/RenderElement.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$output in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Render/MainContent/AjaxRenderer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$page_bottom in empty\\(\\) always exists and is always falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Render/MainContent/HtmlRenderer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$page_top in empty\\(\\) always exists and is always falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Render/MainContent/HtmlRenderer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Routing/MatcherDumper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/Session/SessionHandler.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Session/SessionManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$current might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Site/SettingsEditor.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$index might not be defined\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/lib/Drupal/Core/Site/SettingsEditor.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\StackMiddleware\\\\Session\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/StackMiddleware/Session.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\StreamWrapper\\\\StreamWrapperManager implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/StreamWrapper/StreamWrapperManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\StreamWrapper\\\\StreamWrapperManager\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/StreamWrapper/StreamWrapperManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Template\\\\AttributeValueBase\\:\\:render\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Template/AttributeValueBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Core\\\\Template\\\\TwigEnvironment has an unused parameter \\$root\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Template/TwigEnvironment.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Template/TwigPhpStorageCache.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Core\\\\Test\\\\TestRunnerKernel has an unused parameter \\$allow_dumping\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Test/TestRunnerKernel.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Theme\\\\ThemeInitialization\\:\\:resolveStyleSheetPlaceholders\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Theme/ThemeInitialization.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$candidate might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Theme/ThemeManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$theme_engine in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Theme/ThemeManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\TypedData\\\\ListDataDefinition\\:\\:setDataType\\(\\) should return static\\(Drupal\\\\Core\\\\TypedData\\\\ListDataDefinition\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/TypedData/ListDataDefinition.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Core\\\\TypedData\\\\TypedData\\:\\:\\$value\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/lib/Drupal/Core/TypedData/TypedData.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$cache_key in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/TypedData/Validation/RecursiveContextualValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Update\\\\UpdateHookRegistryFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Update/UpdateHookRegistryFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Update\\\\UpdateHookRegistryFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Update/UpdateHookRegistryFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Update\\\\UpdateKernel\\:\\:discoverServiceProviders\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Update/UpdateKernel.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Core\\\\Update\\\\UpdateRegistryFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Update/UpdateRegistryFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Update\\\\UpdateRegistryFactory\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Update/UpdateRegistryFactory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\Core\\\\Updater\\\\Module\\:\\:postUpdateTasks\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/lib/Drupal/Core/Updater/Module.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\action\\\\Form\\\\ActionFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/action/src/Form/ActionFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$position might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/modules/block/tests/src/Functional/BlockRenderOrderTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$edit might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block/tests/src/Functional/BlockUiTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$dependency in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block_content/src/BlockContentAccessControlHandler.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\block_content\\\\BlockContentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block_content/src/BlockContentForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\block_content\\\\BlockContentTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block_content/src/BlockContentTypeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block_content/tests/src/Functional/BlockContentRevisionsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$loaded might not be defined\\.$#',
+	'count' => 9,
+	'path' => __DIR__ . '/modules/block_content/tests/src/Functional/BlockContentRevisionsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/block_content/tests/src/Functional/BlockContentSaveTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/block_content/tests/src/Kernel/Migrate/d6/MigrateBlockContentTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/block_content/tests/src/Kernel/Migrate/d6/MigrateCustomBlockContentTranslationTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$callable in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/book/src/BookExport.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\book\\\\BookOutline\\:\\:nextLink\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/book/src/BookOutline.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\book\\\\BookOutline\\:\\:prevLink\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/book/src/BookOutline.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\book\\\\Form\\\\BookOutlineForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/book/src/Form/BookOutlineForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$ghs_config_classes in empty\\(\\) always exists and is always falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/ckeditor5/src/Plugin/Validation/Constraint/StyleSensibleElementConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/CommentForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\comment\\\\CommentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/CommentForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/comment/src/CommentStatistics.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\comment\\\\CommentTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/CommentTypeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$state might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/Plugin/migrate/destination/EntityComment.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\comment\\\\Plugin\\\\views\\\\field\\\\NodeNewComments\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/Plugin/views/field/NodeNewComments.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$comment in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/src/Plugin/views/row/Rss.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/CommentBlockTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$position might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/CommentBlockTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$comment_values might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/CommentLanguageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$mode_text might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/CommentTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/CommentTranslationUITest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/comment/tests/src/Functional/Views/DefaultViewRecentCommentsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$data might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/config/src/Form/ConfigSingleImportForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/config_translation/src/FormElement/DateFormat.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\contact\\\\ContactFormEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/contact/src/ContactFormEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\contact\\\\Entity\\\\Message\\:\\:getPersonalRecipient\\(\\) should return Drupal\\\\user\\\\UserInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/contact/src/Entity/Message.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\contact\\\\MessageForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/contact/src/MessageForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$state in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/content_moderation/src/Form/ContentModerationStateForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\content_moderation\\\\ModerationInformation\\:\\:getAffectedRevisionTranslation\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_moderation/src/ModerationInformation.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\content_moderation\\\\ModerationInformation\\:\\:getDefaultRevisionId\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_moderation/src/ModerationInformation.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$checkbox_id might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/content_translation.admin.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$locked_languages might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/content_translation.admin.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$locked_languages might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/content_translation.module',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/content_translation/src/ContentTranslationHandler.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/src/Controller/ContentTranslationController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$source_name might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/src/Controller/ContentTranslationController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$unrestricted_tab_count might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/contextual/tests/src/FunctionalJavascript/EditModeTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\datetime\\\\Plugin\\\\Field\\\\FieldType\\\\DateTimeFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime/src/Plugin/Field/FieldType/DateTimeFieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\datetime\\\\Plugin\\\\Field\\\\FieldType\\\\DateTimeItem\\:\\:\\$date\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime/src/Plugin/Field/FieldType/DateTimeItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime/src/Plugin/Field/FieldType/DateTimeItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$date_part_order might not be defined\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/datetime/src/Plugin/Field/FieldWidget/DateTimeDatelistWidget.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$item in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime/src/Plugin/Validation/Constraint/DateTimeFormatConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/modules/datetime/tests/src/Functional/DateTimeFieldTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime/tests/src/Kernel/Views/FilterDateTimeTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeFieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeItem\\:\\:\\$end_date\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeItem\\:\\:\\$start_date\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$view in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/dblog/dblog.module',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/dblog/tests/src/Functional/DbLogTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/dblog/tests/src/Kernel/DbLogTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field/tests/modules/field_test/src/Plugin/Field/FieldFormatter/TestFieldEmptySettingFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field/tests/modules/field_test/src/Plugin/Field/FieldFormatter/TestFieldMultipleFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/field/tests/src/Functional/NestedFormTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$values might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field/tests/src/Kernel/FieldAttachStorageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field/tests/src/Kernel/Timestamp/TimestampFormatterTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity_display might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Access/FormModeAccessCheck.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity_display might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Access/ViewModeAccessCheck.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\field_ui\\\\FieldUI\\:\\:getOverviewRouteInfo\\(\\) should return Drupal\\\\Core\\\\Url but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/FieldUI.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$updated_columns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Form/EntityDisplayFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$updated_rows might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/field_ui/src/Form/EntityDisplayFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\field_ui\\\\Form\\\\EntityDisplayModeFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Form/EntityDisplayModeFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\field_ui\\\\Form\\\\FieldConfigEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Form/FieldConfigEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\field_ui\\\\Form\\\\FieldStorageConfigEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/field_ui/src/Form/FieldStorageConfigEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/file.install',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$file_upload in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/file.module',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$message might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/file.module',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$rows in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/src/Plugin/Field/FieldFormatter/TableFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\file\\\\Plugin\\\\Field\\\\FieldType\\\\FileFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/src/Plugin/Field/FieldType/FileFieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\file\\\\Plugin\\\\Field\\\\FieldType\\\\FileFieldItemList\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/src/Plugin/Field/FieldType/FileFieldItemList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/file/tests/src/Functional/FileFieldPathTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/file/tests/src/Functional/FileFieldRevisionTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$unexpected in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/tests/src/Functional/FileManagedTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\file\\\\Functional\\\\FileUploadJsonBasicAuthTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/tests/src/Functional/FileUploadJsonBasicAuthTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\file\\\\Functional\\\\FileUploadJsonCookieTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/tests/src/Functional/FileUploadJsonCookieTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/file/tests/src/Kernel/DeleteTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$unexpected in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/file/tests/src/Kernel/FileManagedUnitTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/file/tests/src/Kernel/UsageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$rows might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/filter/src/Plugin/Filter/FilterHtml.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\forum\\\\ForumManager\\:\\:getTopicOrder\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/forum/src/ForumManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$vocabulary in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/forum/src/ForumUninstallValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\history\\\\Plugin\\\\views\\\\field\\\\HistoryUserTimestamp\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/history/src/Plugin/views/field/HistoryUserTimestamp.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/history/src/Plugin/views/filter/HistoryUserTimestamp.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/history/tests/src/Kernel/Views/HistoryTimestampTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$image_style in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/image/src/Controller/ImageStyleDownloadController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$lock_name might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/image/src/Controller/ImageStyleDownloadController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\image\\\\Form\\\\ImageStyleEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/image/src/Form/ImageStyleEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\image\\\\Form\\\\ImageStyleFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/image/src/Form/ImageStyleFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\image\\\\Plugin\\\\Field\\\\FieldType\\\\ImageItem\\:\\:\\$height\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/image/src/Plugin/Field/FieldType/ImageItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\image\\\\Plugin\\\\Field\\\\FieldType\\\\ImageItem\\:\\:\\$width\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/image/src/Plugin/Field/FieldType/ImageItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$image_that_is_too_small_file might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/image/tests/src/Functional/ImageFieldValidateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$edit in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/image/tests/src/Functional/ImageStyleFlushTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/inline_form_errors/tests/src/Unit/FormErrorHandlerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$reason in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/src/Context/FieldResolver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\jsonapi\\\\JsonApiResource\\\\ResourceIdentifier\\:\\:getDataReferencePropertyName\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/src/JsonApiResource/ResourceIdentifier.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/src/Normalizer/EntityAccessDeniedHttpExceptionNormalizer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$group might not be defined\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/jsonapi/src/Query/Filter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\jsonapi\\\\Revisions\\\\VersionNegotiator\\:\\:getRevision\\(\\) should return Drupal\\\\Core\\\\Entity\\\\EntityInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/src/Revisions/VersionNegotiator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$created_entity might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/tests/src/Functional/ResourceTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$dynamic_cache might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/jsonapi/tests/src/Functional/ResourceTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$parseable_invalid_request_body might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/jsonapi/tests/src/Functional/ResourceTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$reason in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/jsonapi/tests/src/Functional/ResourceTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$id in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/jsonapi/tests/src/Unit/Normalizer/JsonApiDocumentTopLevelNormalizerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\language\\\\Form\\\\LanguageAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/language/src/Form/LanguageAddForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\language\\\\Form\\\\LanguageEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/language/src/Form/LanguageEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$key might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/language/src/Form/NegotiationBrowserForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$method_id might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/language/src/LanguageNegotiator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$langcode might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/language/src/Plugin/LanguageNegotiation/LanguageNegotiationContentEntity.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\link\\\\Plugin\\\\migrate\\\\process\\\\FieldLink has an unused parameter \\$migration\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/link/src/Plugin/migrate/process/FieldLink.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Function locale_config_batch_update_components\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/locale.bulk.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$item in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/Form/ExportForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/Form/TranslationStatusForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\locale\\\\LocaleDefaultConfigStorage\\:\\:read\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/LocaleDefaultConfigStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\locale\\\\LocaleProjectStorage\\:\\:deleteAll\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/LocaleProjectStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\locale\\\\PoDatabaseReader\\:\\:readItem\\(\\) should return Drupal\\\\Component\\\\Gettext\\\\PoItem but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/PoDatabaseReader.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\locale\\\\PoDatabaseWriter\\:\\:importString\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/PoDatabaseWriter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$plural in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/PoDatabaseWriter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\locale\\\\StringDatabaseStorage\\:\\:dbStringTable\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/src/StringDatabaseStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/locale/tests/src/Functional/LocaleUpdateBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/locale/tests/src/Functional/LocaleUpdateCronTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/locale/tests/src/Functional/LocaleUpdateInterfaceTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$error in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media/media.install',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\media\\\\MediaTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media/src/MediaTypeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$source in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media/src/MediaTypeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$resource_url on left side of \\?\\? always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media/src/OEmbed/UrlResolver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\media_library\\\\OpenerResolver\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media_library/src/OpenerResolver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$jpg_image might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/media_library/tests/src/FunctionalJavascript/EmbeddedFormWidgetTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\menu_link_content\\\\Form\\\\MenuLinkContentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/menu_link_content/src/Form/MenuLinkContentForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$uuid might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/menu_link_content/src/Plugin/Menu/MenuLinkContent.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\menu_ui\\\\MenuForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/menu_ui/src/MenuForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\migrate\\\\MigrateException has an unused parameter \\$code\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/MigrateException.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\migrate\\\\MigrateException has an unused parameter \\$previous\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/MigrateException.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method registerLoader\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
+This method is deprecated and will be removed in
+            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/Discovery/AnnotatedClassDiscoveryAutomatedProviders.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/MigrateDestinationPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/MigrateSourcePluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\migrate\\\\Plugin\\\\MigrationPluginManager has an unused parameter \\$language_manager\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/MigrationPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\ComponentEntityDisplayBase\\:\\:fields\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/migrate/destination/ComponentEntityDisplayBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\Config\\:\\:fields\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/migrate/destination/Config.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\Entity\\:\\:fields\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/migrate/destination/Entity.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$config might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/migrate/destination/EntityConfigBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\NullDestination\\:\\:import\\(\\) should return array\\|bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/src/Plugin/migrate/destination/NullDestination.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined static method static\\(Drupal\\\\Tests\\\\migrate\\\\Kernel\\\\MigrateTestBase\\)\\:\\:migrateDumpAlter\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate/tests/src/Kernel/MigrateTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$sub_process_plugins might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/migrate/tests/src/Unit/process/SubProcessTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/src/MigrationPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/src/NodeMigrateType.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\migrate_drupal\\\\Plugin\\\\migrate\\\\EntityReferenceTranslationDeriver has an unused parameter \\$base_plugin_id\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/src/Plugin/migrate/EntityReferenceTranslationDeriver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\migrate_drupal\\\\Plugin\\\\migrate\\\\source\\\\ContentEntityDeriver has an unused parameter \\$base_plugin_id\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/src/Plugin/migrate/source/ContentEntityDeriver.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Kernel/StateFileExistsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Kernel/d6/ValidateMigrationStateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Kernel/d7/ValidateMigrationStateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Unit/MigrateFieldPluginManagerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$statement might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/src/Batch/MigrateUpgradeImportBatch.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$connection might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/src/Form/CredentialForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$version might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/src/Form/CredentialForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/src/Form/MigrateUpgradeFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/src/Form/ReviewForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\CredentialFormTest\\:\\:installEntitySchema\\(\\)\\.$#',
+	'count' => 8,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/CredentialFormTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeExecuteTestBase\\:\\:installEntitySchema\\(\\)\\.$#',
+	'count' => 8,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeExecuteTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeFormStepsTest\\:\\:installEntitySchema\\(\\)\\.$#',
+	'count' => 8,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeFormStepsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeFormStepsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeTestBase\\:\\:getManagedFiles\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$patterns might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MultilingualReviewPageTestBase\\:\\:installEntitySchema\\(\\)\\.$#',
+	'count' => 8,
+	'path' => __DIR__ . '/modules/migrate_drupal_ui/tests/src/Functional/MultilingualReviewPageTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to deprecated property \\$needsCleanup of class Drupal\\\\mysql\\\\Driver\\\\Database\\\\mysql\\\\Connection\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There\'s no
+   replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/mysql/src/Driver/Database/mysql/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$last_insert_id might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/mysql/src/Driver/Database/mysql/Insert.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$string_ascii_check might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/mysql/tests/src/Kernel/mysql/SchemaTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$string_check might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/mysql/tests/src/Kernel/mysql/SchemaTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\node\\\\ConfigTranslation\\\\NodeTypeMapper\\:\\:setEntity\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/src/ConfigTranslation/NodeTypeMapper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\node\\\\NodeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/src/NodeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\node\\\\NodeGrantDatabaseStorage\\:\\:alterQuery\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/src/NodeGrantDatabaseStorage.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\node\\\\NodeTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/src/NodeTypeForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$node in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/src/Plugin/views/row/Rss.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/NodeAdminTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/NodeRevisionsAllTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/NodeRevisionsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/NodeSaveTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/NodeTranslationUITest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/Views/FrontPageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/Views/NodeIntegrationTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/node/tests/src/Functional/Views/Wizard/NodeRevisionWizardTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$changed in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListFloatItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/options/src/Plugin/Field/FieldType/ListFloatItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListIntegerItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/options/src/Plugin/Field/FieldType/ListIntegerItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListItemBase\\:\\:\\$value\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/options/src/Plugin/Field/FieldType/ListItemBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListItemBase\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/options/src/Plugin/Field/FieldType/ListItemBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListStringItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/options/src/Plugin/Field/FieldType/ListStringItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\path\\\\PathAliasForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/path/src/PathAliasForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$alias\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/path/src/Plugin/Field/FieldType/PathItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$langcode\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/path/src/Plugin/Field/FieldType/PathItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$pid\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/path/src/Plugin/Field/FieldType/PathItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/path/src/Plugin/Field/FieldType/PathItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/path_alias/src/AliasManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method makeSequenceName\\(\\) of class Drupal\\\\Core\\\\Database\\\\Connection\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is
+  no replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/pgsql/src/Driver/Database/pgsql/Schema.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$table_field might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/pgsql/src/Driver/Database/pgsql/Select.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\pgsql\\\\Driver\\\\Database\\\\pgsql\\\\Upsert\\:\\:execute\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/pgsql/src/Driver/Database/pgsql/Upsert.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method makeSequenceName\\(\\) of class Drupal\\\\Core\\\\Database\\\\Connection\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is
+  no replacement\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/pgsql/src/Update10101.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/pgsql/tests/src/Unit/SchemaTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$responsive_image_styles in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/responsive_image/src/Plugin/Field/FieldFormatter/ResponsiveImageFormatter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\responsive_image\\\\ResponsiveImageStyleForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/responsive_image/src/ResponsiveImageStyleForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$created_entity might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/modules/rest/tests/src/Functional/EntityResource/EntityResourceTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$working_to might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/search.module',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\search\\\\Form\\\\SearchPageAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/src/Form/SearchPageAddForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\search\\\\Form\\\\SearchPageEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/src/Form/SearchPageEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\search\\\\Form\\\\SearchPageFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/src/Form/SearchPageFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/src/SearchIndex.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\search\\\\SearchPageRepository\\:\\:setDefaultSearchPage\\(\\) should return static\\(Drupal\\\\search\\\\SearchPageRepository\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/src/SearchPageRepository.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/search/tests/src/Functional/SearchMultilingualEntityTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/search/tests/src/Functional/SearchRankingTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\serialization\\\\Normalizer\\\\EntityNormalizer\\:\\:getCustomSerializedPropertyNames\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/serialization/src/Normalizer/EntityNormalizer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\shortcut\\\\Form\\\\SetCustomize\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/shortcut/src/Form/SetCustomize.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\shortcut\\\\ShortcutForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/shortcut/src/ShortcutForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\shortcut\\\\ShortcutSetForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/shortcut/src/ShortcutSetForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$args might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/sqlite/src/Driver/Database/sqlite/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$statement might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/sqlite/src/Driver/Database/sqlite/Connection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\system\\\\Controller\\\\BatchController\\:\\:batchPage\\(\\) should return array\\|Symfony\\\\Component\\\\HttpFoundation\\\\Response but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Controller/BatchController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/DateFormatListBuilder.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Form/DateFormatDeleteForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Form/DateFormatEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\system\\\\Form\\\\DateFormatFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Form/DateFormatFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\system\\\\Form\\\\ModulesListNonStableConfirmForm\\:\\:getQuestion\\(\\) should return Drupal\\\\Core\\\\StringTranslation\\\\TranslatableMarkup but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Form/ModulesListNonStableConfirmForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$default_theme in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Form/ThemeSettingsForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$theme_settings in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/Plugin/migrate/destination/d7/ThemeSettings.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$violation_messages might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/src/SecurityAdvisories/SecurityAdvisory.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$directories might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/system.install',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$pdo_message might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/system.install',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$site_path might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/system.install',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$messages might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/batch_test/batch_test.callbacks.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated function deprecation_test_function\\(\\)\\:
+in drupal\\:8\\.4\\.0 and is removed from drupal\\:9\\.0\\.0\\. This is
+  the deprecation message for deprecated_test_function\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/deprecation_test/src/DeprecatedController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/entity_test/src/Plugin/Field/FieldType/ChangedTestItem.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$options might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/form_test/src/Form/FormTestTableSelectJsSelectForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\lazy_route_provider_install_test\\\\PluginManager has an unused parameter \\$cache_backend\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\lazy_route_provider_install_test\\\\PluginManager has an unused parameter \\$url_generator\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/module_test/src/PluginManagerCacheClearer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/plugin_test/src/Plugin/DefaultsTestPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/plugin_test/src/Plugin/MockBlockManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/plugin_test/src/Plugin/TestPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\service_provider_test\\\\TestClass implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/service_provider_test/src/TestClass.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\service_provider_test\\\\TestClass\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/modules/service_provider_test/src/TestClass.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Access to an undefined property Drupal\\\\Tests\\\\system\\\\Functional\\\\FileTransfer\\\\TestFileTransfer\\:\\:\\$connection\\.$#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/system/tests/src/Functional/FileTransfer/TestFileTransfer.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$form_output in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/system/tests/src/Functional/Form/FormTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$parent might not be defined\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/system/tests/src/Functional/Menu/BreadcrumbTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$expected_required_list_items might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/system/tests/src/Functional/Theme/ThemeUiTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/system/tests/src/Kernel/System/CronQueueTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/system/tests/src/Kernel/Token/TokenReplaceKernelTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$help_message might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/Form/OverviewTerms.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\taxonomy\\\\Plugin\\\\migrate\\\\source\\\\d7\\\\TermTranslation\\:\\:prepareRow\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/Plugin/migrate/source/d7/TermTranslation.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$inner_count might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/Plugin/views/argument/IndexTidDepth.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$inner_count might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTidDepth.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\taxonomy\\\\TermForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/TermForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\taxonomy\\\\TermForm\\:\\:validateForm\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/TermForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\taxonomy\\\\VocabularyForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/taxonomy/src/VocabularyForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$depth_count might not be defined\\.$#',
+	'count' => 4,
+	'path' => __DIR__ . '/modules/taxonomy/tests/src/Kernel/TermKernelTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/toolbar/src/Controller/ToolbarController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\tour\\\\TipPluginBase\\:\\:get\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/tour/src/TipPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$location on left side of \\?\\? always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/tour/src/TipPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$violation_messages might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/update/src/ProjectRelease.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/modules/update/src/UpdateProcessor.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$users might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Controller/UserAuthenticationController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Controller/UserController.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/user/src/EventSubscriber/UserRequestSubscriber.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$route_object might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Plugin/LanguageNegotiation/LanguageNegotiationUserAdmin.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$account in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Plugin/Validation/Constraint/ProtectedUserFieldConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$account in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Plugin/Validation/Constraint/UserMailRequiredValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Plugin/Validation/Constraint/UserMailRequiredValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\user\\\\Plugin\\\\views\\\\field\\\\UserData\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/Plugin/views/field/UserData.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\user\\\\ProfileForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/ProfileForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\user\\\\RegisterForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/RegisterForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\user\\\\RoleForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/src/RoleForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserCreateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserEditTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$name in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserLoginHttpTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$pass in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserLoginHttpTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 5,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserPasswordResetTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserPictureTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\Tests\\\\user\\\\Functional\\\\UserRegistrationRestTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserRegistrationRestTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/UserRegistrationTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Functional/Views/UserChangedTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Kernel/Views/HandlerFilterRolesTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Kernel/Views/HandlerFilterRolesTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$result in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/user/tests/src/Unit/UserAccessControlHandlerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Form\\\\ViewsFormMainForm\\:\\:getFormId\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Form/ViewsFormMainForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$display in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/Derivative/ViewsBlock.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method \\$this\\(Drupal\\\\views\\\\Plugin\\\\views\\\\HandlerBase\\)\\:\\:getFormula\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/HandlerBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\HandlerBase\\:\\:getTableJoin\\(\\) should return Drupal\\\\views\\\\Plugin\\\\views\\\\join\\\\JoinPluginBase but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/HandlerBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$group_types might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/HandlerBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/area/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\area\\\\HTTPStatusCode\\:\\:render\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/area/HTTPStatusCode.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$options_name might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/argument/ArgumentPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$plugin_name might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/argument/ArgumentPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$validate_types might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/argument/ArgumentPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/argument/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/argument/Date.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\cache\\\\CachePluginBase\\:\\:cacheGet\\(\\) should return bool but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/cache/CachePluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/cache/Time.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\views\\\\Plugin\\\\views\\\\display\\\\DisplayPluginBase has an unused parameter \\$configuration\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/display/DisplayPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$pager in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/display/DisplayPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$style in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/display/DisplayPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$access_plugin in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/display/PathPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$options might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Boolean.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/BulkForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Date.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\Date\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Date.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$custom_format might not be defined\\.$#',
+	'count' => 9,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Date.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\EntityField\\:\\:getFieldStorageDefinition\\(\\) should return Drupal\\\\Core\\\\Field\\\\FieldStorageDefinitionInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/EntityField.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\EntityField\\:\\:renderItems\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/EntityField.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$field_item_list in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/EntityField.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$options in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/FieldPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$raw_items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/FieldPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$style in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/FieldPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\Markup\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/Markup.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\PrerenderList\\:\\:renderItems\\(\\) should return string but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/field/PrerenderList.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\views\\\\Plugin\\\\views\\\\filter\\\\FilterPluginBase\\:\\:operators\\(\\)\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/FilterPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$groups might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/FilterPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$source might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/InOperator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$source might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/NumericFilter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$source might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/filter/StringFilter.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$left in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/join/JoinPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$join in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/query/Sql.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/relationship/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$sort_field might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/relationship/GroupwiseMax.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$sort_table might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/relationship/GroupwiseMax.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$items might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/sort/Broken.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$plugin in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/style/StylePluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$created_column in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/wizard/WizardPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$default_field might not be defined\\.$#',
+	'count' => 6,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/wizard/WizardPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$sorts in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/wizard/WizardPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$style_plugin in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/wizard/WizardPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$view in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/Plugin/views/wizard/WizardPluginBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/src/ViewExecutable.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$view in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/modules/views_test_data/views_test_data.views_execution.inc',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/BulkFormTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/DefaultViewsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/GlossaryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$link might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/TaxonomyGlossaryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 6,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/Wizard/ItemsPerPageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/Wizard/PagerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/views/tests/src/Functional/Wizard/SortingTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/FunctionalJavascript/ClickSortingAJAXTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 3,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/Handler/FieldDropbuttonTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/Handler/FieldFieldTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$rand1 might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/Plugin/StyleTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$rand2 might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/Plugin/StyleTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$rand3 might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/Plugin/StyleTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views/tests/src/Kernel/RenderCacheIntegrationTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 10,
+	'path' => __DIR__ . '/modules/views/tests/src/Unit/ViewsDataTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$relationship_handler in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/Form/Ajax/ConfigHandler.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Cannot unset offset \'\\#title\' on array\\{\\#theme_wrappers\\: array\\{\'container\'\\}, \\#attributes\\: array\\{class\\: array\\{\'scroll\'\\}, data\\-drupal\\-views\\-scroll\\: true\\}\\}\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/Form/Ajax/Display.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views_ui\\\\ViewEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$group_info might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$display_plugin in empty\\(\\) always exists and is not falsy\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewFormBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:getTypedData\\(\\) should return Drupal\\\\Core\\\\TypedData\\\\ComplexDataInterface but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewUI.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:set\\(\\) should return \\$this\\(Drupal\\\\views_ui\\\\ViewUI\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewUI.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:setSyncing\\(\\) should return \\$this\\(Drupal\\\\views_ui\\\\ViewUI\\) but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/src/ViewUI.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$message in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/views_ui/tests/src/FunctionalJavascript/PreviewTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workflows/src/Form/WorkflowEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowStateAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workflows/src/Form/WorkflowStateAddForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowStateEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workflows/src/Form/WorkflowStateEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowTransitionAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workflows/src/Form/WorkflowTransitionAddForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowTransitionEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workflows/src/Form/WorkflowTransitionEditForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workspaces\\\\EntityTypeInfo\\:\\:entityBaseFieldInfo\\(\\) should return array\\<Drupal\\\\Core\\\\Field\\\\FieldDefinitionInterface\\> but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/EntityTypeInfo.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workspaces\\\\Form\\\\WorkspaceForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/Form/WorkspaceForm.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/Plugin/Validation/Constraint/DeletedWorkspaceConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/Plugin/Validation/Constraint/EntityWorkspaceConflictConstraintValidator.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/WorkspaceAssociation.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workspaces\\\\WorkspaceMerger\\:\\:checkConflictsOnTarget\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/WorkspaceMerger.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/WorkspaceMerger.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Method Drupal\\\\workspaces\\\\WorkspacePublisher\\:\\:checkConflictsOnTarget\\(\\) should return array but return statement is missing\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/modules/workspaces/src/WorkspacePublisher.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$keyed_content might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/profiles/demo_umami/modules/demo_umami_content/src/InstallHelper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$structured_content might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/profiles/demo_umami/modules/demo_umami_content/src/InstallHelper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$project_stabilities might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/BuildTests/Composer/Template/ComposerProjectTemplatesTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\ClassRequiresAvailable\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\ClassRequiresUnavailable\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\MethodRequires\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\UsesCommandRequirements\\:
+in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$found might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Cache/ApcuBackendTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 12,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Cache/GenericCacheBackendUnitTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Config/ConfigInstallTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Config/ConfigInstallTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Database/ConnectionTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$expected_driver might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Database/DriverSpecificKernelTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 3,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Database/StatementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 3,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Database/StatementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 4,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/ContentEntityChangedTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$title might not be defined\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/CreateSampleEntityTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 9,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/EntityCrudHookTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$previous_untranslatable_field_value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/EntityDecoupledTranslationRevisionsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$field might not be defined\\.$#',
+	'count' => 9,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/EntitySchemaTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/EntityTypeConstraintsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$e might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$entity might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$new_field_schema_data might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$x might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Image/ToolkitGdTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$y might not be defined\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Image/ToolkitGdTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/KeyValueStore/GarbageCollectionTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/Render/Element/MachineNameTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/TempStore/TempStoreDatabaseTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 5,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/Core/TypedData/TypedDataTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/KernelTests/KernelTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\TestSite\\\\Commands\\\\TestSiteInstallCommand\\:\\:assertTrue\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to an undefined method Drupal\\\\TestSite\\\\Commands\\\\TestSiteInstallCommand\\:\\:fail\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/BrowserTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\Client\\:
+Client\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/BrowserTestBase.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method registerAutoloadNamespace\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
+This method is deprecated and will be removed in
+            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Annotation/Doctrine/DocParserTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Symfony\\\\Component\\\\ExpressionLanguage\\\\Expression has an unused parameter \\$expression\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/DependencyInjection/Dumper/OptimizedPhpArrayDumperTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/PhpStorage/FileStorageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/PhpStorage/FileStorageTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$charismatic\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$delightful\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$demure\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$electrostatic\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsConfigArrayKey has an unused parameter \\$config_name\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$configuration\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$foo\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$plugin_definition\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$plugin_id\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$what_am_i_doing_here\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsPluginId has an unused parameter \\$plugin_id\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Component/Plugin/StubPluginManagerBaseWithMapper.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Result of static method Drupal\\\\Composer\\\\Composer\\:\\:ensureComposerVersion\\(\\) \\(void\\) is used\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Composer/ComposerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Config/ConfigTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Tests\\\\Core\\\\Controller\\\\MockContainerAware implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Controller/ControllerResolverTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Tests\\\\Core\\\\Controller\\\\MockContainerAware\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Controller/ControllerResolverTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Database/ConditionTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method findCaller\\(\\) of class Drupal\\\\Core\\\\Database\\\\Log\\:
+in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+  Connection\\:\\:findCallerFromDebugBacktrace\\(\\)\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Database/Stub/StubConnection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Fetching class constant class of deprecated class Drupal\\\\Core\\\\Database\\\\StatementWrapper\\:
+in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
+  \\\\Drupal\\\\Core\\\\Database\\\\StatementWrapperIterator instead\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Database/Stub/StubConnection.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Tests\\\\Core\\\\DependencyInjection\\\\DependencySerializationTestDummy implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/DependencyInjection/DependencySerializationTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Trying to mock an undefined method getRevisionId\\(\\) on class Drupal\\\\Tests\\\\Core\\\\Entity\\\\UrlTestEntity\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Trying to mock an undefined method isDefaultRevision\\(\\) on class Drupal\\\\Tests\\\\Core\\\\Entity\\\\UrlTestEntity\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/EventSubscriber/RedirectResponseSubscriberTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/EventSubscriber/SpecialAttributesRouteSubscriberTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/EventSubscriber/SpecialAttributesRouteSubscriberTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Extension/ModuleHandlerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Form/FormCacheTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Form/FormErrorHandlerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\Client\\:
+Client\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Http/ClientFactoryTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Menu/ContextualLinkManagerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Menu/DefaultMenuLinkTreeManipulatorsTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Menu/LocalTaskManagerTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Menu/StaticMenuLinkOverridesTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/Discovery/DerivativeDiscoveryDecoratorTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Core\\\\Plugin\\\\Discovery\\\\TestContainerDerivativeDiscovery has an unused parameter \\$example_service\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/Discovery/TestContainerDerivativeDiscovery.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Constructor of class Drupal\\\\Tests\\\\Core\\\\Plugin\\\\TestPluginManager has an unused parameter \\$namespaces\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/TestPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Missing cache backend declaration for performance\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Plugin/TestPluginManager.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Render/ElementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Render/ElementTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Routing/RouteBuilderTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Security/DoTrustedCallbackTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
+https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Security/DoTrustedCallbackTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 2,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/TempStore/PrivateTempStoreTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 3,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/TempStore/SharedTempStoreTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Test/AssertContentTraitTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/UrlTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Tests\\\\Core\\\\Utility\\\\MockContainerAware implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Utility/CallableResolverTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Tests\\\\Core\\\\Utility\\\\MockContainerAware\\:
+since Symfony 6\\.4, use dependency injection instead$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Core/Utility/CallableResolverTest.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\ClientInterface\\:
+ClientInterface\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/DrupalTestBrowser.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Class Drupal\\\\Tests\\\\Listeners\\\\DrupalListener implements deprecated interface PHPUnit\\\\Framework\\\\TestListener\\.$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Listeners/DrupalListener.php',
+];
+$ignoreErrors[] = [
+	'message' => '#^Usage of deprecated trait PHPUnit\\\\Framework\\\\TestListenerDefaultImplementation in class Drupal\\\\Tests\\\\Listeners\\\\DrupalListener\\:
+The `TestListener` interface is deprecated$#',
+	'count' => 1,
+	'path' => __DIR__ . '/tests/Drupal/Tests/Listeners/DrupalListener.php',
+];
+
+return ['parameters' => ['ignoreErrors' => $ignoreErrors]];
diff --git a/web/core/MAINTAINERS.txt b/web/core/MAINTAINERS.txt
index ae502c7aa1295cf69645b147c3fcdaf94650a491..48499be2a1bc0a7904a5930556fd7e387361a541 100644
--- a/web/core/MAINTAINERS.txt
+++ b/web/core/MAINTAINERS.txt
@@ -421,6 +421,7 @@ Umami demo
 - Gareth Goodwin 'smaz' https://www.drupal.org/u/smaz
 - Keith Jay 'kjay' https://www.drupal.org/u/kjay
 - Ofer Shaal 'shaal' https://www.drupal.org/u/shaal
+- Ivan Berdinsky 'finnsky' https://www.drupal.org/u/finnsky
 
 Update Manager
 - Ted Bowman 'tedbow' https://www.drupal.org/u/tedbow
diff --git a/web/core/assets/scaffold/files/gitattributes b/web/core/assets/scaffold/files/gitattributes
index 76ea8feeb1195cfdce9ee82e6a524b46d2e9a02f..e7b792f8407c7c95dd9a5f34646643adb4fa7a37 100644
--- a/web/core/assets/scaffold/files/gitattributes
+++ b/web/core/assets/scaffold/files/gitattributes
@@ -42,6 +42,9 @@
 *.xml     text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tab-in-indent,tabwidth=2
 *.yml     text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tab-in-indent,tabwidth=2
 
+# PHPStan's baseline uses tabs instead of spaces.
+core/.phpstan-baseline.php text eol=lf whitespace=blank-at-eol,-blank-at-eof,-space-before-tab,tabwidth=2 diff=php linguist-language=php
+
 # Define binary file attributes.
 # - Do not treat them as text.
 # - Include binary diff in patches instead of "binary files differ."
diff --git a/web/core/includes/form.inc b/web/core/includes/form.inc
index d3aeb4577ec5baac4b1bb937f4a7227dba567dbf..1cb064e2757e7a8af3096cfd0aeb8cbb0f4c45ea 100644
--- a/web/core/includes/form.inc
+++ b/web/core/includes/form.inc
@@ -255,7 +255,6 @@ function template_preprocess_details(&$variables) {
       $variables['summary_attributes']['aria-controls'] = $element['#attributes']['id'];
     }
     $variables['summary_attributes']['aria-expanded'] = !empty($element['#attributes']['open']) ? 'true' : 'false';
-    $variables['summary_attributes']['aria-pressed'] = $variables['summary_attributes']['aria-expanded'];
   }
   $variables['title'] = (!empty($element['#title'])) ? $element['#title'] : '';
   // If the element title is a string, wrap it a render array so that markup
diff --git a/web/core/includes/install.inc b/web/core/includes/install.inc
index 083776a5377030be7ea87ae8f0b5400b4aefeb5d..6d2c29126048d71cf58363f2b873b4b9db51b158 100644
--- a/web/core/includes/install.inc
+++ b/web/core/includes/install.inc
@@ -511,7 +511,7 @@ function drupal_install_system($install_state) {
   $kernel = \Drupal::service('kernel');
   $kernel->shutdown();
   // Have installer rebuild from the disk, rather then building from scratch.
-  $kernel->rebuildContainer(FALSE);
+  $kernel->rebuildContainer();
   // Reboot the kernel with new container.
   $kernel->boot();
   $kernel->preHandle($request);
diff --git a/web/core/lib/Drupal.php b/web/core/lib/Drupal.php
index e8930b5fb7c62acc6e2e3c14d567e958892737f6..d16d0d14a8c2e1940e25f4b1ba0a29de6952a95e 100644
--- a/web/core/lib/Drupal.php
+++ b/web/core/lib/Drupal.php
@@ -75,7 +75,7 @@ class Drupal {
   /**
    * The current system version.
    */
-  const VERSION = '10.2.3';
+  const VERSION = '10.2.5';
 
   /**
    * Core API compatibility.
diff --git a/web/core/lib/Drupal/Component/Annotation/Doctrine/StaticReflectionParser.php b/web/core/lib/Drupal/Component/Annotation/Doctrine/StaticReflectionParser.php
index 10b9441c1a28e596cb20e320edd9f7936564db51..ce1aa0c083e115c65e21ba8335423640fc110291 100644
--- a/web/core/lib/Drupal/Component/Annotation/Doctrine/StaticReflectionParser.php
+++ b/web/core/lib/Drupal/Component/Annotation/Doctrine/StaticReflectionParser.php
@@ -205,7 +205,7 @@ protected function parse()
                     break;
                 case T_CLASS:
                     // Convert the attributes to fully qualified names.
-                    $this->classAttributes = array_map(fn($name) => strtolower($this->fullySpecifyName($name)), $attributeNames);
+                    $this->classAttributes = array_map(fn($name) => $this->fullySpecifyName($name), $attributeNames);
                     if ($last_token !== T_PAAMAYIM_NEKUDOTAYIM && $last_token !== T_NEW) {
                         $this->docComment['class'] = $docComment;
                         $docComment                = '';
@@ -346,7 +346,13 @@ public function getStaticReflectionParserForDeclaringClass($type, $name)
     public function hasClassAttribute(string $attribute): bool
     {
         $this->parse();
-        return in_array('\\' . ltrim(strtolower($attribute), '\\'), $this->classAttributes, TRUE);
+        foreach ($this->classAttributes as $classAttribute) {
+            if (is_a($classAttribute, $attribute, TRUE)) {
+                return TRUE;
+            }
+        }
+
+        return FALSE;
     }
 
     /**
diff --git a/web/core/lib/Drupal/Component/Plugin/PluginBase.php b/web/core/lib/Drupal/Component/Plugin/PluginBase.php
index 67691784b3ca9e2e975f57a51e9ce7369365dcd8..6a8955b0a1f5106dd2c5a4840c3ede69019a3ca9 100644
--- a/web/core/lib/Drupal/Component/Plugin/PluginBase.php
+++ b/web/core/lib/Drupal/Component/Plugin/PluginBase.php
@@ -22,7 +22,7 @@ abstract class PluginBase implements PluginInspectionInterface, DerivativeInspec
   /**
    * The plugin implementation definition.
    *
-   * @var array
+   * @var \Drupal\Component\Plugin\Definition\PluginDefinitionInterface|array
    */
   protected $pluginDefinition;
 
diff --git a/web/core/lib/Drupal/Component/Plugin/PluginInspectionInterface.php b/web/core/lib/Drupal/Component/Plugin/PluginInspectionInterface.php
index ab89a06f16af9d589eecc5545054da7d891ce0d2..9924c2b09782535a9de300944ced126faeb2301a 100644
--- a/web/core/lib/Drupal/Component/Plugin/PluginInspectionInterface.php
+++ b/web/core/lib/Drupal/Component/Plugin/PluginInspectionInterface.php
@@ -23,7 +23,7 @@ public function getPluginId();
   /**
    * Gets the definition of the plugin implementation.
    *
-   * @return array
+   * @return \Drupal\Component\Plugin\Definition\PluginDefinitionInterface|array
    *   The plugin definition, as returned by the discovery object used by the
    *   plugin manager.
    */
diff --git a/web/core/lib/Drupal/Core/Block/Attribute/Block.php b/web/core/lib/Drupal/Core/Block/Attribute/Block.php
index 3e5fbc6be88c76107e31755d2e330c89372f0b57..275e399395a86c43cec111512972d7204f4b5e3a 100644
--- a/web/core/lib/Drupal/Core/Block/Attribute/Block.php
+++ b/web/core/lib/Drupal/Core/Block/Attribute/Block.php
@@ -20,7 +20,7 @@ class Block extends Plugin {
    *   The administrative label of the block.
    * @param \Drupal\Core\StringTranslation\TranslatableMarkup|null $category
    *   (optional) The category in the admin UI where the block will be listed.
-   * @param \Drupal\Core\Annotation\ContextDefinition[] $context_definitions
+   * @param \Drupal\Core\Plugin\Context\ContextDefinitionInterface[] $context_definitions
    *   (optional) An array of context definitions describing the context used by
    *   the plugin. The array is keyed by context names.
    * @param string|null $deriver
diff --git a/web/core/lib/Drupal/Core/Config/Plugin/Validation/Constraint/ConfigExistsConstraintValidator.php b/web/core/lib/Drupal/Core/Config/Plugin/Validation/Constraint/ConfigExistsConstraintValidator.php
index 590a3056a110eb7b56674ba1def000eae3d97826..83067c2c1b59339e33e325eac18cc68a7ad30d44 100644
--- a/web/core/lib/Drupal/Core/Config/Plugin/Validation/Constraint/ConfigExistsConstraintValidator.php
+++ b/web/core/lib/Drupal/Core/Config/Plugin/Validation/Constraint/ConfigExistsConstraintValidator.php
@@ -43,6 +43,11 @@ public static function create(ContainerInterface $container) {
    * {@inheritdoc}
    */
   public function validate(mixed $name, Constraint $constraint) {
+    // This constraint may be used to validate nullable (optional) values.
+    if ($name === NULL) {
+      return;
+    }
+
     if (!in_array($name, $this->configFactory->listAll(), TRUE)) {
       $this->context->addViolation($constraint->message, ['@name' => $name]);
     }
diff --git a/web/core/lib/Drupal/Core/Database/Connection.php b/web/core/lib/Drupal/Core/Database/Connection.php
index cdaf0d19ddd56f0bc2add9a73e376f349c02a54e..5a097673ec3d7882dad2aac3344c36d22b714024 100644
--- a/web/core/lib/Drupal/Core/Database/Connection.php
+++ b/web/core/lib/Drupal/Core/Database/Connection.php
@@ -292,6 +292,31 @@ public function __destruct() {
     $this->connection = NULL;
   }
 
+  /**
+   * Commits all the open transactions.
+   *
+   * @internal
+   *   This method exists only to work around a bug caused by Drupal incorrectly
+   *   relying on object destruction order to commit transactions. Xdebug 3.3.0
+   *   changes the order of object destruction when the develop mode is enabled.
+   */
+  public function commitAll() {
+    $manager = $this->transactionManager();
+    if ($manager && $manager->inTransaction() && method_exists($manager, 'commitAll')) {
+      $this->transactionManager()->commitAll();
+    }
+
+    // BC layer.
+    // @phpstan-ignore-next-line
+    if (!empty($this->transactionLayers)) {
+      // Make all transactions committable.
+      // @phpstan-ignore-next-line
+      $this->transactionLayers = array_fill_keys(array_keys($this->transactionLayers), FALSE);
+      // @phpstan-ignore-next-line
+      $this->popCommittableTransactions();
+    }
+  }
+
   /**
    * Returns the client-level database connection object.
    *
diff --git a/web/core/lib/Drupal/Core/Database/Database.php b/web/core/lib/Drupal/Core/Database/Database.php
index b7fd9ed419c478b379ae8bcdeea307d69cc88cfa..d2d1f1262fb60bd520e512ae1b6baf54a742e769 100644
--- a/web/core/lib/Drupal/Core/Database/Database.php
+++ b/web/core/lib/Drupal/Core/Database/Database.php
@@ -493,10 +493,18 @@ public static function closeConnection($target = NULL, $key = NULL) {
     if (!isset($key)) {
       $key = self::$activeKey;
     }
-    if (isset($target)) {
+    if (isset($target) && isset(self::$connections[$key][$target])) {
+      if (self::$connections[$key][$target] instanceof Connection) {
+        self::$connections[$key][$target]->commitAll();
+      }
       unset(self::$connections[$key][$target]);
     }
-    else {
+    elseif (isset(self::$connections[$key])) {
+      foreach (self::$connections[$key] as $connection) {
+        if ($connection instanceof Connection) {
+          $connection->commitAll();
+        }
+      }
       unset(self::$connections[$key]);
     }
     // Force garbage collection to run. This ensures that client connection
@@ -577,6 +585,7 @@ public static function convertDbUrlToConnectionInfo($url, $root, ?bool $include_
     // called during regular runtime.
     $additional_class_loader = new ClassLoader();
     $additional_class_loader->addPsr4($driverNamespace . '\\', $driver->getPath());
+    $additional_class_loader->register();
     $connection_class = $driverNamespace . '\\Connection';
     if (!class_exists($connection_class)) {
       throw new \InvalidArgumentException("Can not convert '$url' to a database connection, class '$connection_class' does not exist");
@@ -747,4 +756,45 @@ private static function isWithinModuleNamespace(string $namespace) {
     return ($first === 'Drupal' && strtolower($second) === $second);
   }
 
+  /**
+   * Calls commitAll() on all the open connections.
+   *
+   * If drupal_register_shutdown_function() exists the commit will occur during
+   * shutdown so that it occurs at the latest possible moment.
+   *
+   * @param bool $shutdown
+   *   Internal param to denote that the method is being called by
+   *   _drupal_shutdown_function().
+   *
+   * @return void
+   *
+   * @internal
+   *   This method exists only to work around a bug caused by Drupal incorrectly
+   *   relying on object destruction order to commit transactions. Xdebug 3.3.0
+   *   changes the order of object destruction when the develop mode is enabled.
+   */
+  public static function commitAllOnShutdown(bool $shutdown = FALSE): void {
+    static $registered = FALSE;
+
+    if ($shutdown) {
+      foreach (self::$connections as $targets) {
+        foreach ($targets as $connection) {
+          if ($connection instanceof Connection) {
+            $connection->commitAll();
+          }
+        }
+      }
+      return;
+    }
+
+    if (!function_exists('drupal_register_shutdown_function')) {
+      return;
+    }
+
+    if (!$registered) {
+      $registered = TRUE;
+      drupal_register_shutdown_function('\Drupal\Core\Database\Database::commitAllOnShutdown', TRUE);
+    }
+  }
+
 }
diff --git a/web/core/lib/Drupal/Core/Database/Query/SelectInterface.php b/web/core/lib/Drupal/Core/Database/Query/SelectInterface.php
index 2c4416ad26c6a1023e2574cabf17d0a85efdb9f9..2293c45ffe0512d3d5c6525d78f32c55ebd9e8a5 100644
--- a/web/core/lib/Drupal/Core/Database/Query/SelectInterface.php
+++ b/web/core/lib/Drupal/Core/Database/Query/SelectInterface.php
@@ -328,7 +328,7 @@ public function leftJoin($table, $alias = NULL, $condition = NULL, $arguments =
   /**
    * Join against another table in the database.
    *
-   * This method does the "hard" work of queuing up a table to be joined against.
+   * This method does the "hard" work of queueing up a table to be joined against.
    * In some cases, that may include dipping into the Schema API to find the necessary
    * fields on which to join.
    *
diff --git a/web/core/lib/Drupal/Core/Database/Transaction.php b/web/core/lib/Drupal/Core/Database/Transaction.php
index 062dd177d09e6ee3a63af1bcb6acf4d1de46c153..2c1ea5e0458b97bac34e74a16f7a823128f67f02 100644
--- a/web/core/lib/Drupal/Core/Database/Transaction.php
+++ b/web/core/lib/Drupal/Core/Database/Transaction.php
@@ -57,6 +57,11 @@ public function __construct(
     $name = NULL,
     protected readonly string $id = '',
   ) {
+    // Transactions rely on objects being destroyed in order to be committed.
+    // PHP makes no guarantee about the order in which objects are destroyed so
+    // ensure all transactions are committed on shutdown.
+    Database::commitAllOnShutdown();
+
     if ($connection->transactionManager()) {
       $this->connection = $connection;
       $this->name = $name;
diff --git a/web/core/lib/Drupal/Core/Database/Transaction/TransactionManagerBase.php b/web/core/lib/Drupal/Core/Database/Transaction/TransactionManagerBase.php
index 34bb51689dc4b536ea0f6cc97412eb6788ca6e37..5f31bd605a646b9a3e9764b93eaadb486d3c0084 100644
--- a/web/core/lib/Drupal/Core/Database/Transaction/TransactionManagerBase.php
+++ b/web/core/lib/Drupal/Core/Database/Transaction/TransactionManagerBase.php
@@ -127,6 +127,20 @@ protected function stack(): array {
     return $this->stack;
   }
 
+  /**
+   * Commits the entire transaction stack.
+   *
+   * @internal
+   *   This method exists only to work around a bug caused by Drupal incorrectly
+   *   relying on object destruction order to commit transactions. Xdebug 3.3.0
+   *   changes the order of object destruction when the develop mode is enabled.
+   */
+  public function commitAll(): void {
+    foreach (array_reverse($this->stack()) as $id => $item) {
+      $this->unpile($item->name, $id);
+    }
+  }
+
   /**
    * Adds an item to the transaction stack.
    *
@@ -253,7 +267,6 @@ public function unpile(string $name, string $id): void {
     // DDL statement breaking an active transaction). That should be listed in
     // $voidedItems, so we can remove it from there.
     if (!isset($this->stack()[$id]) || $this->stack()[$id]->name !== $name) {
-      assert(isset($this->voidedItems[$id]), "Transaction {$id}/{$name} is out of sequence. Active stack: " . $this->dumpStackItemsAsString());
       unset($this->voidedItems[$id]);
       return;
     }
diff --git a/web/core/lib/Drupal/Core/Datetime/DrupalDateTime.php b/web/core/lib/Drupal/Core/Datetime/DrupalDateTime.php
index ad2a89f08cf9fb6fe00bb1bb0091003504cfbd35..172331cf5f841aa40fb6f27a7cc03a5e56de0545 100644
--- a/web/core/lib/Drupal/Core/Datetime/DrupalDateTime.php
+++ b/web/core/lib/Drupal/Core/Datetime/DrupalDateTime.php
@@ -3,6 +3,7 @@
 namespace Drupal\Core\Datetime;
 
 use Drupal\Component\Datetime\DateTimePlus;
+use Drupal\Core\DependencyInjection\DependencySerializationTrait;
 use Drupal\Core\StringTranslation\StringTranslationTrait;
 
 /**
@@ -21,6 +22,9 @@
 class DrupalDateTime extends DateTimePlus {
 
   use StringTranslationTrait;
+  use DependencySerializationTrait {
+    __sleep as defaultSleep;
+  }
 
   /**
    * Formatted strings translation cache.
@@ -52,7 +56,7 @@ class DrupalDateTime extends DateTimePlus {
    *
    * @var array
    */
-  protected $formatTranslationCache;
+  protected $formatTranslationCache = [];
 
   /**
    * Constructs a date object.
@@ -166,4 +170,11 @@ public function format($format, $settings = []) {
     return $value;
   }
 
+  /**
+   * {@inheritdoc}
+   */
+  public function __sleep(): array {
+    return array_diff($this->defaultSleep(), ['formatTranslationCache']);
+  }
+
 }
diff --git a/web/core/lib/Drupal/Core/Datetime/Plugin/Field/FieldWidget/TimestampDatetimeWidget.php b/web/core/lib/Drupal/Core/Datetime/Plugin/Field/FieldWidget/TimestampDatetimeWidget.php
index af3fd0dcee2135e3e8a4d1d2c797379f85ed6621..88efd5efe46ff501459ab871d58f90d13f1515c9 100644
--- a/web/core/lib/Drupal/Core/Datetime/Plugin/Field/FieldWidget/TimestampDatetimeWidget.php
+++ b/web/core/lib/Drupal/Core/Datetime/Plugin/Field/FieldWidget/TimestampDatetimeWidget.php
@@ -25,8 +25,7 @@ class TimestampDatetimeWidget extends WidgetBase {
    * {@inheritdoc}
    */
   public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
-    $parent_entity = $items->getParent()->getValue();
-    $default_value = (!$parent_entity->isNew() && isset($items[$delta]->value)) ? DrupalDateTime::createFromTimestamp($items[$delta]->value) : '';
+    $default_value = isset($items[$delta]->value) ? DrupalDateTime::createFromTimestamp($items[$delta]->value) : '';
     $element['value'] = $element + [
       '#type' => 'datetime',
       '#default_value' => $default_value,
diff --git a/web/core/lib/Drupal/Core/DependencyInjection/Compiler/RegisterStreamWrappersPass.php b/web/core/lib/Drupal/Core/DependencyInjection/Compiler/RegisterStreamWrappersPass.php
index f1ea8cd5b79bb16ad0e3e8ca9811379afe966348..3fa6c3848397c0e76d9c79e0f3a0c2eb06808802 100644
--- a/web/core/lib/Drupal/Core/DependencyInjection/Compiler/RegisterStreamWrappersPass.php
+++ b/web/core/lib/Drupal/Core/DependencyInjection/Compiler/RegisterStreamWrappersPass.php
@@ -20,11 +20,18 @@ public function process(ContainerBuilder $container) {
 
     $stream_wrapper_manager = $container->getDefinition('stream_wrapper_manager');
 
-    foreach ($container->findTaggedServiceIds('stream_wrapper') as $id => $attributes) {
+    foreach ($container->findTaggedServiceIds('stream_wrapper') as $id => $tags) {
       $class = $container->getDefinition($id)->getClass();
-      $scheme = $attributes[0]['scheme'];
-
-      $stream_wrapper_manager->addMethodCall('addStreamWrapper', [$id, $class, $scheme]);
+      // Loop through all the tags for this stream wrapper as we may have
+      // multiple schemes.
+      foreach ($tags as $attributes) {
+        $scheme = $attributes['scheme'];
+        $stream_wrapper_manager->addMethodCall('addStreamWrapper', [
+          $id,
+          $class,
+          $scheme,
+        ]);
+      }
     }
   }
 
diff --git a/web/core/lib/Drupal/Core/Entity/EntityBase.php b/web/core/lib/Drupal/Core/Entity/EntityBase.php
index 79e61b3e14a461b0db9aeadea816806afc9b21b1..781417760ce6ec6b12f7a58b13bb15887d66481d 100644
--- a/web/core/lib/Drupal/Core/Entity/EntityBase.php
+++ b/web/core/lib/Drupal/Core/Entity/EntityBase.php
@@ -164,25 +164,27 @@ public function toUrl($rel = NULL, array $options = []) {
     // The links array might contain URI templates set in annotations.
     $link_templates = $this->linkTemplates();
 
-    // Use the canonical link template by default, or edit-form if there is not
-    // a canonical one.
-    if ($rel === NULL) {
-      $rel_candidates = array_intersect(
-        ['canonical', 'edit-form'],
-        array_flip($link_templates),
-      );
-      $rel = array_shift($rel_candidates);
-      if ($rel === NULL) {
-        throw new UndefinedLinkTemplateException("Cannot generate default URL because no link template 'canonical' or 'edit-form' was found for the '{$this->getEntityTypeId()}' entity type");
-      }
-    }
-
     // Links pointing to the current revision point to the actual entity. So
     // instead of using the 'revision' link, use the 'canonical' link.
     if ($rel === 'revision' && $this instanceof RevisionableInterface && $this->isDefaultRevision()) {
       $rel = 'canonical';
     }
 
+    $exception_message = "No link template '$rel' found for the '{$this->getEntityTypeId()}' entity type";
+    // Use the canonical link template by default, or edit-form if there is not
+    // a canonical one.
+    if ($rel === NULL) {
+      if (isset($link_templates['canonical'])) {
+        $rel = 'canonical';
+      }
+      elseif (isset($link_templates['edit-form'])) {
+        $rel = 'edit-form';
+      }
+      else {
+        $exception_message = "Cannot generate default URL because no link template 'canonical' or 'edit-form' was found for the '{$this->getEntityTypeId()}' entity type";
+      }
+    }
+
     if (isset($link_templates[$rel])) {
       $route_parameters = $this->urlRouteParameters($rel);
       $route_name = "entity.{$this->entityTypeId}." . str_replace(['-', 'drupal:'], ['_', ''], $rel);
@@ -206,7 +208,7 @@ public function toUrl($rel = NULL, array $options = []) {
         $uri = call_user_func($uri_callback, $this);
       }
       else {
-        throw new UndefinedLinkTemplateException("No link template '$rel' found for the '{$this->getEntityTypeId()}' entity type");
+        throw new UndefinedLinkTemplateException($exception_message);
       }
     }
 
diff --git a/web/core/lib/Drupal/Core/Entity/EntityTypeManager.php b/web/core/lib/Drupal/Core/Entity/EntityTypeManager.php
index 7e78c08752e07ce0aaf4ab53219cb8027217ffe3..f135c5550dfa19a48e05bb786d3e155b56d7a601 100644
--- a/web/core/lib/Drupal/Core/Entity/EntityTypeManager.php
+++ b/web/core/lib/Drupal/Core/Entity/EntityTypeManager.php
@@ -204,7 +204,11 @@ public function getListBuilder($entity_type_id) {
    */
   public function getFormObject($entity_type_id, $operation) {
     if (!$class = $this->getDefinition($entity_type_id, TRUE)->getFormClass($operation)) {
-      throw new InvalidPluginDefinitionException($entity_type_id, sprintf('The "%s" entity type did not specify a "%s" form class.', $entity_type_id, $operation));
+      $handlers = $this->getDefinition($entity_type_id, TRUE)->getHandlerClasses();
+      if (!isset($handlers['form'][$operation])) {
+        throw new InvalidPluginDefinitionException($entity_type_id, sprintf('The "%s" entity type did not specify a "%s" form class.', $entity_type_id, $operation));
+      }
+      throw new InvalidPluginDefinitionException($entity_type_id, sprintf('The "%s" form handler of the "%s" entity type specifies a non-existent class "%s".', $operation, $entity_type_id, $handlers['form'][$operation]));
     }
 
     $form_object = $this->classResolver->getInstanceFromDefinition($class);
diff --git a/web/core/lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php b/web/core/lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php
index 9a8c1012c8d90e191c6f834e669d478d5a01078f..415fe880c7fcebb093c1421e75c07759abed880c 100644
--- a/web/core/lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php
+++ b/web/core/lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php
@@ -183,6 +183,9 @@ public function buildConfigurationForm(array $form, FormStateInterface $form_sta
         '#size' => 6,
         '#multiple' => TRUE,
         '#element_validate' => [[static::class, 'elementValidateFilter']],
+        // Use a form process callback to build #ajax property properly and also
+        // to avoid code duplication.
+        // @see \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem::fieldSettingsAjaxProcess()
         '#ajax' => TRUE,
         '#limit_validation_errors' => [],
       ];
@@ -232,6 +235,9 @@ public function buildConfigurationForm(array $form, FormStateInterface $form_sta
         '#type' => 'select',
         '#title' => $this->t('Sort by'),
         '#options' => $fields,
+        // Use a form process callback to build #ajax property properly and also
+        // to avoid code duplication.
+        // @see \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem::fieldSettingsAjaxProcess()
         '#ajax' => TRUE,
         '#empty_value' => '_none',
         '#sort_options' => TRUE,
diff --git a/web/core/lib/Drupal/Core/Entity/Query/QueryBase.php b/web/core/lib/Drupal/Core/Entity/Query/QueryBase.php
index cf7446cd0a06f7ce440383a592d07d4365193abb..585a8fdf9946f461cb9eeee0ab0351090d86d569 100644
--- a/web/core/lib/Drupal/Core/Entity/Query/QueryBase.php
+++ b/web/core/lib/Drupal/Core/Entity/Query/QueryBase.php
@@ -193,8 +193,8 @@ public function notExists($property, $langcode = NULL) {
    * {@inheritdoc}
    */
   public function range($start = NULL, $length = NULL) {
-    $this->range = [
-      'start' => $start,
+    $this->range = is_null($start) && is_null($length) ? [] : [
+      'start' => $start ?? 0,
       'length' => $length,
     ];
     return $this;
diff --git a/web/core/lib/Drupal/Core/EventSubscriber/RssResponseRelativeUrlFilter.php b/web/core/lib/Drupal/Core/EventSubscriber/RssResponseRelativeUrlFilter.php
index 70c9184a85d9ad1ae4023f2f10ff06961109bd13..fa6c09c7a7d226fb73b43f943dfbea9bfce25f1e 100644
--- a/web/core/lib/Drupal/Core/EventSubscriber/RssResponseRelativeUrlFilter.php
+++ b/web/core/lib/Drupal/Core/EventSubscriber/RssResponseRelativeUrlFilter.php
@@ -57,10 +57,12 @@ protected function transformRootRelativeUrlsToAbsolute($rss_markup, Request $req
 
     // Invoke Html::transformRootRelativeUrlsToAbsolute() on all HTML content
     // embedded in this RSS feed.
-    foreach ($rss_dom->getElementsByTagName('description') as $node) {
-      $html_markup = $node->nodeValue;
-      if (!empty($html_markup)) {
-        $node->replaceChild($rss_dom->createTextNode(Html::transformRootRelativeUrlsToAbsolute($html_markup, $request->getSchemeAndHttpHost())), $node->firstChild);
+    foreach ($rss_dom->getElementsByTagName('item') as $item) {
+      foreach ($item->getElementsByTagName('description') as $node) {
+        $html_markup = $node->nodeValue;
+        if (!empty($html_markup)) {
+          $node->replaceChild($rss_dom->createTextNode(Html::transformRootRelativeUrlsToAbsolute($html_markup, $request->getSchemeAndHttpHost())), $node->firstChild);
+        }
       }
     }
 
diff --git a/web/core/lib/Drupal/Core/Extension/DatabaseDriver.php b/web/core/lib/Drupal/Core/Extension/DatabaseDriver.php
index 24785766d10aadf559f1e96b1c6cb1acafc5388a..cb4e7a4a880cdbce6ce03e1ad5b42065146b3f22 100644
--- a/web/core/lib/Drupal/Core/Extension/DatabaseDriver.php
+++ b/web/core/lib/Drupal/Core/Extension/DatabaseDriver.php
@@ -90,7 +90,12 @@ public function getPath() {
    */
   public function load() {
     if (!isset($this->classLoader)) {
-      $this->classLoader = \Drupal::service('class_loader');
+      if (\Drupal::hasContainer() && \Drupal::hasService('class_loader')) {
+        $this->classLoader = \Drupal::service('class_loader');
+      }
+      else {
+        $this->classLoader = require DRUPAL_ROOT . '/autoload.php';
+      }
       $this->classLoader->addPsr4($this->getNamespace() . '\\', $this->getPath());
       foreach (($this->getAutoloadInfo()['dependencies'] ?? []) as $dependency) {
         $this->classLoader->addPsr4($dependency['namespace'] . '\\', $dependency['autoload']);
diff --git a/web/core/lib/Drupal/Core/Extension/Plugin/Validation/Constraint/ExtensionExistsConstraintValidator.php b/web/core/lib/Drupal/Core/Extension/Plugin/Validation/Constraint/ExtensionExistsConstraintValidator.php
index 404d5dcf38c220add9550b1e895daee2e1515856..6f4599618901c53a511c06c3a5368daa2fb6d975 100644
--- a/web/core/lib/Drupal/Core/Extension/Plugin/Validation/Constraint/ExtensionExistsConstraintValidator.php
+++ b/web/core/lib/Drupal/Core/Extension/Plugin/Validation/Constraint/ExtensionExistsConstraintValidator.php
@@ -61,12 +61,26 @@ public function validate(mixed $extension_name, Constraint $constraint) {
 
     switch ($constraint->type) {
       case 'module':
+        // This constraint may be used to validate nullable (optional) values.
+        if ($extension_name === NULL) {
+          return;
+        }
+        // Some plugins are shipped in `core/lib`, which corresponds to the
+        // special `core` extension name.
+        // For example: \Drupal\Core\Menu\Plugin\Block\LocalActionsBlock.
+        if ($extension_name === 'core') {
+          return;
+        }
         if (!$this->moduleHandler->moduleExists($extension_name)) {
           $this->context->addViolation($constraint->moduleMessage, $variables);
         }
         break;
 
       case 'theme':
+        // This constraint may be used to validate nullable (optional) values.
+        if ($extension_name === NULL) {
+          return;
+        }
         if (!$this->themeHandler->themeExists($extension_name)) {
           $this->context->addViolation($constraint->themeMessage, $variables);
         }
diff --git a/web/core/lib/Drupal/Core/Field/FormatterBase.php b/web/core/lib/Drupal/Core/Field/FormatterBase.php
index a0ed3ea11e71212a43bc5db010bb48dd949bbced..aa415d39cad14517f6c99103fc5c00de83f7e849 100644
--- a/web/core/lib/Drupal/Core/Field/FormatterBase.php
+++ b/web/core/lib/Drupal/Core/Field/FormatterBase.php
@@ -2,6 +2,8 @@
 
 namespace Drupal\Core\Field;
 
+use Drupal\Core\Cache\CacheableDependencyInterface;
+use Drupal\Core\Cache\CacheableMetadata;
 use Drupal\Core\Form\FormStateInterface;
 use Drupal\Core\Language\LanguageInterface;
 use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
@@ -88,8 +90,16 @@ public function view(FieldItemListInterface $items, $langcode = NULL) {
     }
     $elements = $this->viewElements($items, $langcode);
 
+    // Field item lists, in particular for computed fields, may carry cacheable
+    // metadata which must be bubbled.
+    if ($items instanceof CacheableDependencyInterface) {
+      (new CacheableMetadata())
+        ->addCacheableDependency($items)
+        ->applyTo($elements);
+    }
+
     // If there are actual renderable children, use #theme => field, otherwise,
-    // let access cacheability metadata pass through for correct bubbling.
+    // let cacheability metadata pass through for correct bubbling.
     if (Element::children($elements)) {
       $entity = $items->getEntity();
       $entity_type = $entity->getEntityTypeId();
diff --git a/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php b/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php
index 2a58bb7585d6d32a3e7aefab60ec84b2859fd1c6..782ecba82e9e2ac97434eb3d09108f0be9f07aab 100644
--- a/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php
+++ b/web/core/lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php
@@ -2,11 +2,11 @@
 
 namespace Drupal\Core\Field\Plugin\Field\FieldType;
 
+use Drupal\Component\Plugin\Exception\PluginNotFoundException;
 use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Component\Utility\Html;
 use Drupal\Core\Entity\ContentEntityStorageInterface;
 use Drupal\Core\Entity\EntityInterface;
-use Drupal\Component\Plugin\Exception\PluginNotFoundException;
 use Drupal\Core\Entity\EntityTypeInterface;
 use Drupal\Core\Entity\FieldableEntityInterface;
 use Drupal\Core\Entity\TypedData\EntityDataDefinition;
@@ -477,6 +477,9 @@ public function fieldSettingsForm(array $form, FormStateInterface $form_state) {
       '#options' => $handlers_options,
       '#default_value' => $field->getSetting('handler'),
       '#required' => TRUE,
+      // Use a form process callback to build #ajax property properly and also
+      // to avoid code duplication.
+      // @see \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem::fieldSettingsAjaxProcess()
       '#ajax' => TRUE,
       '#limit_validation_errors' => [],
     ];
@@ -703,6 +706,7 @@ public static function fieldSettingsAjaxProcess($form, FormStateInterface $form_
    * @see static::fieldSettingsAjaxProcess()
    */
   public static function fieldSettingsAjaxProcessElement(&$element, $main_form) {
+    // Elements are marked as TRUE ('#ajax' => TRUE,), so not empty.
     if (!empty($element['#ajax'])) {
       $element['#ajax'] = [
         'trigger_as' => ['name' => 'handler_settings_submit'],
diff --git a/web/core/lib/Drupal/Core/Form/FormBuilder.php b/web/core/lib/Drupal/Core/Form/FormBuilder.php
index 5fcac94117958c7aa73384792266412fd8419e49..40829d936b8bf0a8a8a5ee822675962deb2ddb4f 100644
--- a/web/core/lib/Drupal/Core/Form/FormBuilder.php
+++ b/web/core/lib/Drupal/Core/Form/FormBuilder.php
@@ -19,7 +19,7 @@
 use Drupal\Core\Theme\ThemeManagerInterface;
 use Symfony\Contracts\EventDispatcher\EventDispatcherInterface;
 use Symfony\Component\HttpFoundation\FileBag;
-use Symfony\Component\HttpFoundation\ParameterBag;
+use Symfony\Component\HttpFoundation\InputBag;
 use Symfony\Component\HttpFoundation\RequestStack;
 use Symfony\Component\HttpFoundation\Response;
 
@@ -327,7 +327,7 @@ public function buildForm($form_arg, FormStateInterface &$form_state) {
     // In case the post request exceeds the configured allowed size
     // (post_max_size), the post request is potentially broken. Add some
     // protection against that and at the same time have a nice error message.
-    if ($ajax_form_request && !$request->request->has('form_id')) {
+    if ($ajax_form_request && !$request->get('form_id')) {
       throw new BrokenPostRequestException($this->getFileUploadMaxSize());
     }
 
@@ -340,7 +340,7 @@ public function buildForm($form_arg, FormStateInterface &$form_state) {
     // build a proper AJAX response.
     // Only do this when the form ID matches, since there is no guarantee from
     // $ajax_form_request that it's an AJAX request for this particular form.
-    if ($ajax_form_request && $form_state->isProcessingInput() && $request->request->get('form_id') == $form_id) {
+    if ($ajax_form_request && $form_state->isProcessingInput() && $request->get('form_id') == $form_id) {
       throw new FormAjaxException($form, $form_state);
     }
 
@@ -967,7 +967,7 @@ public function doBuildForm($form_id, &$element, FormStateInterface &$form_state
 
             $request = $this->requestStack->getCurrentRequest();
             // Do not trust any POST data.
-            $request->request = new ParameterBag();
+            $request->request = new InputBag();
             // Make sure file uploads do not get processed.
             $request->files = new FileBag();
             // Ensure PHP globals reflect these changes.
diff --git a/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php b/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php
index c4e5b3ba13371a98bbbdfc086f70a7318ee244c1..45d32f09efb83219d86f130b639ca3615e0e50a5 100644
--- a/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php
+++ b/web/core/lib/Drupal/Core/Queue/QueueDatabaseFactory.php
@@ -5,9 +5,9 @@
 use Drupal\Core\Database\Connection;
 
 /**
- * Defines the key/value store factory for the database backend.
+ * Defines the queue factory for the database backend.
  */
-class QueueDatabaseFactory {
+class QueueDatabaseFactory implements QueueFactoryInterface {
 
   /**
    * The database connection.
@@ -20,20 +20,14 @@ class QueueDatabaseFactory {
    * Constructs this factory object.
    *
    * @param \Drupal\Core\Database\Connection $connection
-   *   The Connection object containing the key-value tables.
+   *   The Connection object containing the queue table.
    */
   public function __construct(Connection $connection) {
     $this->connection = $connection;
   }
 
   /**
-   * Constructs a new queue object for a given name.
-   *
-   * @param string $name
-   *   The name of the collection holding key and value pairs.
-   *
-   * @return \Drupal\Core\Queue\DatabaseQueue
-   *   A key/value store implementation for the given $collection.
+   * {@inheritdoc}
    */
   public function get($name) {
     return new DatabaseQueue($name, $this->connection);
diff --git a/web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php b/web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php
new file mode 100644
index 0000000000000000000000000000000000000000..580d958ee879db4c83c8a4a9b412933e391c9c7b
--- /dev/null
+++ b/web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php
@@ -0,0 +1,21 @@
+<?php
+
+namespace Drupal\Core\Queue;
+
+/**
+ * An interface defining queue factory classes.
+ */
+interface QueueFactoryInterface {
+
+  /**
+   * Constructs a new queue object for a given name.
+   *
+   * @param string $name
+   *   The name of the queue.
+   *
+   * @return \Drupal\Core\Queue\QueueInterface
+   *   The queue object.
+   */
+  public function get($name);
+
+}
diff --git a/web/core/lib/Drupal/Core/Render/Renderer.php b/web/core/lib/Drupal/Core/Render/Renderer.php
index 5a7fc05dd5466c6471344ad406437fac87a30387..9ad0d34d7894d5b76fe7f71016d1e21845dfb7a5 100644
--- a/web/core/lib/Drupal/Core/Render/Renderer.php
+++ b/web/core/lib/Drupal/Core/Render/Renderer.php
@@ -810,10 +810,11 @@ protected function xssFilterAdminIfUnsafe($string) {
    * @param array $elements
    *   A render array with #markup set.
    *
-   * @return \Drupal\Component\Render\MarkupInterface|string
-   *   The escaped markup wrapped in a Markup object. If $elements['#markup']
-   *   is an instance of \Drupal\Component\Render\MarkupInterface, it won't be
-   *   escaped or filtered again.
+   * @return array
+   *   The given array with the escaped markup wrapped in a Markup object.
+   *   If $elements['#markup'] is an instance of
+   *   \Drupal\Component\Render\MarkupInterface, it won't be escaped or filtered
+   *   again.
    *
    * @see \Drupal\Component\Utility\Html::escape()
    * @see \Drupal\Component\Utility\Xss::filter()
diff --git a/web/core/lib/Drupal/Core/StringTranslation/PluralTranslatableMarkup.php b/web/core/lib/Drupal/Core/StringTranslation/PluralTranslatableMarkup.php
index fb7ab9e83965718ca1d7f0370efae3edc8253bd5..d6410b2e5910f9f6f4a428382dd6f75accf52583 100644
--- a/web/core/lib/Drupal/Core/StringTranslation/PluralTranslatableMarkup.php
+++ b/web/core/lib/Drupal/Core/StringTranslation/PluralTranslatableMarkup.php
@@ -107,28 +107,15 @@ public function render() {
     $arguments['@count'] = $this->count;
     $translated_array = explode(PoItem::DELIMITER, $this->translatedString);
 
-    if ($this->count == 1) {
-      return $this->placeholderFormat($translated_array[0], $arguments);
-    }
-
     $index = $this->getPluralIndex();
-    if ($index == 0) {
+    if ($this->count == 1 || $index == 0 || count($translated_array) == 1) {
       // Singular form.
       $return = $translated_array[0];
     }
     else {
-      if (isset($translated_array[$index])) {
-        // N-th plural form.
-        $return = $translated_array[$index];
-      }
-      else {
-        // If the index cannot be computed or there's no translation, use the
-        // second plural form as a fallback (which allows for most flexibility
-        // with the replaceable @count value).
-        $return = $translated_array[1];
-      }
+      // Nth plural form, fallback to second plural form.
+      $return = $translated_array[$index] ?? $translated_array[1];
     }
-
     return $this->placeholderFormat($return, $arguments);
   }
 
diff --git a/web/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php b/web/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php
index 2e7083ff86f076e0a42e9a9c215927e19c27b915..bdc11f51cbceb531ed8ef4d1b073407e1ec15726 100644
--- a/web/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php
+++ b/web/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php
@@ -3,7 +3,6 @@
 namespace Drupal\Core\Test;
 
 use Drupal\Component\FileCache\FileCacheFactory;
-use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Component\Utility\Environment;
 use Drupal\Core\Config\Development\ConfigSchemaChecker;
 use Drupal\Core\Config\FileStorage;
@@ -474,7 +473,7 @@ protected function installModulesFromClassProperty(ContainerInterface $container
       $modules = array_unique($modules);
       try {
         $success = $container->get('module_installer')->install($modules, TRUE);
-        $this->assertTrue($success, new FormattableMarkup('Enabled modules: %modules', ['%modules' => implode(', ', $modules)]));
+        $this->assertTrue($success, 'Enabled modules: ' . implode(', ', $modules));
       }
       catch (MissingDependencyException $e) {
         // The exception message has all the details.
diff --git a/web/core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/UniqueFieldValueValidator.php b/web/core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/UniqueFieldValueValidator.php
index 050f108d69ea4a1f75e0f02a0acac805745575e5..111bda03f228b166e99c81ef6ee945d4bb3aca0c 100644
--- a/web/core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/UniqueFieldValueValidator.php
+++ b/web/core/lib/Drupal/Core/Validation/Plugin/Validation/Constraint/UniqueFieldValueValidator.php
@@ -82,7 +82,7 @@ public function validate($items, Constraint $constraint) {
       // If our entity duplicates field values in any other entity, the query
       // will return all field values that belong to those entities. Narrow
       // down to only the specific duplicate values.
-      $duplicate_values = array_intersect($item_values, $other_entity_values);
+      $duplicate_values = $this->caseInsensitiveArrayIntersect($item_values, $other_entity_values);
 
       foreach ($duplicate_values as $delta => $dupe) {
         $violation = $this->context
@@ -112,6 +112,26 @@ public function validate($items, Constraint $constraint) {
     }
   }
 
+  /**
+   * Perform a case-insensitive array intersection, but keep original capitalization.
+   *
+   * @param array $orig_values
+   *   The original values to be returned.
+   * @param array $comp_values
+   *   The values to intersect $orig_values with.
+   *
+   * @return array
+   *   Elements of $orig_values contained in $comp_values when ignoring capitalization.
+   */
+  private function caseInsensitiveArrayIntersect(array $orig_values, array $comp_values): array {
+    $lowercase_comp_values = array_map('strtolower', $comp_values);
+    $intersect_map = array_map(fn (string $x) => in_array(strtolower($x), $lowercase_comp_values, TRUE) ? $x : NULL, $orig_values);
+
+    return array_filter($intersect_map, function ($x) {
+      return $x !== NULL;
+    });
+  }
+
   /**
    * Get an array of duplicate field values.
    *
diff --git a/web/core/misc/cspell/dictionary.txt b/web/core/misc/cspell/dictionary.txt
index 283331f4e1e7c8bfba49ddec797c5a1fc6c83104..9a90c3566b7d6d7f556992ecd781ff43ecad60e6 100644
--- a/web/core/misc/cspell/dictionary.txt
+++ b/web/core/misc/cspell/dictionary.txt
@@ -203,9 +203,6 @@ delsp
 denormalizable
 denormalizer
 denormalizers
-dependee
-dependee's
-dependees
 derivedfrom
 desaturate
 desaturated
@@ -464,7 +461,6 @@ metatags
 mglaman
 micheh
 mikey
-milli
 mimetypes
 minifyzombies
 minusthick
@@ -932,7 +928,6 @@ versionable
 versionless
 verygreatdrupalmodule
 vfsstream
-viewmode
 viewports
 vocabs
 wcag
diff --git a/web/core/misc/cspell/drupal-dictionary.txt b/web/core/misc/cspell/drupal-dictionary.txt
index 6186bc3494ac39ba22fe7fc34fa81197d073f11e..06b07c5abe2776b9393bc458ae24b413576a8428 100644
--- a/web/core/misc/cspell/drupal-dictionary.txt
+++ b/web/core/misc/cspell/drupal-dictionary.txt
@@ -1,5 +1,8 @@
 bartik
 dblog
+dependee
+dependee's
+dependees
 drupalci
 druplicon
 drush
diff --git a/web/core/misc/details-aria.js b/web/core/misc/details-aria.js
index 1d0ef555586c26bea11131100ac9b20c95868a0b..c629719a3fc64404d7caedf9ace776fa024aed22 100644
--- a/web/core/misc/details-aria.js
+++ b/web/core/misc/details-aria.js
@@ -23,7 +23,6 @@
 
           $summary.attr({
             'aria-expanded': open,
-            'aria-pressed': open,
           });
         },
       );
diff --git a/web/core/misc/details.js b/web/core/misc/details.js
index 53927987d1c2c3a9af61f3e117998188f7ea5513..908f5dfb4a97eb45369f3547b3d43820b066e1e6 100644
--- a/web/core/misc/details.js
+++ b/web/core/misc/details.js
@@ -28,4 +28,17 @@
     'formFragmentLinkClickOrHashChange.details',
     handleFragmentLinkClickOrHashChange,
   );
+
+  /**
+   * Binds a listener to handle required fields in details elements.
+   */
+  window.addEventListener(
+    'invalid',
+    (event) => {
+      if (event.target.matches('details input[required]')) {
+        handleFragmentLinkClickOrHashChange(event, $(event.target));
+      }
+    },
+    { capture: true },
+  );
 })(jQuery);
diff --git a/web/core/misc/drupal.js b/web/core/misc/drupal.js
index 7d0f3b12c7976577af1f53d0c6c2bd3bd84c230b..4a8ab09de5987d76b2bab06f3230d48dd615eab7 100644
--- a/web/core/misc/drupal.js
+++ b/web/core/misc/drupal.js
@@ -71,7 +71,7 @@ window.Drupal = { behaviors: {}, locale: {} };
    *
    * @callback Drupal~behaviorAttach
    *
-   * @param {HTMLDocument|HTMLElement} context
+   * @param {Document|HTMLElement} context
    *   An element to detach behaviors from.
    * @param {?object} settings
    *   An object containing settings for the current context. It is rarely used.
@@ -84,7 +84,7 @@ window.Drupal = { behaviors: {}, locale: {} };
    *
    * @callback Drupal~behaviorDetach
    *
-   * @param {HTMLDocument|HTMLElement} context
+   * @param {Document|HTMLElement} context
    *   An element to attach behaviors to.
    * @param {object} settings
    *   An object containing settings for the current context.
@@ -143,7 +143,7 @@ window.Drupal = { behaviors: {}, locale: {} };
    *   }
    * };
    *
-   * @param {HTMLDocument|HTMLElement} [context=document]
+   * @param {Document|HTMLElement} [context=document]
    *   An element to attach behaviors to.
    * @param {object} [settings=drupalSettings]
    *   An object containing settings for the current context. If none is given,
@@ -183,7 +183,7 @@ window.Drupal = { behaviors: {}, locale: {} };
    * implementation, i.e. `once.remove('behaviorName', selector, context)`,
    * to ensure the behavior is detached only from previously processed elements.
    *
-   * @param {HTMLDocument|HTMLElement} [context=document]
+   * @param {Document|HTMLElement} [context=document]
    *   An element to detach behaviors from.
    * @param {object} [settings=drupalSettings]
    *   An object containing settings for the current context. If none given,
diff --git a/web/core/misc/form.js b/web/core/misc/form.js
index 3256a17fd82c8f2c9345e089b0631f3eff8012ba..e293b9d87e2b7199e56ec126021885b601950291 100644
--- a/web/core/misc/form.js
+++ b/web/core/misc/form.js
@@ -111,10 +111,10 @@
    *   (due to limitations of jQuery.serialize()). That is deemed to be
    *   acceptable, because if the user forgot to attach a file, then the size of
    *   HTTP payload will most likely be small enough to be fully passed to the
-   *   server endpoint within (milli)seconds. If a user mistakenly attached a
-   *   wrong file and is technically versed enough to cancel the form submission
-   *   (and HTTP payload) in order to attach a different file, then that
-   *   edge-case is not supported here.
+   *   server endpoint within seconds, or even milliseconds. If a user
+   *   mistakenly attached a wrong file and is technically versed enough to
+   *   cancel the form submission (and HTTP payload) in order to attach a
+   *   different file, then that edge-case is not supported here.
    *
    * Lastly, all forms submitted via HTTP GET are idempotent by definition of
    * HTTP standards, so excluded in this implementation.
@@ -293,7 +293,7 @@
     } else {
       url = window.location;
     }
-    const hash = url.hash.substr(1);
+    const hash = url.hash.substring(1);
     if (hash) {
       const $target = $(`#${hash}`);
       $('body').trigger('formFragmentLinkClickOrHashChange', [$target]);
diff --git a/web/core/misc/states.js b/web/core/misc/states.js
index 218b89268884845728161ab769ec77e5e8743fb9..f33dd0b9617ec9a809530ddb76b69fc98da2cb69 100644
--- a/web/core/misc/states.js
+++ b/web/core/misc/states.js
@@ -149,6 +149,7 @@
    *
    * @prop {function} RegExp
    * @prop {function} Function
+   * @prop {function} Array
    * @prop {function} Number
    */
   states.Dependent.comparisons = {
@@ -159,6 +160,15 @@
       // The "reference" variable is a comparison function.
       return reference(value);
     },
+    Array(reference, value) {
+      // Make sure value is an array.
+      if (!Array.isArray(value)) {
+        return false;
+      }
+
+      // The arrays values should match.
+      return JSON.stringify(reference.sort()) === JSON.stringify(value.sort());
+    },
     Number(reference, value) {
       // If "reference" is a number and "value" is a string, then cast
       // reference as a string before applying the strict comparison in
@@ -681,11 +691,14 @@
   $document.on('state:disabled', (e) => {
     // Only act when this change was triggered by a dependency and not by the
     // element monitoring itself.
+    const tagsSupportDisable =
+      'button, fieldset, optgroup, option, select, textarea, input';
     if (e.trigger) {
       $(e.target)
         .closest('.js-form-item, .js-form-submit, .js-form-wrapper')
         .toggleClass('form-disabled', e.value)
-        .find('select, input, textarea')
+        .find(tagsSupportDisable)
+        .addBack(tagsSupportDisable)
         .prop('disabled', e.value);
     }
   });
diff --git a/web/core/misc/tableheader.js b/web/core/misc/tableheader.js
index 2c7624023ca986bc1de8db1d3b41a5a4d33f26cf..f649a767a3983576dec20b86f0dd90e4afc8c7dc 100644
--- a/web/core/misc/tableheader.js
+++ b/web/core/misc/tableheader.js
@@ -325,7 +325,7 @@
             $stickyCell[0].style.display = 'none';
           }
         }
-        this.$stickyTable[0].style.width = this.$originalTable.outerWidth();
+        this.$stickyTable[0].style.width = `${this.$originalTable.outerWidth()}px`;
       },
     },
   );
diff --git a/web/core/modules/big_pipe/js/big_pipe.js b/web/core/modules/big_pipe/js/big_pipe.js
index 5d592e72f16bf1073555287746229311748f2395..3c3e106e70373886175161fca11d3dbbbf739e12 100644
--- a/web/core/modules/big_pipe/js/big_pipe.js
+++ b/web/core/modules/big_pipe/js/big_pipe.js
@@ -113,7 +113,12 @@
     // occur if the script node was first observed with empty content and then
     // the child text node was added in full later.
     // @see `@ingroup large_chunk` for more information.
-    else if (checkMutation(node.parentNode)) {
+    // If an element is added and then immediately (faster than the next
+    // setImmediate is triggered) removed to a watched element of a
+    // MutationObserver, the observer will notice and add a mutation for both
+    // the addedNode and the removedNode - but the referenced element will not
+    // have a parent node.
+    else if (node.parentNode !== null && checkMutation(node.parentNode)) {
       processReplacement(node.parentNode);
     }
   }
diff --git a/web/core/modules/big_pipe/tests/src/Functional/BigPipeTest.php b/web/core/modules/big_pipe/tests/src/Functional/BigPipeTest.php
index 0a5899ba9194748309421d8ab975a1c7c836434a..86a4ec44753e0bd365f96d99f33a36f24fe332bf 100644
--- a/web/core/modules/big_pipe/tests/src/Functional/BigPipeTest.php
+++ b/web/core/modules/big_pipe/tests/src/Functional/BigPipeTest.php
@@ -81,19 +81,19 @@ public function testNoJsDetection() {
 
     // 1. No session (anonymous).
     $this->drupalGet(Url::fromRoute('<front>'));
-    $this->assertSessionCookieExists(FALSE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('0');
+    $this->assertBigPipeNoJsCookieExists('0');
     $this->assertSession()->responseNotContains('<noscript><meta http-equiv="Refresh" content="0; URL=');
     $this->assertSession()->responseNotContains($no_js_to_js_markup);
 
     // 2. Session (authenticated).
     $this->drupalLogin($this->rootUser);
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
     $this->assertSession()->responseContains('<noscript><meta http-equiv="Refresh" content="0; URL=' . base_path() . 'big_pipe/no-js?destination=' . UrlHelper::encodePath(base_path() . 'user/1?check_logged_in=1') . '" />' . "\n" . '</noscript>');
     $this->assertSession()->responseNotContains($no_js_to_js_markup);
     $this->assertBigPipeNoJsMetaRefreshRedirect();
-    $this->assertBigPipeNoJsCookieExists(TRUE);
+    $this->assertBigPipeNoJsCookieExists('1');
     $this->assertSession()->responseNotContains('<noscript><meta http-equiv="Refresh" content="0; URL=');
     $this->assertSession()->responseContains($no_js_to_js_markup);
     $this->drupalLogout();
@@ -104,12 +104,12 @@ public function testNoJsDetection() {
     // 3. Session (anonymous).
     $this->drupalGet(Url::fromRoute('user.login', [], ['query' => ['trigger_session' => 1]]));
     $this->drupalGet(Url::fromRoute('user.login'));
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
     $this->assertSession()->responseContains('<noscript><meta http-equiv="Refresh" content="0; URL=' . base_path() . 'big_pipe/no-js?destination=' . base_path() . 'user/login" />' . "\n" . '</noscript>');
     $this->assertSession()->responseNotContains($no_js_to_js_markup);
     $this->assertBigPipeNoJsMetaRefreshRedirect();
-    $this->assertBigPipeNoJsCookieExists(TRUE);
+    $this->assertBigPipeNoJsCookieExists('1');
     $this->assertSession()->responseNotContains('<noscript><meta http-equiv="Refresh" content="0; URL=');
     $this->assertSession()->responseContains($no_js_to_js_markup);
 
@@ -118,14 +118,14 @@ public function testNoJsDetection() {
 
     // Edge case: route with '_no_big_pipe' option.
     $this->drupalGet(Url::fromRoute('no_big_pipe'));
-    $this->assertSessionCookieExists(FALSE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('0');
+    $this->assertBigPipeNoJsCookieExists('0');
     $this->assertSession()->responseNotContains('<noscript><meta http-equiv="Refresh" content="0; URL=');
     $this->assertSession()->responseNotContains($no_js_to_js_markup);
     $this->drupalLogin($this->rootUser);
     $this->drupalGet(Url::fromRoute('no_big_pipe'));
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
     $this->assertSession()->responseNotContains('<noscript><meta http-equiv="Refresh" content="0; URL=');
     $this->assertSession()->responseNotContains($no_js_to_js_markup);
   }
@@ -145,8 +145,8 @@ public function testBigPipe() {
     $this->config('system.logging')->set('error_level', ERROR_REPORTING_HIDE)->save();
 
     $this->drupalLogin($this->rootUser);
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
 
     $connection = Database::getConnection();
     $log_count = $connection->select('watchdog')->countQuery()->execute()->fetchField();
@@ -236,8 +236,8 @@ public function testBigPipeNoJs() {
     $this->config('system.logging')->set('error_level', ERROR_REPORTING_HIDE)->save();
 
     $this->drupalLogin($this->rootUser);
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
 
     // By calling performMetaRefresh() here, we simulate JavaScript being
     // disabled, because as far as the BigPipe module is concerned, it is
@@ -245,7 +245,7 @@ public function testBigPipeNoJs() {
     // @see setUp()
     // @see performMetaRefresh()
     $this->performMetaRefresh();
-    $this->assertBigPipeNoJsCookieExists(TRUE);
+    $this->assertBigPipeNoJsCookieExists('1');
 
     $this->drupalGet(Url::fromRoute('big_pipe_test'));
     $this->assertBigPipeResponseHeadersPresent();
@@ -296,8 +296,8 @@ public function testBigPipeNoJs() {
    */
   public function testBigPipeMultiOccurrencePlaceholders() {
     $this->drupalLogin($this->rootUser);
-    $this->assertSessionCookieExists(TRUE);
-    $this->assertBigPipeNoJsCookieExists(FALSE);
+    $this->assertSessionCookieExists('1');
+    $this->assertBigPipeNoJsCookieExists('0');
 
     // By not calling performMetaRefresh() here, we simulate JavaScript being
     // enabled, because as far as the BigPipe module is concerned, JavaScript is
@@ -321,7 +321,7 @@ public function testBigPipeMultiOccurrencePlaceholders() {
     // @see setUp()
     // @see performMetaRefresh()
     $this->performMetaRefresh();
-    $this->assertBigPipeNoJsCookieExists(TRUE);
+    $this->assertBigPipeNoJsCookieExists('1');
     $this->drupalGet(Url::fromRoute('big_pipe_test_multi_occurrence'));
     $this->assertSession()->pageTextContains('The count is 1.');
     $this->assertSession()->responseNotContains('The count is 2.');
diff --git a/web/core/modules/block/js/block.js b/web/core/modules/block/js/block.js
index 9e66a759232ed4479a5498d24d799fe31113b1a3..7de67a81430c84165756a55441afe76905d6e021 100644
--- a/web/core/modules/block/js/block.js
+++ b/web/core/modules/block/js/block.js
@@ -24,7 +24,7 @@
       /**
        * Create a summary for checkboxes in the provided context.
        *
-       * @param {HTMLDocument|HTMLElement} context
+       * @param {Document|HTMLElement} context
        *   A context where one would find checkboxes to summarize.
        *
        * @return {string}
diff --git a/web/core/modules/block/tests/src/Unit/Plugin/DisplayVariant/BlockPageVariantTest.php b/web/core/modules/block/tests/src/Unit/Plugin/DisplayVariant/BlockPageVariantTest.php
index 5842e957d6d279c990ae7c168ae0373ae11f8583..2d56c3d24b1351bc43a9691046a5ea83e55711c7 100644
--- a/web/core/modules/block/tests/src/Unit/Plugin/DisplayVariant/BlockPageVariantTest.php
+++ b/web/core/modules/block/tests/src/Unit/Plugin/DisplayVariant/BlockPageVariantTest.php
@@ -4,6 +4,7 @@
 
 namespace Drupal\Tests\block\Unit\Plugin\DisplayVariant;
 
+use Drupal\block\Plugin\DisplayVariant\BlockPageVariant;
 use Drupal\Core\Cache\CacheableMetadata;
 use Drupal\Core\DependencyInjection\Container;
 use Drupal\Tests\UnitTestCase;
@@ -43,8 +44,8 @@ class BlockPageVariantTest extends UnitTestCase {
    * @param array $definition
    *   The plugin definition array.
    *
-   * @return \Drupal\block\Plugin\DisplayVariant\BlockPageVariant|\PHPUnit\Framework\MockObject\MockObject
-   *   A mocked display variant plugin.
+   * @return \Drupal\block\Plugin\DisplayVariant\BlockPageVariant
+   *   A test display variant plugin.
    */
   public function setUpDisplayVariant($configuration = [], $definition = []) {
 
@@ -62,10 +63,7 @@ public function setUpDisplayVariant($configuration = [], $definition = []) {
     $this->blockRepository = $this->createMock('Drupal\block\BlockRepositoryInterface');
     $this->blockViewBuilder = $this->createMock('Drupal\Core\Entity\EntityViewBuilderInterface');
 
-    return $this->getMockBuilder('Drupal\block\Plugin\DisplayVariant\BlockPageVariant')
-      ->setConstructorArgs([$configuration, 'test', $definition, $this->blockRepository, $this->blockViewBuilder, ['config:block_list']])
-      ->addMethods(['getRegionNames'])
-      ->getMock();
+    return new BlockPageVariant($configuration, 'test', $definition, $this->blockRepository, $this->blockViewBuilder, ['config:block_list']);
   }
 
   public function providerBuild() {
diff --git a/web/core/modules/block_content/src/BlockContentForm.php b/web/core/modules/block_content/src/BlockContentForm.php
index f7503d345d75900c30845fc984ab83370172255b..7c97c6a6d1d287b5cf3b15e5b4748f89e4198335 100644
--- a/web/core/modules/block_content/src/BlockContentForm.php
+++ b/web/core/modules/block_content/src/BlockContentForm.php
@@ -41,7 +41,7 @@ public function form(array $form, FormStateInterface $form_state) {
   /**
    * {@inheritdoc}
    */
-  public function actions(array $form, FormStateInterface $form_state): array {
+  protected function actions(array $form, FormStateInterface $form_state): array {
     $element = parent::actions($form, $form_state);
 
     if ($this->getRequest()->query->has('theme')) {
@@ -108,20 +108,18 @@ public function save(array $form, FormStateInterface $form_state) {
     if ($block->id()) {
       $form_state->setValue('id', $block->id());
       $form_state->set('id', $block->id());
-      if ($insert) {
-        $theme = $block->getTheme();
-        if ($theme) {
-          $form_state->setRedirect(
-            'block.admin_add',
-            [
-              'plugin_id' => 'block_content:' . $block->uuid(),
-              'theme' => $theme,
-            ]
-          );
-        }
-        else {
-          $form_state->setRedirectUrl($block->toUrl('collection'));
-        }
+      $theme = $block->getTheme();
+      if ($insert && $theme) {
+        $form_state->setRedirect(
+          'block.admin_add',
+          [
+            'plugin_id' => 'block_content:' . $block->uuid(),
+            'theme' => $theme,
+          ]
+        );
+      }
+      else {
+        $form_state->setRedirectUrl($block->toUrl('collection'));
       }
     }
     else {
diff --git a/web/core/modules/block_content/src/Plugin/Derivative/BlockContent.php b/web/core/modules/block_content/src/Plugin/Derivative/BlockContent.php
index 5ba836f1a8d0ed09b97d9935c984918692999aeb..472f04183cb338ca7722b5f27f2201f49ced5b5b 100644
--- a/web/core/modules/block_content/src/Plugin/Derivative/BlockContent.php
+++ b/web/core/modules/block_content/src/Plugin/Derivative/BlockContent.php
@@ -49,7 +49,7 @@ public function getDerivativeDefinitions($base_plugin_definition) {
     /** @var \Drupal\block_content\Entity\BlockContent $block_content */
     foreach ($block_contents as $block_content) {
       $this->derivatives[$block_content->uuid()] = $base_plugin_definition;
-      $this->derivatives[$block_content->uuid()]['admin_label'] = $block_content->label();
+      $this->derivatives[$block_content->uuid()]['admin_label'] = $block_content->label() ?? ($block_content->type->entity->label() . ': ' . $block_content->id());
       $this->derivatives[$block_content->uuid()]['config_dependencies']['content'] = [
         $block_content->getConfigDependencyName(),
       ];
diff --git a/web/core/modules/block_content/tests/src/Functional/BlockContentCreationTest.php b/web/core/modules/block_content/tests/src/Functional/BlockContentCreationTest.php
index 71eb497607fbc82fe6d74f0903ddbdafd4b6293f..b251951b3013ae93d5df4466abeab91d41f0a099 100644
--- a/web/core/modules/block_content/tests/src/Functional/BlockContentCreationTest.php
+++ b/web/core/modules/block_content/tests/src/Functional/BlockContentCreationTest.php
@@ -2,6 +2,7 @@
 
 namespace Drupal\Tests\block_content\Functional;
 
+use Drupal\block_content\BlockContentInterface;
 use Drupal\block_content\Entity\BlockContent;
 use Drupal\Core\Database\Database;
 
@@ -67,10 +68,7 @@ public function testBlockContentCreation() {
     $this->assertSession()->fieldNotExists('settings[view_mode]');
 
     // Check that the block exists in the database.
-    $blocks = \Drupal::entityTypeManager()
-      ->getStorage('block_content')
-      ->loadByProperties(['info' => $edit['info[0][value]']]);
-    $block = reset($blocks);
+    $block = $this->getBlockByLabel($edit['info[0][value]']);
     $this->assertNotEmpty($block, 'Content Block found in database.');
   }
 
@@ -133,10 +131,7 @@ public function testBlockContentCreationMultipleViewModes() {
     $this->assertSession()->fieldValueEquals('settings[view_mode]', 'test_view_mode');
 
     // Check that the block exists in the database.
-    $blocks = \Drupal::entityTypeManager()
-      ->getStorage('block_content')
-      ->loadByProperties(['info' => $edit['info[0][value]']]);
-    $block = reset($blocks);
+    $block = $this->getBlockByLabel($edit['info[0][value]']);
     $this->assertNotEmpty($block, 'Content Block found in database.');
   }
 
@@ -175,6 +170,14 @@ public function testBlockContentFormSubmitHandlers() {
     $this->assertSession()->pageTextContains('basic ' . $edit['info[0][value]'] . ' has been created.');
     $this->assertSession()->addressEquals('/admin/content/block');
 
+    // Check that the user is redirected to the block library on edit.
+    $block = $this->getBlockByLabel($edit['info[0][value]']);
+    $this->drupalGet($block->toUrl('edit-form'));
+    $this->submitForm([
+      'info[0][value]' => 'Test Block Updated',
+    ], 'Save');
+    $this->assertSession()->addressEquals('admin/content/block');
+
     // Test with user who doesn't have permission to place a block.
     $this->drupalLogin($this->drupalCreateUser(['administer block content']));
     $this->drupalGet('block/add/basic');
@@ -200,10 +203,7 @@ public function testDefaultBlockContentCreation() {
     $this->assertSession()->pageTextContains('basic ' . $edit['info[0][value]'] . ' has been created.');
 
     // Check that the block exists in the database.
-    $blocks = \Drupal::entityTypeManager()
-      ->getStorage('block_content')
-      ->loadByProperties(['info' => $edit['info[0][value]']]);
-    $block = reset($blocks);
+    $block = $this->getBlockByLabel($edit['info[0][value]']);
     $this->assertNotEmpty($block, 'Default Content Block found in database.');
   }
 
@@ -316,4 +316,17 @@ public function testConfigDependencies() {
     $this->assertEquals($block_placement_id, $block_placement->id(), "The block placement config entity has a dependency on the block content entity.");
   }
 
+  /**
+   * Load a block based on the label.
+   */
+  private function getBlockByLabel(string $label): ?BlockContentInterface {
+    $blocks = \Drupal::entityTypeManager()
+      ->getStorage('block_content')
+      ->loadByProperties(['info' => $label]);
+    if (empty($blocks)) {
+      return NULL;
+    }
+    return reset($blocks);
+  }
+
 }
diff --git a/web/core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php b/web/core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php
index 3695c591b634aac519d4d4d914d21f6d1349542e..86aae63f7a2bfad2a391a73e2898d4836fd1e101 100644
--- a/web/core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php
+++ b/web/core/modules/block_content/tests/src/Kernel/BlockContentDeriverTest.php
@@ -4,6 +4,7 @@
 
 use Drupal\block_content\Entity\BlockContent;
 use Drupal\block_content\Entity\BlockContentType;
+use Drupal\block_content\Plugin\Derivative\BlockContent as DerivativeBlockContent;
 use Drupal\Component\Plugin\PluginBase;
 use Drupal\KernelTests\KernelTestBase;
 
@@ -19,6 +20,32 @@ class BlockContentDeriverTest extends KernelTestBase {
    */
   protected static $modules = ['block', 'block_content', 'system', 'user'];
 
+  /**
+   * The definition array of the base plugin.
+   *
+   * @var array
+   */
+  protected $baseDefinition = [
+    'id' => 'block_content',
+    'provider' => 'block_content',
+    'class' => '\Drupal\block_content\Plugin\Block\BlockContentBlock',
+    'deriver' => '\Drupal\block_content\Plugin\Derivative\BlockContent',
+  ];
+
+  /**
+   * The block content storage.
+   *
+   * @var \Drupal\Core\Entity\EntityStorageInterface
+   */
+  protected $blockContentStorage;
+
+  /**
+   * The tested block content derivative class.
+   *
+   * @var \Drupal\block_content\Plugin\Derivative\BlockContent
+   */
+  protected $blockContentDerivative;
+
   /**
    * {@inheritdoc}
    */
@@ -26,6 +53,9 @@ protected function setUp(): void {
     parent::setUp();
     $this->installEntitySchema('user');
     $this->installEntitySchema('block_content');
+
+    $this->blockContentStorage = \Drupal::entityTypeManager()->getStorage('block_content');
+    $this->blockContentDerivative = new DerivativeBlockContent($this->blockContentStorage);
   }
 
   /**
@@ -62,4 +92,31 @@ public function testReusableBlocksOnlyAreDerived() {
     $this->assertFalse($block_manager->hasDefinition($plugin_id));
   }
 
+  /**
+   * Tests the admin labels of derivative definitions.
+   */
+  public function testGetDerivativeDefinitionsAdminLabels(): void {
+    $blockContentType = BlockContentType::create([
+      'id' => 'basic',
+      'label' => 'Basic Block',
+    ]);
+    $blockContentType->save();
+    $blockContentWithLabel = BlockContent::create([
+      'info' => 'Basic prototype',
+      'type' => 'basic',
+    ]);
+    $blockContentWithLabel->save();
+    $blockContentNoLabel = BlockContent::create([
+      'type' => 'basic',
+    ]);
+    $blockContentNoLabel->save();
+
+    $blockPluginManager = \Drupal::service('plugin.manager.block');
+    $plugin = $blockPluginManager->createInstance('block_content:' . $blockContentWithLabel->uuid());
+    $this->assertEquals('Basic prototype', $plugin->getPluginDefinition()['admin_label']);
+
+    $plugin = $blockPluginManager->createInstance('block_content:' . $blockContentNoLabel->uuid());
+    $this->assertEquals('Basic Block: ' . $blockContentNoLabel->id(), $plugin->getPluginDefinition()['admin_label']);
+  }
+
 }
diff --git a/web/core/modules/book/tests/src/Functional/BookBreadcrumbTest.php b/web/core/modules/book/tests/src/Functional/BookBreadcrumbTest.php
index 4652abd6515083fb9c13582b99f015ee282580ab..a00acfa773bec7209cefe12013ffc3b434b9616c 100644
--- a/web/core/modules/book/tests/src/Functional/BookBreadcrumbTest.php
+++ b/web/core/modules/book/tests/src/Functional/BookBreadcrumbTest.php
@@ -117,7 +117,7 @@ protected function createBookNode($book_nid, $parent = NULL) {
     static $number = 0;
 
     $edit = [];
-    $edit['title[0][value]'] = str_pad($number, 2, '0', STR_PAD_LEFT) . ' - test node ' . $this->randomMachineName(10);
+    $edit['title[0][value]'] = str_pad((string) $number, 2, '0', STR_PAD_LEFT) . ' - test node ' . $this->randomMachineName(10);
     $edit['body[0][value]'] = 'test body ' . $this->randomMachineName(32) . ' ' . $this->randomMachineName(32);
     $edit['book[bid]'] = $book_nid;
 
diff --git a/web/core/modules/book/tests/src/Functional/BookTestTrait.php b/web/core/modules/book/tests/src/Functional/BookTestTrait.php
index fae697225f55238d63b1082959a67a2055eb6838..4488476f8bde4ea81ee9d21feb64054dd8f23755 100644
--- a/web/core/modules/book/tests/src/Functional/BookTestTrait.php
+++ b/web/core/modules/book/tests/src/Functional/BookTestTrait.php
@@ -192,7 +192,7 @@ public function createBookNode($book_nid, $parent = NULL, $edit = []) {
     // Used to ensure that when sorted nodes stay in same order.
     static $number = 0;
 
-    $edit['title[0][value]'] = str_pad($number, 2, '0', STR_PAD_LEFT) . ' - test node ' . $this->randomMachineName(10);
+    $edit['title[0][value]'] = str_pad((string) $number, 2, '0', STR_PAD_LEFT) . ' - test node ' . $this->randomMachineName(10);
     $edit['body[0][value]'] = 'test body ' . $this->randomMachineName(32) . ' ' . $this->randomMachineName(32);
     $edit['book[bid]'] = $book_nid;
 
diff --git a/web/core/modules/ckeditor5/css/editor.css b/web/core/modules/ckeditor5/css/editor.css
index f0b2422630db8a7b5c6af957f198c72aa3618cc5..bbc9a31b504f658e67f36fb773d79010ad4d283a 100644
--- a/web/core/modules/ckeditor5/css/editor.css
+++ b/web/core/modules/ckeditor5/css/editor.css
@@ -24,3 +24,8 @@
 .ck-editor__main > .ck-source-editing-area textarea {
   overflow: auto;
 }
+
+/* Enhance visibility of selected/active buttons on the toolbar. */
+.ck-toolbar__items .ck.ck-button.ck-on {
+  border: 1px solid var(--ck-color-button-on-color);
+}
diff --git a/web/core/modules/ckeditor5/css/essentials.admin.css b/web/core/modules/ckeditor5/css/essentials.admin.css
index 62a5ac434b9d3a019d288f078e79ef842662f0f3..429166121edd5200982b0d748933715ec78d0a80 100644
--- a/web/core/modules/ckeditor5/css/essentials.admin.css
+++ b/web/core/modules/ckeditor5/css/essentials.admin.css
@@ -1,6 +1,7 @@
 .ckeditor5-toolbar-button-divider {
   background-image: url(../icons/divider.svg);
 }
+
 .ckeditor5-toolbar-button-wrapping {
   background-image: url(../icons/separator.svg);
 }
@@ -20,15 +21,20 @@
   width: 100px;
   color: #000;
 }
+
 .ckeditor5-toolbar-button-heading::before {
   margin-left: 10px;
+  /* For browsers which don't support alt content, eg FireFox */
   content: "Heading";
+  content: "Heading" / "";
   font-size: 14px;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-heading::before {
   margin-right: 10px;
   margin-left: 0;
 }
+
 .ckeditor5-toolbar-button-heading::after {
   display: inline-block;
   width: 7px;
@@ -39,6 +45,7 @@
   border-width: 2px 2px 0 0;
   border-style: solid;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-heading::after {
   margin-right: 0;
   margin-left: 10px;
diff --git a/web/core/modules/ckeditor5/css/language.admin.css b/web/core/modules/ckeditor5/css/language.admin.css
index 42ebab47e99b3411a2b94070543587d03f3a4978..cb9997852bfd6d2dff7352c628d79f1677ea6063 100644
--- a/web/core/modules/ckeditor5/css/language.admin.css
+++ b/web/core/modules/ckeditor5/css/language.admin.css
@@ -5,15 +5,20 @@
   width: 110px;
   color: #000;
 }
+
 .ckeditor5-toolbar-button-textPartLanguage::before {
   margin-left: 10px;
+  /* For browsers which don't support alt content, eg FireFox */
   content: "Language";
+  content: "Language" / "";
   font-size: 14px;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-textPartLanguage::before {
   margin-right: 10px;
   margin-left: 0;
 }
+
 .ckeditor5-toolbar-button-textPartLanguage::after {
   display: inline-block;
   width: 7px;
@@ -24,6 +29,7 @@
   border-width: 2px 2px 0 0;
   border-style: solid;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-textPartLanguage::after {
   margin-right: 0;
   margin-left: 10px;
diff --git a/web/core/modules/ckeditor5/css/style.admin.css b/web/core/modules/ckeditor5/css/style.admin.css
index 6cb5b6bd5303dcc122c913593f889e70727f4901..add5dbabd38042dc5e9fa9eaf0361fb24bb17de6 100644
--- a/web/core/modules/ckeditor5/css/style.admin.css
+++ b/web/core/modules/ckeditor5/css/style.admin.css
@@ -5,15 +5,20 @@
   width: 110px;
   color: #000;
 }
+
 .ckeditor5-toolbar-button-style::before {
   margin-left: 10px;
+  /* For browsers which don't support alt content, eg FireFox */
   content: "Style";
+  content: "Style" / "";
   font-size: 14px;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-style::before {
   margin-right: 10px;
   margin-left: 0;
 }
+
 .ckeditor5-toolbar-button-style::after {
   display: inline-block;
   width: 7px;
@@ -24,6 +29,7 @@
   border-width: 2px 2px 0 0;
   border-style: solid;
 }
+
 [dir="rtl"] .ckeditor5-toolbar-button-style::after {
   margin-right: 0;
   margin-left: 10px;
diff --git a/web/core/modules/ckeditor5/js/build/drupalImage.js b/web/core/modules/ckeditor5/js/build/drupalImage.js
index 5f5e75012a1947968c0cb06942cc1ad3eaa2b2a6..81cab05e554c5e95a4b2c581b1703e32e9a918fb 100644
--- a/web/core/modules/ckeditor5/js/build/drupalImage.js
+++ b/web/core/modules/ckeditor5/js/build/drupalImage.js
@@ -1 +1 @@
-!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.drupalImage=t())}(globalThis,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/engine.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/engine.js")},"ckeditor5/src/ui.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/upload.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/upload.js")},"ckeditor5/src/utils.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/utils.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function i(r){var s=t[r];if(void 0!==s)return s.exports;var n=t[r]={exports:{}};return e[r](n,n.exports,i),n.exports}i.d=(e,t)=>{for(var r in t)i.o(t,r)&&!i.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);var r={};return(()=>{"use strict";i.d(r,{default:()=>B});var e=i("ckeditor5/src/core.js");function t(e,t,i){if(t.attributes)for(const[r,s]of Object.entries(t.attributes))e.setAttribute(r,s,i);t.styles&&e.setStyle(t.styles,i),t.classes&&e.addClass(t.classes,i)}var s=i("ckeditor5/src/engine.js");class n extends s.Observer{observe(e){this.listenTo(e,"load",((e,t)=>{const i=t.target;this.checkShouldIgnoreEventFromTarget(i)||"IMG"==i.tagName&&this._fireEvents(t)}),{useCapture:!0})}stopObserving(e){this.stopListening(e)}_fireEvents(e){this.isEnabled&&(this.document.fire("layoutChanged"),this.document.fire("imageLoaded",e))}}function o(e){return e.createEmptyElement("img")}function a(e){const t=parseFloat(e);return!Number.isNaN(t)&&e===String(t)}function l(e){return"string"==typeof e&&e.endsWith("%")?e:`${parseInt(e,10)}`}const u=[{modelValue:"alignCenter",dataValue:"center"},{modelValue:"alignRight",dataValue:"right"},{modelValue:"alignLeft",dataValue:"left"}];class d extends e.Plugin{static get requires(){return["ImageUtils"]}static get pluginName(){return"DrupalImageEditing"}init(){const{editor:e}=this,{conversion:i}=e,{schema:r}=e.model;if(r.isRegistered("imageInline")&&r.extend("imageInline",{allowAttributes:["dataEntityUuid","dataEntityType","isDecorative"]}),r.isRegistered("imageBlock")&&r.extend("imageBlock",{allowAttributes:["dataEntityUuid","dataEntityType","isDecorative"]}),i.for("upcast").add(function(e){function t(t,i,r){const{viewItem:s}=i,{writer:n,consumable:o,safeInsert:a,updateConversionResult:l,schema:d}=r,c=[];let m;if(!o.test(s,{name:!0,attributes:"src"}))return;const g=o.test(s,{name:!0,attributes:"data-caption"});if(m=d.checkChild(i.modelCursor,"imageInline")&&!g?n.createElement("imageInline",{src:s.getAttribute("src")}):n.createElement("imageBlock",{src:s.getAttribute("src")}),e.plugins.has("ImageStyleEditing")&&o.test(s,{name:!0,attributes:"data-align"})){const e=s.getAttribute("data-align"),t=u.find((t=>t.dataValue===e));t&&(n.setAttribute("imageStyle",t.modelValue,m),c.push("data-align"))}if(g){const t=n.createElement("caption"),i=e.data.processor.toView(s.getAttribute("data-caption"));r.consumable.constructor.createFrom(i,r.consumable),r.convertChildren(i,t),n.append(t,m),c.push("data-caption")}o.test(s,{name:!0,attributes:"data-entity-uuid"})&&(n.setAttribute("dataEntityUuid",s.getAttribute("data-entity-uuid"),m),c.push("data-entity-uuid")),o.test(s,{name:!0,attributes:"data-entity-type"})&&(n.setAttribute("dataEntityType",s.getAttribute("data-entity-type"),m),c.push("data-entity-type")),a(m,i.modelCursor)&&(o.consume(s,{name:!0,attributes:c}),l(m,i))}return e=>{e.on("element:img",t,{priority:"high"})}}(e)).attributeToAttribute({view:{name:"img",key:"width"},model:{key:"resizedWidth",value:e=>a(e.getAttribute("width"))?`${parseInt(e.getAttribute("width"),10)}px`:e.getAttribute("width").trim()}}).attributeToAttribute({view:{name:"img",key:"height"},model:{key:"resizedHeight",value:e=>a(e.getAttribute("height"))?`${parseInt(e.getAttribute("height"),10)}px`:e.getAttribute("height").trim()}}),e.plugins.has("DataFilter")){const t=e.plugins.get("DataFilter");i.for("upcast").add(function(e){function t(t,i,r){if(!i.modelRange)return;const s=i.viewItem.parent;if(!s.is("element","a"))return;if(!i.modelRange.getContainedElement().is("element","imageBlock"))return;const n=e.processViewAttributes(s,r);n&&r.writer.setAttribute("htmlLinkAttributes",n,i.modelRange)}return e=>{e.on("element:img",t,{priority:"high"})}}(t))}i.for("downcast").add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i;if(!s.consume(r,e.name))return;const o=i.mapper.toViewElement(r),a=Array.from(o.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-entity-uuid",t.attributeNewValue,a||o)}return t=>{t.on("attribute:dataEntityUuid",e)}}()).add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i;if(!s.consume(r,e.name))return;const o=i.mapper.toViewElement(r),a=Array.from(o.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-entity-type",t.attributeNewValue,a||o)}return t=>{t.on("attribute:dataEntityType",e)}}()),i.for("dataDowncast").add(function(e){return t=>{t.on("insert:caption",((t,i,r)=>{const{consumable:s,writer:n,mapper:o}=r;if(!e.plugins.get("ImageUtils").isImage(i.item.parent)||!s.consume(i.item,"insert"))return;const a=e.model.createRangeIn(i.item),l=n.createDocumentFragment();o.bindElements(i.item,l);for(const{item:t}of Array.from(a)){const i={item:t,range:e.model.createRangeOn(t)},s=`insert:${t.name||"$text"}`;e.data.downcastDispatcher.fire(s,i,r);for(const s of t.getAttributeKeys())Object.assign(i,{attributeKey:s,attributeOldValue:null,attributeNewValue:i.item.getAttribute(s)}),e.data.downcastDispatcher.fire(`attribute:${s}`,i,r)}for(const e of n.createRangeIn(l).getItems())o.unbindViewElement(e);o.unbindViewElement(l);const u=e.data.processor.toData(l);if(u){const e=o.toViewElement(i.item.parent);n.setAttribute("data-caption",u,e)}}),{priority:"high"})}}(e)).elementToElement({model:"imageBlock",view:(e,{writer:t})=>o(t),converterPriority:"high"}).elementToElement({model:"imageInline",view:(e,{writer:t})=>o(t),converterPriority:"high"}).add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i,o=u.find((e=>e.modelValue===t.attributeNewValue));if(!o||!s.consume(r,e.name))return;const a=i.mapper.toViewElement(r),l=Array.from(a.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-align",o.dataValue,l||a)}return t=>{t.on("attribute:imageStyle",e,{priority:"high"})}}()).add(function(){function e(e,i,r){if(!r.consumable.consume(i.item,e.name))return;const s=r.mapper.toViewElement(i.item),n=r.writer,o=n.createContainerElement("a",{href:i.attributeNewValue});n.insert(n.createPositionBefore(s),o),n.move(n.createRangeOn(s),n.createPositionAt(o,0)),r.consumable.consume(i.item,"attribute:htmlLinkAttributes:imageBlock")&&t(r.writer,i.item.getAttribute("htmlLinkAttributes"),o)}return t=>{t.on("attribute:linkHref:imageBlock",e,{priority:"high"})}}()).attributeToAttribute({model:{name:"imageBlock",key:"resizedWidth"},view:e=>({key:"width",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"resizedWidth"},view:e=>({key:"width",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"resizedHeight"},view:e=>({key:"height",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"resizedHeight"},view:e=>({key:"height",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"width"},view:(e,{consumable:t},i)=>i.item.hasAttribute("resizedWidth")?(t.consume(i.item,"attribute:width"),null):{key:"width",value:e},converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"width"},view:(e,{consumable:t},i)=>i.item.hasAttribute("resizedWidth")?(t.consume(i.item,"attribute:width"),null):{key:"width",value:e},converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"height"},view:(e,t,i)=>{if(i.item.hasAttribute("resizedWidth")){if(i.item.getAttribute("resizedWidth").endsWith("%"))return{key:"height",value:i.item.getAttribute("resizedWidth")};const t=parseInt(i.item.getAttribute("resizedWidth"),10),r=parseInt(i.item.getAttribute("width"),10)/parseInt(e,10);return{key:"height",value:`${Math.round(t/r)}`}}return{key:"height",value:e}},converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"height"},view:(e,t,i)=>{if(i.item.hasAttribute("resizedWidth")){if(i.item.getAttribute("resizedWidth").endsWith("%"))return{key:"height",value:i.item.getAttribute("resizedWidth")};const t=parseInt(i.item.getAttribute("resizedWidth"),10),r=parseInt(i.item.getAttribute("width"),10)/parseInt(e,10);return{key:"height",value:`${Math.round(t/r)}`}}return{key:"height",value:e}},converterPriority:"high"}),e.editing.view.addObserver(n);const s=e.plugins.get("ImageUtils");e.editing.view.document.on("imageLoaded",((t,i)=>{const r=e.editing.view.domConverter.mapDomToView(i.target);if(!r)return;const n=s.getImageWidgetFromImageView(r);if(!n)return;const o=e.editing.mapper.toModelElement(n);o&&e.model.enqueueChange({isUndoable:!1},(()=>{s.setImageNaturalSizeAttributes(o)}))}))}}class c extends e.Command{refresh(){const e=this.editor.plugins.get("ImageUtils").getClosestSelectedImageElement(this.editor.model.document.selection);this.isEnabled=!!e,this.isEnabled&&e.hasAttribute("alt")?this.value=e.getAttribute("alt"):this.value=!1}execute(e){const t=this.editor,i=t.plugins.get("ImageUtils"),r=t.model,s=i.getClosestSelectedImageElement(r.document.selection);r.change((t=>{t.setAttribute("alt",e.newValue,s)}))}}class m extends e.Plugin{static get requires(){return["ImageUtils"]}static get pluginName(){return"DrupalImageAlternativeTextEditing"}constructor(e){super(e),this._missingAltTextViewReferences=new Set}init(){const e=this.editor;e.conversion.for("editingDowncast").add(this._imageEditingDowncastConverter("attribute:alt",e)).add(this._imageEditingDowncastConverter("attribute:src",e)),e.commands.add("imageTextAlternative",new c(this.editor)),e.editing.view.on("render",(()=>{for(const e of this._missingAltTextViewReferences)e.button.element.isConnected||(e.destroy(),this._missingAltTextViewReferences.delete(e))}))}_imageEditingDowncastConverter(e){const t=(e,t,i)=>{const r=this.editor;if(!r.plugins.get("ImageUtils").isImage(t.item))return;const s=i.mapper.toViewElement(t.item),n=Array.from(s.getChildren()).find((e=>e.getCustomProperty("drupalImageMissingAltWarning")));if(t.item.hasAttribute("alt"))return void(n&&i.writer.remove(n));if(n)return;const o=r.ui.componentFactory.create("drupalImageAlternativeTextMissing");o.listenTo(r.ui,"update",(()=>{const e=r.model.document.selection.getFirstRange(),i=r.model.createRangeOn(t.item);o.set({isSelected:e.containsRange(i)||e.isIntersecting(i)})})),o.render(),this._missingAltTextViewReferences.add(o);const a=i.writer.createUIElement("span",{class:"image-alternative-text-missing-wrapper"},(function(e){const t=this.toDomElement(e);return t.appendChild(o.element),t}));i.writer.setCustomProperty("drupalImageMissingAltWarning",!0,a),i.writer.insert(i.writer.createPositionAt(s,"end"),a)};return i=>{i.on(e,t,{priority:"low"})}}}var g=i("ckeditor5/src/ui.js");function h(e){const t=e.plugins.get("ContextualBalloon");if(e.plugins.get("ImageUtils").getClosestSelectedImageWidget(e.editing.view.document.selection)){const i=p(e);t.updatePosition(i)}}function p(e){const t=e.editing.view,i=g.BalloonPanelView.defaultPositions,r=e.plugins.get("ImageUtils");return{target:t.domConverter.mapViewToDom(r.getClosestSelectedImageWidget(t.document.selection)),positions:[i.northArrowSouth,i.northArrowSouthWest,i.northArrowSouthEast,i.southArrowNorth,i.southArrowNorthWest,i.southArrowNorthEast,i.viewportStickyNorth]}}var b=i("ckeditor5/src/utils.js");class f extends g.View{constructor(t){super(t),this.focusTracker=new b.FocusTracker,this.keystrokes=new b.KeystrokeHandler,this.decorativeToggle=this._decorativeToggleView(),this.labeledInput=this._createLabeledInputView(),this.saveButtonView=this._createButton(Drupal.t("Save"),e.icons.check,"ck-button-save"),this.saveButtonView.type="submit",this.saveButtonView.bind("isEnabled").to(this.decorativeToggle,"isOn",this.labeledInput,"isEmpty",((e,t)=>e||!t)),this.cancelButtonView=this._createButton(Drupal.t("Cancel"),e.icons.cancel,"ck-button-cancel","cancel"),this._focusables=new g.ViewCollection,this._focusCycler=new g.FocusCycler({focusables:this._focusables,focusTracker:this.focusTracker,keystrokeHandler:this.keystrokes,actions:{focusPrevious:"shift + tab",focusNext:"tab"}}),this.setTemplate({tag:"form",attributes:{class:["ck","ck-text-alternative-form","ck-text-alternative-form--with-decorative-toggle","ck-responsive-form"],tabindex:"-1"},children:[{tag:"div",attributes:{class:["ck","ck-text-alternative-form__decorative-toggle"]},children:[this.decorativeToggle]},this.labeledInput,this.saveButtonView,this.cancelButtonView]}),(0,g.injectCssTransitionDisabler)(this)}render(){super.render(),this.keystrokes.listenTo(this.element),(0,g.submitHandler)({view:this}),[this.decorativeToggle,this.labeledInput,this.saveButtonView,this.cancelButtonView].forEach((e=>{this._focusables.add(e),this.focusTracker.add(e.element)}))}destroy(){super.destroy(),this.focusTracker.destroy(),this.keystrokes.destroy()}_createButton(e,t,i,r){const s=new g.ButtonView(this.locale);return s.set({label:e,icon:t,tooltip:!0}),s.extendTemplate({attributes:{class:i}}),r&&s.delegate("execute").to(this,r),s}_createLabeledInputView(){const e=new g.LabeledFieldView(this.locale,g.createLabeledInputText);return e.bind("class").to(this.decorativeToggle,"isOn",(e=>e?"ck-hidden":"")),e.label=Drupal.t("Text alternative"),e}_decorativeToggleView(){const e=new g.SwitchButtonView(this.locale);return e.set({withText:!0,label:Drupal.t("Decorative image")}),e.on("execute",(()=>{e.set("isOn",!e.isOn)})),e}}class w extends g.View{constructor(e){super(e);const t=this.bindTemplate;this.set("isVisible"),this.set("isSelected");const i=Drupal.t("Add missing alternative text");this.button=new g.ButtonView(e),this.button.set({label:i,tooltip:!1,withText:!0}),this.setTemplate({tag:"span",attributes:{class:["image-alternative-text-missing",t.to("isVisible",(e=>e?"":"ck-hidden"))],title:i},children:[this.button]})}}class v extends e.Plugin{static get requires(){return[g.ContextualBalloon]}static get pluginName(){return"DrupalImageTextAlternativeUI"}init(){this._createButton(),this._createForm(),this._createMissingAltTextComponent();const e=()=>{this.editor.plugins.get("ImageUtils").getClosestSelectedImageWidget(this.editor.editing.view.document.selection)&&this._showForm()};if(this.editor.commands.get("insertImage")){this.editor.commands.get("insertImage").on("execute",e)}if(this.editor.plugins.has("ImageUploadEditing")){this.editor.plugins.get("ImageUploadEditing").on("uploadComplete",e)}}_createMissingAltTextComponent(){this.editor.ui.componentFactory.add("drupalImageAlternativeTextMissing",(e=>{const t=new w(e);return t.listenTo(t.button,"execute",(()=>{this._isInBalloon&&this._balloon.remove(this._form),this._showForm()})),t.listenTo(this.editor.ui,"update",(()=>{t.set({isVisible:!this._isVisible||!t.isSelected})})),t}))}destroy(){super.destroy(),this._form.destroy()}_createButton(){const t=this.editor;t.ui.componentFactory.add("drupalImageAlternativeText",(i=>{const r=t.commands.get("imageTextAlternative"),s=new g.ButtonView(i);return s.set({label:Drupal.t("Change image alternative text"),icon:e.icons.lowVision,tooltip:!0}),s.bind("isEnabled").to(r,"isEnabled"),this.listenTo(s,"execute",(()=>{this._showForm()})),s}))}_createForm(){const e=this.editor,t=e.editing.view.document,i=e.plugins.get("ImageUtils");this._balloon=this.editor.plugins.get("ContextualBalloon"),this._form=new f(e.locale),this._form.render(),this.listenTo(this._form,"submit",(()=>{e.execute("imageTextAlternative",{newValue:this._form.decorativeToggle.isOn?"":this._form.labeledInput.fieldView.element.value}),this._hideForm(!0)})),this.listenTo(this._form,"cancel",(()=>{this._hideForm(!0)})),this.listenTo(this._form.decorativeToggle,"execute",(()=>{h(e)})),this._form.keystrokes.set("Esc",((e,t)=>{this._hideForm(!0),t()})),this.listenTo(e.ui,"update",(()=>{i.getClosestSelectedImageWidget(t.selection)?this._isVisible&&h(e):this._hideForm(!0)})),(0,g.clickOutsideHandler)({emitter:this._form,activator:()=>this._isVisible,contextElements:[this._balloon.view.element],callback:()=>this._hideForm()})}_showForm(){if(this._isVisible)return;const e=this.editor,t=e.commands.get("imageTextAlternative"),i=this._form.decorativeToggle,r=this._form.labeledInput;this._form.disableCssTransitions(),this._isInBalloon||this._balloon.add({view:this._form,position:p(e)}),i.isOn=""===t.value,r.fieldView.element.value=t.value||"",r.fieldView.value=r.fieldView.element.value,i.isOn?i.focus():r.fieldView.select(),this._form.enableCssTransitions()}_hideForm(e){this._isInBalloon&&(this._form.focusTracker.isFocused&&this._form.saveButtonView.focus(),this._balloon.remove(this._form),e&&this.editor.editing.view.focus())}get _isVisible(){return this._balloon.visibleView===this._form}get _isInBalloon(){return this._balloon.hasView(this._form)}}class y extends e.Plugin{static get requires(){return[m,v]}static get pluginName(){return"DrupalImageAlternativeText"}}class I extends e.Plugin{static get requires(){return[d,y]}static get pluginName(){return"DrupalImage"}}const A=I;class k extends e.Plugin{init(){const{editor:e}=this;e.plugins.get("ImageUploadEditing").on("uploadComplete",((t,{data:i,imageElement:r})=>{e.model.change((e=>{e.setAttribute("dataEntityUuid",i.response.uuid,r),e.setAttribute("dataEntityType",i.response.entity_type,r)}))}))}static get pluginName(){return"DrupalImageUploadEditing"}}var x=i("ckeditor5/src/upload.js");class _{constructor(e,t){this.loader=e,this.options=t}upload(){return this.loader.file.then((e=>new Promise(((t,i)=>{this._initRequest(),this._initListeners(t,i,e),this._sendRequest(e)}))))}abort(){this.xhr&&this.xhr.abort()}_initRequest(){this.xhr=new XMLHttpRequest,this.xhr.open("POST",this.options.uploadUrl,!0),this.xhr.responseType="json"}_initListeners(e,t,i){const r=this.xhr,s=this.loader,n=`Couldn't upload file: ${i.name}.`;r.addEventListener("error",(()=>t(n))),r.addEventListener("abort",(()=>t())),r.addEventListener("load",(()=>{const i=r.response;if(!i||i.error)return t(i&&i.error&&i.error.message?i.error.message:n);e({response:i,urls:{default:i.url}})})),r.upload&&r.upload.addEventListener("progress",(e=>{e.lengthComputable&&(s.uploadTotal=e.total,s.uploaded=e.loaded)}))}_sendRequest(e){const t=this.options.headers||{},i=this.options.withCredentials||!1;Object.keys(t).forEach((e=>{this.xhr.setRequestHeader(e,t[e])})),this.xhr.withCredentials=i;const r=new FormData;r.append("upload",e),this.xhr.send(r)}}class T extends e.Plugin{static get requires(){return[x.FileRepository]}static get pluginName(){return"DrupalFileRepository"}init(){const e=this.editor.config.get("drupalImageUpload");e&&(e.uploadUrl?this.editor.plugins.get(x.FileRepository).createUploadAdapter=t=>new _(t,e):(0,b.logWarning)("simple-upload-adapter-missing-uploadurl"))}}class E extends e.Plugin{static get requires(){return[T,k]}static get pluginName(){return"DrupalImageUpload"}}const V=E;class C extends e.Plugin{init(){const{editor:e}=this;e.ui.componentFactory.add("drupalInsertImage",(()=>e.ui.componentFactory.create("insertImage")))}static get pluginName(){return"DrupalInsertImage"}}const B={DrupalImage:A,DrupalImageUpload:V,DrupalInsertImage:C}})(),r=r.default})()));
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.CKEditor5=t():(e.CKEditor5=e.CKEditor5||{},e.CKEditor5.drupalImage=t())}(globalThis,(()=>(()=>{var e={"ckeditor5/src/core.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/core.js")},"ckeditor5/src/engine.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/engine.js")},"ckeditor5/src/ui.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/ui.js")},"ckeditor5/src/upload.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/upload.js")},"ckeditor5/src/utils.js":(e,t,i)=>{e.exports=i("dll-reference CKEditor5.dll")("./src/utils.js")},"dll-reference CKEditor5.dll":e=>{"use strict";e.exports=CKEditor5.dll}},t={};function i(r){var s=t[r];if(void 0!==s)return s.exports;var n=t[r]={exports:{}};return e[r](n,n.exports,i),n.exports}i.d=(e,t)=>{for(var r in t)i.o(t,r)&&!i.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},i.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);var r={};return(()=>{"use strict";i.d(r,{default:()=>B});var e=i("ckeditor5/src/core.js");function t(e,t,i){if(t.attributes)for(const[r,s]of Object.entries(t.attributes))e.setAttribute(r,s,i);t.styles&&e.setStyle(t.styles,i),t.classes&&e.addClass(t.classes,i)}var s=i("ckeditor5/src/engine.js");class n extends s.Observer{observe(e){this.listenTo(e,"load",((e,t)=>{const i=t.target;this.checkShouldIgnoreEventFromTarget(i)||"IMG"==i.tagName&&this._fireEvents(t)}),{useCapture:!0})}stopObserving(e){this.stopListening(e)}_fireEvents(e){this.isEnabled&&(this.document.fire("layoutChanged"),this.document.fire("imageLoaded",e))}}function o(e){return e.createEmptyElement("img")}function a(e){const t=parseFloat(e);return!Number.isNaN(t)&&e===String(t)}function l(e){return"string"==typeof e&&e.endsWith("%")?e:`${parseInt(e,10)}`}const u=[{modelValue:"alignCenter",dataValue:"center"},{modelValue:"alignRight",dataValue:"right"},{modelValue:"alignLeft",dataValue:"left"}];class d extends e.Plugin{static get requires(){return["ImageUtils"]}static get pluginName(){return"DrupalImageEditing"}init(){const{editor:e}=this,{conversion:i}=e,{schema:r}=e.model;if(r.isRegistered("imageInline")&&r.extend("imageInline",{allowAttributes:["dataEntityUuid","dataEntityType","isDecorative"]}),r.isRegistered("imageBlock")&&r.extend("imageBlock",{allowAttributes:["dataEntityUuid","dataEntityType","isDecorative"]}),i.for("upcast").add(function(e){function t(t,i,r){const{viewItem:s}=i,{writer:n,consumable:o,safeInsert:a,updateConversionResult:l,schema:d}=r,c=[];let m;if(!o.test(s,{name:!0,attributes:"src"}))return;const g=o.test(s,{name:!0,attributes:"data-caption"});if(m=d.checkChild(i.modelCursor,"imageInline")&&!g?n.createElement("imageInline",{src:s.getAttribute("src")}):n.createElement("imageBlock",{src:s.getAttribute("src")}),e.plugins.has("ImageStyleEditing")&&o.test(s,{name:!0,attributes:"data-align"})){const e=s.getAttribute("data-align"),t=u.find((t=>t.dataValue===e));t&&(n.setAttribute("imageStyle",t.modelValue,m),c.push("data-align"))}if(g){const t=n.createElement("caption"),i=e.data.processor.toView(s.getAttribute("data-caption"));r.consumable.constructor.createFrom(i,r.consumable),r.convertChildren(i,t),n.append(t,m),c.push("data-caption")}o.test(s,{name:!0,attributes:"data-entity-uuid"})&&(n.setAttribute("dataEntityUuid",s.getAttribute("data-entity-uuid"),m),c.push("data-entity-uuid")),o.test(s,{name:!0,attributes:"data-entity-type"})&&(n.setAttribute("dataEntityType",s.getAttribute("data-entity-type"),m),c.push("data-entity-type")),a(m,i.modelCursor)&&(o.consume(s,{name:!0,attributes:c}),l(m,i))}return e=>{e.on("element:img",t,{priority:"high"})}}(e)).attributeToAttribute({view:{name:"img",key:"width"},model:{key:"resizedWidth",value:e=>a(e.getAttribute("width"))?`${parseInt(e.getAttribute("width"),10)}px`:e.getAttribute("width").trim()}}).attributeToAttribute({view:{name:"img",key:"height"},model:{key:"resizedHeight",value:e=>a(e.getAttribute("height"))?`${parseInt(e.getAttribute("height"),10)}px`:e.getAttribute("height").trim()}}),e.plugins.has("DataFilter")){const t=e.plugins.get("DataFilter");i.for("upcast").add(function(e){function t(t,i,r){if(!i.modelRange)return;const s=i.viewItem.parent;if(!s.is("element","a"))return;if(!i.modelRange.getContainedElement().is("element","imageBlock"))return;const n=e.processViewAttributes(s,r);n&&r.writer.setAttribute("htmlLinkAttributes",n,i.modelRange)}return e=>{e.on("element:img",t,{priority:"high"})}}(t))}i.for("downcast").add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i;if(!s.consume(r,e.name))return;const o=i.mapper.toViewElement(r),a=Array.from(o.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-entity-uuid",t.attributeNewValue,a||o)}return t=>{t.on("attribute:dataEntityUuid",e)}}()).add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i;if(!s.consume(r,e.name))return;const o=i.mapper.toViewElement(r),a=Array.from(o.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-entity-type",t.attributeNewValue,a||o)}return t=>{t.on("attribute:dataEntityType",e)}}()),i.for("dataDowncast").add(function(e){return t=>{t.on("insert:caption",((t,i,r)=>{const{consumable:s,writer:n,mapper:o}=r;if(!e.plugins.get("ImageUtils").isImage(i.item.parent)||!s.consume(i.item,"insert"))return;const a=e.model.createRangeIn(i.item),l=n.createDocumentFragment();o.bindElements(i.item,l);for(const{item:t}of Array.from(a)){const i={item:t,range:e.model.createRangeOn(t)},s=`insert:${t.name||"$text"}`;e.data.downcastDispatcher.fire(s,i,r);for(const s of t.getAttributeKeys())Object.assign(i,{attributeKey:s,attributeOldValue:null,attributeNewValue:i.item.getAttribute(s)}),e.data.downcastDispatcher.fire(`attribute:${s}`,i,r)}for(const e of n.createRangeIn(l).getItems())o.unbindViewElement(e);o.unbindViewElement(l);const u=e.data.processor.toData(l);if(u){const e=o.toViewElement(i.item.parent);n.setAttribute("data-caption",u,e)}}),{priority:"high"})}}(e)).elementToElement({model:"imageBlock",view:(e,{writer:t})=>o(t),converterPriority:"high"}).elementToElement({model:"imageInline",view:(e,{writer:t})=>o(t),converterPriority:"high"}).add(function(){function e(e,t,i){const{item:r}=t,{consumable:s,writer:n}=i,o=u.find((e=>e.modelValue===t.attributeNewValue));if(!o||!s.consume(r,e.name))return;const a=i.mapper.toViewElement(r),l=Array.from(a.getChildren()).find((e=>"img"===e.name));n.setAttribute("data-align",o.dataValue,l||a)}return t=>{t.on("attribute:imageStyle",e,{priority:"high"})}}()).add(function(){function e(e,i,r){if(!r.consumable.consume(i.item,e.name))return;const s=r.mapper.toViewElement(i.item),n=r.writer,o=n.createContainerElement("a",{href:i.attributeNewValue});n.insert(n.createPositionBefore(s),o),n.move(n.createRangeOn(s),n.createPositionAt(o,0)),r.consumable.consume(i.item,"attribute:htmlLinkAttributes:imageBlock")&&t(r.writer,i.item.getAttribute("htmlLinkAttributes"),o)}return t=>{t.on("attribute:linkHref:imageBlock",e,{priority:"high"})}}()).attributeToAttribute({model:{name:"imageBlock",key:"resizedWidth"},view:e=>({key:"width",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"resizedWidth"},view:e=>({key:"width",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"resizedHeight"},view:e=>({key:"height",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"resizedHeight"},view:e=>({key:"height",value:l(e)}),converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"width"},view:(e,{consumable:t},i)=>i.item.hasAttribute("resizedWidth")?(t.consume(i.item,"attribute:width"),null):{key:"width",value:e},converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"width"},view:(e,{consumable:t},i)=>i.item.hasAttribute("resizedWidth")?(t.consume(i.item,"attribute:width"),null):{key:"width",value:e},converterPriority:"high"}).attributeToAttribute({model:{name:"imageBlock",key:"height"},view:(e,t,i)=>{if(i.item.hasAttribute("resizedWidth")){if(i.item.getAttribute("resizedWidth").endsWith("%"))return{key:"height",value:i.item.getAttribute("resizedWidth")};const t=parseInt(i.item.getAttribute("resizedWidth"),10),r=parseInt(i.item.getAttribute("width"),10)/parseInt(e,10);return{key:"height",value:`${Math.round(t/r)}`}}return{key:"height",value:e}},converterPriority:"high"}).attributeToAttribute({model:{name:"imageInline",key:"height"},view:(e,t,i)=>{if(i.item.hasAttribute("resizedWidth")){if(i.item.getAttribute("resizedWidth").endsWith("%"))return{key:"height",value:i.item.getAttribute("resizedWidth")};const t=parseInt(i.item.getAttribute("resizedWidth"),10),r=parseInt(i.item.getAttribute("width"),10)/parseInt(e,10);return{key:"height",value:`${Math.round(t/r)}`}}return{key:"height",value:e}},converterPriority:"high"}),e.editing.view.addObserver(n);const s=e.plugins.get("ImageUtils");e.editing.view.document.on("imageLoaded",((t,i)=>{const r=e.editing.view.domConverter.mapDomToView(i.target);if(!r)return;const n=s.getImageWidgetFromImageView(r);if(!n)return;const o=e.editing.mapper.toModelElement(n);o&&e.model.enqueueChange({isUndoable:!1},(()=>{s.setImageNaturalSizeAttributes(o)}))}))}}class c extends e.Command{refresh(){const e=this.editor.plugins.get("ImageUtils").getClosestSelectedImageElement(this.editor.model.document.selection);this.isEnabled=!!e,this.isEnabled&&e.hasAttribute("alt")?this.value=e.getAttribute("alt"):this.value=!1}execute(e){const t=this.editor,i=t.plugins.get("ImageUtils"),r=t.model,s=i.getClosestSelectedImageElement(r.document.selection);r.change((t=>{t.setAttribute("alt",e.newValue,s)}))}}class m extends e.Plugin{static get requires(){return["ImageUtils"]}static get pluginName(){return"DrupalImageAlternativeTextEditing"}constructor(e){super(e),this._missingAltTextViewReferences=new Set}init(){const e=this.editor;e.conversion.for("editingDowncast").add(this._imageEditingDowncastConverter("attribute:alt",e)).add(this._imageEditingDowncastConverter("attribute:src",e)),e.commands.add("imageTextAlternative",new c(this.editor)),e.editing.view.on("render",(()=>{for(const e of this._missingAltTextViewReferences)e.button.element.isConnected||(e.destroy(),this._missingAltTextViewReferences.delete(e))}))}_imageEditingDowncastConverter(e){const t=(e,t,i)=>{const r=this.editor;if(!r.plugins.get("ImageUtils").isImage(t.item))return;const s=i.mapper.toViewElement(t.item),n=Array.from(s.getChildren()).find((e=>e.getCustomProperty("drupalImageMissingAltWarning")));if(t.item.hasAttribute("alt"))return void(n&&i.writer.remove(n));if(n)return;const o=r.ui.componentFactory.create("drupalImageAlternativeTextMissing");o.listenTo(r.ui,"update",(()=>{const e=r.model.document.selection.getFirstRange(),i=r.model.createRangeOn(t.item);o.set({isSelected:e.containsRange(i)||e.isIntersecting(i)})})),o.render(),this._missingAltTextViewReferences.add(o);const a=i.writer.createUIElement("span",{class:"image-alternative-text-missing-wrapper"},(function(e){const t=this.toDomElement(e);return t.appendChild(o.element),t}));i.writer.setCustomProperty("drupalImageMissingAltWarning",!0,a),i.writer.insert(i.writer.createPositionAt(s,"end"),a)};return i=>{i.on(e,t,{priority:"low"})}}}var g=i("ckeditor5/src/ui.js");function h(e){const t=e.plugins.get("ContextualBalloon");if(e.plugins.get("ImageUtils").getClosestSelectedImageWidget(e.editing.view.document.selection)){const i=p(e);t.updatePosition(i)}}function p(e){const t=e.editing.view,i=g.BalloonPanelView.defaultPositions,r=e.plugins.get("ImageUtils");return{target:t.domConverter.mapViewToDom(r.getClosestSelectedImageWidget(t.document.selection)),positions:[i.northArrowSouth,i.northArrowSouthWest,i.northArrowSouthEast,i.southArrowNorth,i.southArrowNorthWest,i.southArrowNorthEast,i.viewportStickyNorth]}}var b=i("ckeditor5/src/utils.js");class f extends g.View{constructor(t){super(t),this.focusTracker=new b.FocusTracker,this.keystrokes=new b.KeystrokeHandler,this.decorativeToggle=this._decorativeToggleView(),this.labeledInput=this._createLabeledInputView(),this.saveButtonView=this._createButton(Drupal.t("Save"),e.icons.check,"ck-button-save"),this.saveButtonView.type="submit",this.saveButtonView.bind("isEnabled").to(this.decorativeToggle,"isOn",this.labeledInput,"isEmpty",((e,t)=>e||!t)),this.cancelButtonView=this._createButton(Drupal.t("Cancel"),e.icons.cancel,"ck-button-cancel","cancel"),this._focusables=new g.ViewCollection,this._focusCycler=new g.FocusCycler({focusables:this._focusables,focusTracker:this.focusTracker,keystrokeHandler:this.keystrokes,actions:{focusPrevious:"shift + tab",focusNext:"tab"}}),this.setTemplate({tag:"form",attributes:{class:["ck","ck-text-alternative-form","ck-text-alternative-form--with-decorative-toggle","ck-responsive-form"],tabindex:"-1"},children:[{tag:"div",attributes:{class:["ck","ck-text-alternative-form__decorative-toggle"]},children:[this.decorativeToggle]},this.labeledInput,this.saveButtonView,this.cancelButtonView]}),(0,g.injectCssTransitionDisabler)(this)}render(){super.render(),this.keystrokes.listenTo(this.element),(0,g.submitHandler)({view:this}),[this.decorativeToggle,this.labeledInput,this.saveButtonView,this.cancelButtonView].forEach((e=>{this._focusables.add(e),this.focusTracker.add(e.element)}))}destroy(){super.destroy(),this.focusTracker.destroy(),this.keystrokes.destroy()}_createButton(e,t,i,r){const s=new g.ButtonView(this.locale);return s.set({label:e,icon:t,tooltip:!0}),s.extendTemplate({attributes:{class:i}}),r&&s.delegate("execute").to(this,r),s}_createLabeledInputView(){const e=new g.LabeledFieldView(this.locale,g.createLabeledInputText);return e.bind("class").to(this.decorativeToggle,"isOn",(e=>e?"ck-hidden":"")),e.label=Drupal.t("Alternative text"),e}_decorativeToggleView(){const e=new g.SwitchButtonView(this.locale);return e.set({withText:!0,label:Drupal.t("Decorative image")}),e.on("execute",(()=>{e.set("isOn",!e.isOn)})),e}}class w extends g.View{constructor(e){super(e);const t=this.bindTemplate;this.set("isVisible"),this.set("isSelected");const i=Drupal.t("Add missing alternative text");this.button=new g.ButtonView(e),this.button.set({label:i,tooltip:!1,withText:!0}),this.setTemplate({tag:"span",attributes:{class:["image-alternative-text-missing",t.to("isVisible",(e=>e?"":"ck-hidden"))],title:i},children:[this.button]})}}class v extends e.Plugin{static get requires(){return[g.ContextualBalloon]}static get pluginName(){return"DrupalImageTextAlternativeUI"}init(){this._createButton(),this._createForm(),this._createMissingAltTextComponent();const e=()=>{this.editor.plugins.get("ImageUtils").getClosestSelectedImageWidget(this.editor.editing.view.document.selection)&&this._showForm()};if(this.editor.commands.get("insertImage")){this.editor.commands.get("insertImage").on("execute",e)}if(this.editor.plugins.has("ImageUploadEditing")){this.editor.plugins.get("ImageUploadEditing").on("uploadComplete",e)}}_createMissingAltTextComponent(){this.editor.ui.componentFactory.add("drupalImageAlternativeTextMissing",(e=>{const t=new w(e);return t.listenTo(t.button,"execute",(()=>{this._isInBalloon&&this._balloon.remove(this._form),this._showForm()})),t.listenTo(this.editor.ui,"update",(()=>{t.set({isVisible:!this._isVisible||!t.isSelected})})),t}))}destroy(){super.destroy(),this._form.destroy()}_createButton(){const t=this.editor;t.ui.componentFactory.add("drupalImageAlternativeText",(i=>{const r=t.commands.get("imageTextAlternative"),s=new g.ButtonView(i);return s.set({label:Drupal.t("Change image alternative text"),icon:e.icons.lowVision,tooltip:!0}),s.bind("isEnabled").to(r,"isEnabled"),this.listenTo(s,"execute",(()=>{this._showForm()})),s}))}_createForm(){const e=this.editor,t=e.editing.view.document,i=e.plugins.get("ImageUtils");this._balloon=this.editor.plugins.get("ContextualBalloon"),this._form=new f(e.locale),this._form.render(),this.listenTo(this._form,"submit",(()=>{e.execute("imageTextAlternative",{newValue:this._form.decorativeToggle.isOn?"":this._form.labeledInput.fieldView.element.value}),this._hideForm(!0)})),this.listenTo(this._form,"cancel",(()=>{this._hideForm(!0)})),this.listenTo(this._form.decorativeToggle,"execute",(()=>{h(e)})),this._form.keystrokes.set("Esc",((e,t)=>{this._hideForm(!0),t()})),this.listenTo(e.ui,"update",(()=>{i.getClosestSelectedImageWidget(t.selection)?this._isVisible&&h(e):this._hideForm(!0)})),(0,g.clickOutsideHandler)({emitter:this._form,activator:()=>this._isVisible,contextElements:[this._balloon.view.element],callback:()=>this._hideForm()})}_showForm(){if(this._isVisible)return;const e=this.editor,t=e.commands.get("imageTextAlternative"),i=this._form.decorativeToggle,r=this._form.labeledInput;this._form.disableCssTransitions(),this._isInBalloon||this._balloon.add({view:this._form,position:p(e)}),i.isOn=""===t.value,r.fieldView.element.value=t.value||"",r.fieldView.value=r.fieldView.element.value,i.isOn?i.focus():r.fieldView.select(),this._form.enableCssTransitions()}_hideForm(e){this._isInBalloon&&(this._form.focusTracker.isFocused&&this._form.saveButtonView.focus(),this._balloon.remove(this._form),e&&this.editor.editing.view.focus())}get _isVisible(){return this._balloon.visibleView===this._form}get _isInBalloon(){return this._balloon.hasView(this._form)}}class y extends e.Plugin{static get requires(){return[m,v]}static get pluginName(){return"DrupalImageAlternativeText"}}class A extends e.Plugin{static get requires(){return[d,y]}static get pluginName(){return"DrupalImage"}}const I=A;class k extends e.Plugin{init(){const{editor:e}=this;e.plugins.get("ImageUploadEditing").on("uploadComplete",((t,{data:i,imageElement:r})=>{e.model.change((e=>{e.setAttribute("dataEntityUuid",i.response.uuid,r),e.setAttribute("dataEntityType",i.response.entity_type,r)}))}))}static get pluginName(){return"DrupalImageUploadEditing"}}var x=i("ckeditor5/src/upload.js");class _{constructor(e,t){this.loader=e,this.options=t}upload(){return this.loader.file.then((e=>new Promise(((t,i)=>{this._initRequest(),this._initListeners(t,i,e),this._sendRequest(e)}))))}abort(){this.xhr&&this.xhr.abort()}_initRequest(){this.xhr=new XMLHttpRequest,this.xhr.open("POST",this.options.uploadUrl,!0),this.xhr.responseType="json"}_initListeners(e,t,i){const r=this.xhr,s=this.loader,n=`Couldn't upload file: ${i.name}.`;r.addEventListener("error",(()=>t(n))),r.addEventListener("abort",(()=>t())),r.addEventListener("load",(()=>{const i=r.response;if(!i||i.error)return t(i&&i.error&&i.error.message?i.error.message:n);e({response:i,urls:{default:i.url}})})),r.upload&&r.upload.addEventListener("progress",(e=>{e.lengthComputable&&(s.uploadTotal=e.total,s.uploaded=e.loaded)}))}_sendRequest(e){const t=this.options.headers||{},i=this.options.withCredentials||!1;Object.keys(t).forEach((e=>{this.xhr.setRequestHeader(e,t[e])})),this.xhr.withCredentials=i;const r=new FormData;r.append("upload",e),this.xhr.send(r)}}class T extends e.Plugin{static get requires(){return[x.FileRepository]}static get pluginName(){return"DrupalFileRepository"}init(){const e=this.editor.config.get("drupalImageUpload");e&&(e.uploadUrl?this.editor.plugins.get(x.FileRepository).createUploadAdapter=t=>new _(t,e):(0,b.logWarning)("simple-upload-adapter-missing-uploadurl"))}}class E extends e.Plugin{static get requires(){return[T,k]}static get pluginName(){return"DrupalImageUpload"}}const V=E;class C extends e.Plugin{init(){const{editor:e}=this;e.ui.componentFactory.add("drupalInsertImage",(()=>e.ui.componentFactory.create("insertImage")))}static get pluginName(){return"DrupalInsertImage"}}const B={DrupalImage:I,DrupalImageUpload:V,DrupalInsertImage:C}})(),r=r.default})()));
\ No newline at end of file
diff --git a/web/core/modules/ckeditor5/js/ckeditor5.js b/web/core/modules/ckeditor5/js/ckeditor5.js
index e204023d7a4c3e46a0767d2312c047bd2b3daccb..bd5f3facdf9c19f252461880e24eea078a0f5dbe 100644
--- a/web/core/modules/ckeditor5/js/ckeditor5.js
+++ b/web/core/modules/ckeditor5/js/ckeditor5.js
@@ -116,6 +116,10 @@
       });
     }
 
+    if (config === null) {
+      return null;
+    }
+
     return Object.entries(config).reduce((processed, [key, value]) => {
       if (typeof value === 'object') {
         // Check for null values.
@@ -443,22 +447,9 @@
           editor.model.document.on('change:data', () => {
             const callback = callbacks.get(id);
             if (callback) {
-              if (editor.plugins.has('SourceEditing')) {
-                // If the change:data is being called while in source editing
-                // mode, it means that the form is being submitted. To avoid
-                // race conditions, in this case the callback gets called
-                // without decorating the callback with debounce.
-                // @see https://www.drupal.org/i/3229174
-                // @see Drupal.editorDetach
-                if (editor.plugins.get('SourceEditing').isSourceEditingMode) {
-                  callback();
-                  return;
-                }
-              }
-
               // Marks the field as changed.
               // @see Drupal.editorAttach
-              debounce(callback, 400)();
+              callback();
             }
           });
 
@@ -530,7 +521,7 @@
      *   Callback called with the value of the editor.
      */
     onChange(element, callback) {
-      callbacks.set(getElementId(element), callback);
+      callbacks.set(getElementId(element), debounce(callback, 400, true));
     },
 
     /**
@@ -570,7 +561,7 @@
             const callback = callbacks.get(id);
             if (callback) {
               // Allow modules to update EditorModel by providing the current data.
-              debounce(callback, 400)(editor.getData());
+              callback(editor.getData());
             }
           });
         })
@@ -637,7 +628,7 @@
 
   // Redirect on hash change when the original hash has an associated CKEditor 5.
   function redirectTextareaFragmentToCKEditor5Instance() {
-    const hash = window.location.hash.substr(1);
+    const hash = window.location.hash.substring(1);
     const element = document.getElementById(hash);
     if (element) {
       const editorID = getElementId(element);
diff --git a/web/core/modules/ckeditor5/js/ckeditor5_plugins/drupalImage/src/imagealternativetext/ui/imagealternativetextformview.js b/web/core/modules/ckeditor5/js/ckeditor5_plugins/drupalImage/src/imagealternativetext/ui/imagealternativetextformview.js
index e87c06521d527f55e01165d1abb656680bbe7932..8c6ceadd4a1346fa0e81ca3a16baecb166b5d67c 100644
--- a/web/core/modules/ckeditor5/js/ckeditor5_plugins/drupalImage/src/imagealternativetext/ui/imagealternativetextformview.js
+++ b/web/core/modules/ckeditor5/js/ckeditor5_plugins/drupalImage/src/imagealternativetext/ui/imagealternativetextformview.js
@@ -251,7 +251,7 @@ export default class ImageAlternativeTextFormView extends View {
     labeledInput
       .bind('class')
       .to(this.decorativeToggle, 'isOn', (value) => (value ? 'ck-hidden' : ''));
-    labeledInput.label = Drupal.t('Text alternative');
+    labeledInput.label = Drupal.t('Alternative text');
 
     return labeledInput;
   }
diff --git a/web/core/modules/ckeditor5/tests/src/FunctionalJavascript/CKEditor5Test.php b/web/core/modules/ckeditor5/tests/src/FunctionalJavascript/CKEditor5Test.php
index edc3b94576dcda1b3c2bfe048d594be813ded911..fac456f5a6f35f877e6987dac4652ee268869c07 100644
--- a/web/core/modules/ckeditor5/tests/src/FunctionalJavascript/CKEditor5Test.php
+++ b/web/core/modules/ckeditor5/tests/src/FunctionalJavascript/CKEditor5Test.php
@@ -792,4 +792,82 @@ function (ConstraintViolation $v) {
     $assert_session->responseContains('<!-- Hamsters, alpacas, llamas, and kittens are cute! --><p>This is a <em>test!</em></p>');
   }
 
+  /**
+   * Ensures that changes are saved in CKEditor 5.
+   */
+  public function testSave(): void {
+    // To replicate the bug from https://www.drupal.org/i/3396742
+    // We need 2 or more text formats and node edit page.
+    FilterFormat::create([
+      'format' => 'ckeditor5',
+      'name' => 'CKEditor 5 HTML',
+      'roles' => [RoleInterface::AUTHENTICATED_ID],
+    ])->save();
+    Editor::create([
+      'format' => 'ckeditor5',
+      'editor' => 'ckeditor5',
+      'settings' => [
+        'toolbar' => [
+          'items' => [
+            'sourceEditing',
+          ],
+        ],
+        'plugins' => [
+          'ckeditor5_sourceEditing' => [
+            'allowed_tags' => [],
+          ],
+        ],
+      ],
+    ])->save();
+    $this->assertSame([], array_map(
+      function (ConstraintViolation $v) {
+        return (string) $v->getMessage();
+      },
+      iterator_to_array(CKEditor5::validatePair(
+        Editor::load('ckeditor5'),
+        FilterFormat::load('ckeditor5')
+      ))
+    ));
+    FilterFormat::create([
+      'format' => 'ckeditor5_2',
+      'name' => 'CKEditor 5 HTML 2',
+      'roles' => [RoleInterface::AUTHENTICATED_ID],
+    ])->save();
+    Editor::create([
+      'format' => 'ckeditor5_2',
+      'editor' => 'ckeditor5',
+    ])->save();
+    $this->assertSame([], array_map(
+      function (ConstraintViolation $v) {
+        return (string) $v->getMessage();
+      },
+      iterator_to_array(CKEditor5::validatePair(
+        Editor::load('ckeditor5_2'),
+        FilterFormat::load('ckeditor5_2')
+      ))
+    ));
+    $this->drupalCreateNode([
+      'title' => 'My test content',
+    ]);
+
+    // Test that entered text is saved.
+    $this->drupalGet('node/1/edit');
+    $page = $this->getSession()->getPage();
+    $this->waitForEditor();
+    $editor = $page->find('css', '.ck-content');
+    $editor->setValue('Very important information');
+    $page->pressButton('Save');
+    $this->assertSession()->responseContains('Very important information');
+
+    // Test that changes only in source are saved.
+    $this->drupalGet('node/1/edit');
+    $page = $this->getSession()->getPage();
+    $this->waitForEditor();
+    $this->pressEditorButton('Source');
+    $editor = $page->find('css', '.ck-source-editing-area textarea');
+    $editor->setValue('Text hidden in the source');
+    $page->pressButton('Save');
+    $this->assertSession()->responseContains('Text hidden in the source');
+  }
+
 }
diff --git a/web/core/modules/comment/src/CommentForm.php b/web/core/modules/comment/src/CommentForm.php
index 7bd37d3b118c418c8febcdff8cd6564bd822f85c..18b48460d348ff006a3b774cd4653d697105a88c 100644
--- a/web/core/modules/comment/src/CommentForm.php
+++ b/web/core/modules/comment/src/CommentForm.php
@@ -313,7 +313,7 @@ public function buildEntity(array $form, FormStateInterface $form_state) {
     // Validate the comment's subject. If not specified, extract from comment
     // body.
     if (trim($comment->getSubject()) == '') {
-      if ($comment->hasField('comment_body')) {
+      if ($comment->hasField('comment_body') && !$comment->comment_body->isEmpty()) {
         // The body may be in any format, so:
         // 1) Filter it into HTML
         // 2) Strip out all HTML tags
@@ -323,7 +323,7 @@ public function buildEntity(array $form, FormStateInterface $form_state) {
       }
       // Edge cases where the comment body is populated only by HTML tags will
       // require a default subject.
-      if ($comment->getSubject() == '') {
+      if (trim($comment->getSubject()) == '') {
         $comment->setSubject($this->t('(No subject)'));
       }
     }
diff --git a/web/core/modules/comment/src/CommentLazyBuilders.php b/web/core/modules/comment/src/CommentLazyBuilders.php
index d7198499147ec37c02162143a8ddb62174f21325..d553411b9f34db02ef2ea932179c97b693557d64 100644
--- a/web/core/modules/comment/src/CommentLazyBuilders.php
+++ b/web/core/modules/comment/src/CommentLazyBuilders.php
@@ -161,7 +161,9 @@ public function renderLinks($comment_entity_id, $view_mode, $langcode, $is_in_pr
    *   The entity to which the comment is attached.
    *
    * @return array
-   *   An array that can be processed by drupal_pre_render_links().
+   *   An array that can be processed by Link::preRenderLinks().
+   *
+   * @see \Drupal\Core\Render\Element\Link::preRenderLinks()
    */
   protected function buildLinks(CommentInterface $entity, EntityInterface $commented_entity) {
     $links = [];
diff --git a/web/core/modules/comment/tests/src/Functional/CommentInterfaceTest.php b/web/core/modules/comment/tests/src/Functional/CommentInterfaceTest.php
index c82d1b91a81d585baa14d4a87800a164419c36df..dfc8a21dc8fbebf674db117ed5d3da97a1878547 100644
--- a/web/core/modules/comment/tests/src/Functional/CommentInterfaceTest.php
+++ b/web/core/modules/comment/tests/src/Functional/CommentInterfaceTest.php
@@ -8,6 +8,7 @@
 use Drupal\comment\Entity\Comment;
 use Drupal\Core\Entity\Entity\EntityViewDisplay;
 use Drupal\Core\Entity\Entity\EntityViewMode;
+use Drupal\field\Entity\FieldConfig;
 use Drupal\user\RoleInterface;
 use Drupal\filter\Entity\FilterFormat;
 
@@ -238,6 +239,16 @@ public function testAutoFilledSubject() {
     $body_text2 = 'AQuickBrownFoxJumpedOverTheLazyDog';
     $comment2 = $this->postComment(NULL, $body_text2, '', TRUE);
     $this->assertEquals('AQuickBrownFoxJumpedOverTheL…', $comment2->getSubject());
+
+    // Make the body field non required.
+    $comment_body_field = FieldConfig::loadByName('comment', 'comment', 'comment_body');
+    $comment_body_field->setRequired(FALSE)->save();
+    // Try to post a comment without any value in body and subject fields.
+    $this->drupalGet('node/' . $this->node->id());
+    // Ensure that there are no PHP errors or warnings when automatically
+    // generating the subject. This occurs when the comment body is empty.
+    $comment2 = $this->postComment(NULL, '', '', TRUE);
+    $this->assertEquals('(No subject)', $comment2->getSubject());
   }
 
   /**
diff --git a/web/core/modules/comment/tests/src/Functional/CommentThreadingTest.php b/web/core/modules/comment/tests/src/Functional/CommentThreadingTest.php
index 35f1d749d67e782a1d6c80fb7043941fc655e38a..08ced21dc42fed61bf382e0e71e2df07c7723772 100644
--- a/web/core/modules/comment/tests/src/Functional/CommentThreadingTest.php
+++ b/web/core/modules/comment/tests/src/Functional/CommentThreadingTest.php
@@ -125,14 +125,14 @@ public function testCommentThreading() {
   /**
    * Asserts that the link to the specified parent comment is present.
    *
-   * @param int $cid
+   * @param string $cid
    *   The comment ID to check.
-   * @param int $pid
+   * @param string $pid
    *   The expected parent comment ID.
    *
    * @internal
    */
-  protected function assertParentLink(int $cid, int $pid): void {
+  protected function assertParentLink(string $cid, string $pid): void {
     // This pattern matches a markup structure like:
     // @code
     // <article id="comment-2">
@@ -156,12 +156,12 @@ protected function assertParentLink(int $cid, int $pid): void {
   /**
    * Asserts that the specified comment does not have a link to a parent.
    *
-   * @param int $cid
+   * @param string $cid
    *   The comment ID to check.
    *
    * @internal
    */
-  protected function assertNoParentLink(int $cid): void {
+  protected function assertNoParentLink(string $cid): void {
     $pattern = "//article[@id='comment-$cid']";
     // A parent link is always accompanied by the text "In reply to".
     $this->assertSession()->elementTextNotContains('xpath', $pattern, 'In reply to');
diff --git a/web/core/modules/comment/tests/src/Functional/Rest/CommentResourceTestBase.php b/web/core/modules/comment/tests/src/Functional/Rest/CommentResourceTestBase.php
index ac1a1b7ffb6b037a979674bb61b6aba464a2b48a..f404d0e49e603fda5f83f9dff16f9ec8405dbbc5 100644
--- a/web/core/modules/comment/tests/src/Functional/Rest/CommentResourceTestBase.php
+++ b/web/core/modules/comment/tests/src/Functional/Rest/CommentResourceTestBase.php
@@ -359,6 +359,9 @@ public function testPostSkipCommentApproval() {
     $this->assertResourceResponse(201, FALSE, $response);
     $this->assertFalse($unserialized->isPublished());
 
+    // Make sure the role save below properly invalidates cache tags.
+    $this->refreshVariables();
+
     // Grant anonymous permission to skip comment approval.
     $this->grantPermissionsToTestedRole(['skip comment approval']);
 
diff --git a/web/core/modules/config/tests/src/Functional/ConfigEntityListTest.php b/web/core/modules/config/tests/src/Functional/ConfigEntityListTest.php
index 6bad38c77b14701f52aaded94862c72c0f6fc79a..86fa29ef972d667fbc710ae28b5f01b2ee71d985 100644
--- a/web/core/modules/config/tests/src/Functional/ConfigEntityListTest.php
+++ b/web/core/modules/config/tests/src/Functional/ConfigEntityListTest.php
@@ -277,7 +277,7 @@ public function testPager() {
     // Create 51 test entities.
     for ($i = 1; $i < 52; $i++) {
       $storage->create([
-        'id' => str_pad($i, 2, '0', STR_PAD_LEFT),
+        'id' => str_pad((string) $i, 2, '0', STR_PAD_LEFT),
         'label' => 'Test config entity ' . $i,
         'weight' => $i,
         'protected_property' => $i,
diff --git a/web/core/modules/config/tests/src/Functional/ConfigInstallProfileUnmetDependenciesTest.php b/web/core/modules/config/tests/src/Functional/ConfigInstallProfileUnmetDependenciesTest.php
index 5653b28e4e4c91c8f1ecf8dc808894b586303f92..dc5ace9423cc3833d74d9d37cc94ad4b8709de88 100644
--- a/web/core/modules/config/tests/src/Functional/ConfigInstallProfileUnmetDependenciesTest.php
+++ b/web/core/modules/config/tests/src/Functional/ConfigInstallProfileUnmetDependenciesTest.php
@@ -80,7 +80,7 @@ protected function copyTestingOverrides() {
         mkdir($dest . DIRECTORY_SEPARATOR . $iterator->getSubPathName());
       }
       else {
-        copy($item, $dest . DIRECTORY_SEPARATOR . $iterator->getSubPathName());
+        copy((string) $item, $dest . DIRECTORY_SEPARATOR . $iterator->getSubPathName());
       }
     }
 
diff --git a/web/core/modules/content_moderation/src/EventSubscriber/ConfigImportSubscriber.php b/web/core/modules/content_moderation/src/EventSubscriber/ConfigImportSubscriber.php
index 930167f04f23383be87003fd965adca2630e8e9d..68eb18dbb8b33ee9e145b8f4985a2681cc5e09d1 100644
--- a/web/core/modules/content_moderation/src/EventSubscriber/ConfigImportSubscriber.php
+++ b/web/core/modules/content_moderation/src/EventSubscriber/ConfigImportSubscriber.php
@@ -47,7 +47,8 @@ public function onConfigImporterValidate(ConfigImporterEvent $event) {
     foreach (['update', 'delete'] as $op) {
       $unprocessed_configurations = $event->getConfigImporter()->getUnprocessedConfiguration($op);
       foreach ($unprocessed_configurations as $unprocessed_configuration) {
-        if ($workflow = $this->getWorkflow($unprocessed_configuration)) {
+        if (($workflow = $this->getWorkflow($unprocessed_configuration))
+            && $workflow->getTypePlugin()->getPluginId() === 'content_moderation') {
           if ($op === 'update') {
             $original_workflow_config = $event->getConfigImporter()
               ->getStorageComparer()
diff --git a/web/core/modules/content_moderation/src/Plugin/views/filter/ModerationStateFilter.php b/web/core/modules/content_moderation/src/Plugin/views/filter/ModerationStateFilter.php
index 0dfbe3d865d8b14a6699b787079911ab56ce8486..b5b9f1dcc9cce533e6f26feb55bdd9946f259eff 100644
--- a/web/core/modules/content_moderation/src/Plugin/views/filter/ModerationStateFilter.php
+++ b/web/core/modules/content_moderation/src/Plugin/views/filter/ModerationStateFilter.php
@@ -144,16 +144,17 @@ protected function opSimple() {
         $entity_base_table = $entity_type->getBaseTable();
         $entity_revision_base_table = $entity_type->isTranslatable() ? $entity_type->getRevisionDataTable() : $entity_type->getRevisionTable();
         if ($this->table === $entity_revision_base_table) {
+          $entity_revision_base_table_alias = $this->relationship ?: $this->table;
           $configuration = [
             'table' => $entity_base_table,
             'field' => $entity_type->getKey('id'),
-            'left_table' => $entity_revision_base_table,
+            'left_table' => $entity_revision_base_table_alias,
             'left_field' => $entity_type->getKey('id'),
             'type' => 'INNER',
           ];
 
           $join = Views::pluginManager('join')->createInstance('standard', $configuration);
-          $entity_base_table_alias = $this->query->addRelationship($entity_base_table, $join, $entity_revision_base_table);
+          $entity_base_table_alias = $this->query->addRelationship($entity_base_table, $join, $entity_revision_base_table_alias);
         }
 
         $bundle_condition = $this->view->query->getConnection()->condition('AND');
diff --git a/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/config/install/views.view.test_content_moderation_filter_via_revision_relationship.yml b/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/config/install/views.view.test_content_moderation_filter_via_revision_relationship.yml
new file mode 100644
index 0000000000000000000000000000000000000000..ca998cde89df49c91708bd7c432e51728e9fdcc3
--- /dev/null
+++ b/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/config/install/views.view.test_content_moderation_filter_via_revision_relationship.yml
@@ -0,0 +1,351 @@
+langcode: en
+status: true
+dependencies:
+  module:
+    - content_moderation
+    - user
+id: test_content_moderation_filter_via_revision_relationship
+label: test_content_moderation_filter_via_revision_relationship
+module: views
+description: ''
+tag: ''
+base_table: users_field_data
+base_field: uid
+display:
+  default:
+    id: default
+    display_title: Default
+    display_plugin: default
+    position: 0
+    display_options:
+      title: test_content_moderation_filter_via_revision_relationship
+      fields:
+        name:
+          id: name
+          table: users_field_data
+          field: name
+          relationship: none
+          group_type: group
+          admin_label: ''
+          entity_type: user
+          entity_field: name
+          plugin_id: field
+          label: ''
+          exclude: false
+          alter:
+            alter_text: false
+            text: ''
+            make_link: false
+            path: ''
+            absolute: false
+            external: false
+            replace_spaces: false
+            path_case: none
+            trim_whitespace: false
+            alt: ''
+            rel: ''
+            link_class: ''
+            prefix: ''
+            suffix: ''
+            target: ''
+            nl2br: false
+            max_length: 0
+            word_boundary: false
+            ellipsis: false
+            more_link: false
+            more_link_text: ''
+            more_link_path: ''
+            strip_tags: false
+            trim: false
+            preserve_tags: ''
+            html: false
+          element_type: ''
+          element_class: ''
+          element_label_type: ''
+          element_label_class: ''
+          element_label_colon: false
+          element_wrapper_type: ''
+          element_wrapper_class: ''
+          element_default_classes: true
+          empty: ''
+          hide_empty: false
+          empty_zero: false
+          hide_alter_empty: true
+          click_sort_column: value
+          type: user_name
+          settings:
+            link_to_entity: false
+          group_column: value
+          group_columns: {  }
+          group_rows: true
+          delta_limit: 0
+          delta_offset: 0
+          delta_reversed: false
+          delta_first_last: false
+          multi_type: separator
+          separator: ', '
+          field_api_classes: false
+        title:
+          id: title
+          table: node_field_revision
+          field: title
+          relationship: uid_revision_test
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          entity_field: title
+          plugin_id: field
+          label: ''
+          exclude: false
+          alter:
+            alter_text: false
+            text: ''
+            make_link: false
+            path: ''
+            absolute: false
+            external: false
+            replace_spaces: false
+            path_case: none
+            trim_whitespace: false
+            alt: ''
+            rel: ''
+            link_class: ''
+            prefix: ''
+            suffix: ''
+            target: ''
+            nl2br: false
+            max_length: 0
+            word_boundary: true
+            ellipsis: true
+            more_link: false
+            more_link_text: ''
+            more_link_path: ''
+            strip_tags: false
+            trim: false
+            preserve_tags: ''
+            html: false
+          element_type: ''
+          element_class: ''
+          element_label_type: ''
+          element_label_class: ''
+          element_label_colon: false
+          element_wrapper_type: ''
+          element_wrapper_class: ''
+          element_default_classes: true
+          empty: ''
+          hide_empty: false
+          empty_zero: false
+          hide_alter_empty: true
+          click_sort_column: value
+          type: string
+          settings:
+            link_to_entity: false
+          group_column: value
+          group_columns: {  }
+          group_rows: true
+          delta_limit: 0
+          delta_offset: 0
+          delta_reversed: false
+          delta_first_last: false
+          multi_type: separator
+          separator: ', '
+          field_api_classes: false
+        moderation_state:
+          id: moderation_state
+          table: node_field_revision
+          field: moderation_state
+          relationship: uid_revision_test
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          plugin_id: moderation_state_field
+          label: ''
+          exclude: false
+          alter:
+            alter_text: false
+            text: ''
+            make_link: false
+            path: ''
+            absolute: false
+            external: false
+            replace_spaces: false
+            path_case: none
+            trim_whitespace: false
+            alt: ''
+            rel: ''
+            link_class: ''
+            prefix: ''
+            suffix: ''
+            target: ''
+            nl2br: false
+            max_length: 0
+            word_boundary: true
+            ellipsis: true
+            more_link: false
+            more_link_text: ''
+            more_link_path: ''
+            strip_tags: false
+            trim: false
+            preserve_tags: ''
+            html: false
+          element_type: ''
+          element_class: ''
+          element_label_type: ''
+          element_label_class: ''
+          element_label_colon: false
+          element_wrapper_type: ''
+          element_wrapper_class: ''
+          element_default_classes: true
+          empty: ''
+          hide_empty: false
+          empty_zero: false
+          hide_alter_empty: true
+          click_sort_column: value
+          type: content_moderation_state
+          settings: {  }
+          group_column: value
+          group_columns: {  }
+          group_rows: true
+          delta_limit: 0
+          delta_offset: 0
+          delta_reversed: false
+          delta_first_last: false
+          multi_type: separator
+          separator: ', '
+          field_api_classes: false
+      pager:
+        type: none
+        options:
+          offset: 0
+      exposed_form:
+        type: basic
+        options:
+          submit_button: Apply
+          reset_button: false
+          reset_button_label: Reset
+          exposed_sorts_label: 'Sort by'
+          expose_sort_order: true
+          sort_asc_label: Asc
+          sort_desc_label: Desc
+      access:
+        type: perm
+        options:
+          perm: 'access user profiles'
+      cache:
+        type: tag
+        options: {  }
+      empty: {  }
+      sorts:
+        vid:
+          id: vid
+          table: node_field_revision
+          field: vid
+          relationship: uid_revision_test
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          entity_field: vid
+          plugin_id: standard
+          order: ASC
+          expose:
+            label: ''
+            field_identifier: ''
+          exposed: false
+      arguments: {  }
+      filters:
+        moderation_state:
+          id: moderation_state
+          table: node_field_revision
+          field: moderation_state
+          relationship: uid_revision_test
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          plugin_id: moderation_state_filter
+          operator: in
+          value: {  }
+          group: 1
+          exposed: true
+          expose:
+            operator_id: moderation_state_op
+            label: 'Moderation state'
+            description: ''
+            use_operator: false
+            operator: moderation_state_op
+            operator_limit_selection: false
+            operator_list: {  }
+            identifier: moderation_state
+            required: false
+            remember: false
+            multiple: false
+            remember_roles:
+              authenticated: authenticated
+              anonymous: '0'
+              administrator: '0'
+            reduce: false
+          is_grouped: false
+          group_info:
+            label: ''
+            description: ''
+            identifier: ''
+            optional: true
+            widget: select
+            multiple: false
+            remember: false
+            default_group: All
+            default_group_multiple: {  }
+            group_items: {  }
+      style:
+        type: default
+      row:
+        type: fields
+      query:
+        type: views_query
+        options:
+          query_comment: ''
+          disable_sql_rewrite: false
+          distinct: false
+          replica: false
+          query_tags: {  }
+      relationships:
+        uid_revision_test:
+          id: uid_revision_test
+          table: users_field_data
+          field: uid_revision_test
+          relationship: none
+          group_type: group
+          admin_label: 'node revisions'
+          entity_type: user
+          plugin_id: standard
+          required: true
+      header: {  }
+      footer: {  }
+      display_extenders: {  }
+    cache_metadata:
+      max-age: -1
+      contexts:
+        - 'languages:language_content'
+        - 'languages:language_interface'
+        - url
+        - url.query_args
+        - user.permissions
+      tags:
+        - 'config:workflow_list'
+  page_1:
+    id: page_1
+    display_title: Page
+    display_plugin: page
+    position: 1
+    display_options:
+      display_extenders: {  }
+      path: test-content-moderation-filter-revision-relationship
+    cache_metadata:
+      max-age: -1
+      contexts:
+        - 'languages:language_content'
+        - 'languages:language_interface'
+        - url
+        - url.query_args
+        - user.permissions
+      tags:
+        - 'config:workflow_list'
diff --git a/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/content_moderation_test_views.module b/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/content_moderation_test_views.module
index 11fe270883914292c9447bc5f50600084ef68467..47f34c21f667321046893606938e02991430e83f 100644
--- a/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/content_moderation_test_views.module
+++ b/web/core/modules/content_moderation/tests/modules/content_moderation_test_views/content_moderation_test_views.module
@@ -20,3 +20,26 @@ function content_moderation_test_views_views_query_alter(ViewExecutable $view, Q
     $query->addOrderBy('node_field_revision', 'vid', 'ASC');
   }
 }
+
+/**
+ * Implements hook_views_data_alter().
+ *
+ * @see \Drupal\Tests\content_moderation\Kernel\ViewsModerationStateFilterTest
+ */
+function content_moderation_test_views_views_data_alter(array &$data) {
+  if (isset($data['users_field_data'])) {
+    $data['users_field_data']['uid_revision_test'] = [
+      'help' => t('Relate the content revision to the user who created it.'),
+      'real field' => 'uid',
+      'relationship' => [
+        'title' => t('Content revision authored'),
+        'help' => t('Relate the content revision to the user who created it. This relationship will create one record for each content revision item created by the user.'),
+        'id' => 'standard',
+        'base' => 'node_field_revision',
+        'base field' => 'uid',
+        'field' => 'uid',
+        'label' => t('node revisions'),
+      ],
+    ];
+  }
+}
diff --git a/web/core/modules/content_moderation/tests/src/Functional/ModerationFormTest.php b/web/core/modules/content_moderation/tests/src/Functional/ModerationFormTest.php
index 4f621c0868bef30f596a4743060387b24cd36963..c4b992ac196e245b8016284f652bd1d628fbca34 100644
--- a/web/core/modules/content_moderation/tests/src/Functional/ModerationFormTest.php
+++ b/web/core/modules/content_moderation/tests/src/Functional/ModerationFormTest.php
@@ -312,7 +312,7 @@ public function testContentTranslationNodeForm() {
     $french = \Drupal::languageManager()->getLanguage('fr');
 
     $this->drupalGet($latest_version_path);
-    $this->assertSession()->statusCodeEquals('403');
+    $this->assertSession()->statusCodeEquals(403);
     $this->assertSession()->elementNotExists('xpath', '//ul[@class="entity-moderation-form"]');
 
     // Add french translation (revision 2).
@@ -326,7 +326,7 @@ public function testContentTranslationNodeForm() {
     ], 'Save (this translation)');
 
     $this->drupalGet($latest_version_path, ['language' => $french]);
-    $this->assertSession()->statusCodeEquals('403');
+    $this->assertSession()->statusCodeEquals(403);
     $this->assertSession()->elementNotExists('xpath', '//ul[@class="entity-moderation-form"]');
 
     // Add french pending revision (revision 3).
diff --git a/web/core/modules/content_moderation/tests/src/Functional/ViewsModerationStateFilterTest.php b/web/core/modules/content_moderation/tests/src/Functional/ViewsModerationStateFilterTest.php
index cdaae0d2e41f115bbf21aac7b878c4c8e8915f81..a3e7354ca9b142624f1d04ee8c2428d1ffed78ce 100644
--- a/web/core/modules/content_moderation/tests/src/Functional/ViewsModerationStateFilterTest.php
+++ b/web/core/modules/content_moderation/tests/src/Functional/ViewsModerationStateFilterTest.php
@@ -341,7 +341,7 @@ protected function assertFilterStates(array $states, bool $check_size = FALSE):
     // Check that the size of the select element does not exceed 8 options.
     if ($check_size) {
       $this->assertGreaterThan(8, count($states));
-      $assert_session->elementAttributeContains('css', '#edit-default-revision-state', 'size', 8);
+      $assert_session->elementAttributeContains('css', '#edit-default-revision-state', 'size', '8');
     }
 
     // Check that an option exists for each of the expected states.
diff --git a/web/core/modules/content_moderation/tests/src/Kernel/ViewsModerationStateFilterTest.php b/web/core/modules/content_moderation/tests/src/Kernel/ViewsModerationStateFilterTest.php
index c4912798df98653e24243a301fe9e88a07d29f4e..063d91149580a6bfa6b805f400770e34dd8f0c66 100644
--- a/web/core/modules/content_moderation/tests/src/Kernel/ViewsModerationStateFilterTest.php
+++ b/web/core/modules/content_moderation/tests/src/Kernel/ViewsModerationStateFilterTest.php
@@ -240,6 +240,34 @@ public function testModerationStateFilterOnJoinedEntity() {
     ]);
     $view->execute();
     $this->assertIdenticalResultset($view, [], ['name' => 'name']);
+
+    // Revision Data Table Relationship: Filtering by the published state will
+    // filter out the sample content.
+    $view = Views::getView('test_content_moderation_filter_via_revision_relationship');
+    $view->setExposedInput([
+      'moderation_state' => 'editorial-published',
+    ]);
+    $view->execute();
+    $this->assertIdenticalResultset($view, [
+      [
+        'name' => 'Test user',
+        'title' => 'Test node',
+        'moderation_state' => 'published',
+      ],
+    ], [
+      'name' => 'name',
+      'title' => 'title',
+      'moderation_state' => 'moderation_state',
+    ]);
+
+    // Revision Data Table Relationship: Filtering by the draft state will
+    // filter out the sample content.
+    $view = Views::getView('test_content_moderation_filter_via_revision_relationship');
+    $view->setExposedInput([
+      'moderation_state' => 'editorial-draft',
+    ]);
+    $view->execute();
+    $this->assertIdenticalResultset($view, [], ['name' => 'name']);
   }
 
   /**
diff --git a/web/core/modules/content_translation/content_translation.admin.js b/web/core/modules/content_translation/content_translation.admin.js
index 463525b1bcfab54305e5d8bc2e966d89ff790b17..f24cc4dac51ef4fa4aafd4dc13880c1126d54fed 100644
--- a/web/core/modules/content_translation/content_translation.admin.js
+++ b/web/core/modules/content_translation/content_translation.admin.js
@@ -61,7 +61,10 @@
           $element = $fields.filter(filterFieldsList);
         }
 
-        if ($element[0].matches(`input[value="${column}"]:checked`)) {
+        if (
+          $element.length &&
+          $element[0].matches(`input[value="${column}"]:checked`)
+        ) {
           $fields.prop('checked', true).not($element).prop('disabled', true);
         } else {
           $fields.prop('disabled', false);
@@ -89,7 +92,7 @@
       ).forEach((input) => {
         const $input = $(input);
         const $bundleSettings = $input.closest('.bundle-settings');
-        if (input.checked) {
+        if (!input.checked) {
           $bundleSettings.nextUntil('.bundle-settings').hide();
         } else {
           $bundleSettings
diff --git a/web/core/modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php b/web/core/modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php
index 689a006b9f3e160d4f2625ebece36c89c75cd047..c2035dcb2fb6b0ca82704b5c697400b99f9f95f3 100644
--- a/web/core/modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php
+++ b/web/core/modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php
@@ -2,7 +2,6 @@
 
 namespace Drupal\Tests\content_translation\Functional;
 
-use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Core\Cache\Cache;
 use Drupal\Core\Entity\EntityChangedInterface;
 use Drupal\Core\Entity\EntityInterface;
@@ -576,7 +575,7 @@ protected function doTestTranslationChanged() {
         $entity = $storage->load($this->entityId);
         $this->assertEquals(
           $entity->getChangedTimeAcrossTranslations(), $entity->getTranslation($langcode)->getChangedTime(),
-          new FormattableMarkup('Changed time for language %language is the latest change over all languages.', ['%language' => $language->getName()])
+          "Changed time for language {$language->getName()} is the latest change over all languages."
         );
       }
 
diff --git a/web/core/modules/content_translation/tests/src/FunctionalJavascript/ContentTranslationConfigUITest.php b/web/core/modules/content_translation/tests/src/FunctionalJavascript/ContentTranslationConfigUITest.php
new file mode 100644
index 0000000000000000000000000000000000000000..ed54b4527079e189541c7e85e7750b67222a9cb8
--- /dev/null
+++ b/web/core/modules/content_translation/tests/src/FunctionalJavascript/ContentTranslationConfigUITest.php
@@ -0,0 +1,47 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\content_translation\FunctionalJavascript;
+
+use Drupal\FunctionalJavascriptTests\WebDriverTestBase;
+
+/**
+ * Tests that the content translation configuration javascript does't fail.
+ *
+ * @group content_translation
+ */
+class ContentTranslationConfigUITest extends WebDriverTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected static $modules = ['content_translation', 'node'];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'stark';
+
+  /**
+   * Use the minimal profile.
+   *
+   * @var string
+   */
+  protected $profile = 'standard';
+
+  /**
+   * Tests that the content translation configuration javascript does't fail.
+   */
+  public function testContentTranslationConfigUI() {
+    $content_translation_manager = $this->container->get('content_translation.manager');
+    $content_translation_manager->setEnabled('node', 'article', TRUE);
+    $this->rebuildContainer();
+
+    $admin = $this->drupalCreateUser([], NULL, TRUE);
+    $this->drupalLogin($admin);
+    $this->drupalGet('/admin/config/regional/content-language');
+    $this->failOnJavaScriptErrors();
+  }
+
+}
diff --git a/web/core/modules/datetime/tests/src/Functional/Views/FilterDateTest.php b/web/core/modules/datetime/tests/src/Functional/Views/FilterDateTest.php
index ce3f43014533d4d30adc3f4f223acd9db158ee90..fdb33d1710949b22c9a763230adbd66a21868691 100644
--- a/web/core/modules/datetime/tests/src/Functional/Views/FilterDateTest.php
+++ b/web/core/modules/datetime/tests/src/Functional/Views/FilterDateTest.php
@@ -122,12 +122,12 @@ protected function setUp($import_test_views = TRUE, $modules = ['views_test_conf
    * Tests exposed grouped filters.
    */
   public function testExposedGroupedFilters() {
-    // Expose the empty and not empty operators in a grouped filter.
-    $this->drupalGet('admin/structure/views/nojs/handler/test_filter_datetime/default/filter/' . $this->fieldName . '_value');
+    $filter_identifier = $this->fieldName . '_value';
+    $this->drupalGet('admin/structure/views/nojs/handler/test_filter_datetime/default/filter/' . $filter_identifier);
     $this->submitForm([], 'Expose filter');
     $this->submitForm([], 'Grouped filters');
 
-    // Test operators with different amount of expected values.
+    // Create groups with different amount of expected values.
     $edit = [];
     // No values are required.
     $edit['options[group_info][group_items][1][title]'] = 'empty';
@@ -160,24 +160,37 @@ public function testExposedGroupedFilters() {
     $this->drupalGet($path);
 
     // Filter the Preview by 'empty'.
-    $this->getSession()->getPage()->findField($this->fieldName . '_value')->selectOption(1);
+    $this->getSession()->getPage()->findField($filter_identifier)->selectOption('1');
     $this->getSession()->getPage()->pressButton('Apply');
     $this->assertIds([4]);
 
     // Filter the Preview by 'not empty'.
-    $this->getSession()->getPage()->findField($this->fieldName . '_value')->selectOption(2);
+    $this->getSession()->getPage()->findField($filter_identifier)->selectOption('2');
     $this->getSession()->getPage()->pressButton('Apply');
     $this->assertIds([1, 2, 3]);
 
     // Filter the Preview by 'less than'.
-    $this->getSession()->getPage()->findField($this->fieldName . '_value')->selectOption(3);
+    $this->getSession()->getPage()->findField($filter_identifier)->selectOption('3');
     $this->getSession()->getPage()->pressButton('Apply');
     $this->assertIds([2, 3]);
 
     // Filter the Preview by 'between'.
-    $this->getSession()->getPage()->findField($this->fieldName . '_value')->selectOption(4);
+    $this->getSession()->getPage()->findField($filter_identifier)->selectOption('4');
     $this->getSession()->getPage()->pressButton('Apply');
     $this->assertIds([2]);
+
+    // Change the identifier for grouped exposed filter.
+    $this->drupalGet('admin/structure/views/nojs/handler/test_filter_datetime/default/filter/' . $filter_identifier);
+    $filter_identifier = 'date';
+    $edit['options[group_info][identifier]'] = $filter_identifier;
+    $this->submitForm($edit, 'Apply');
+    $this->submitForm([], 'Save');
+
+    // Filter results again using a new filter identifier.
+    $this->drupalGet($path);
+    $this->getSession()->getPage()->findField($filter_identifier)->selectOption('2');
+    $this->getSession()->getPage()->pressButton('Apply');
+    $this->assertIds([1, 2, 3]);
   }
 
   /**
diff --git a/web/core/modules/field/field.module b/web/core/modules/field/field.module
index faafebdf521a8d50de1dc68b6fea07f1253afde2..534d0718f125a5e8c59a2075422ff9a107dd4709 100644
--- a/web/core/modules/field/field.module
+++ b/web/core/modules/field/field.module
@@ -392,6 +392,9 @@ function field_field_storage_config_update(FieldStorageConfigInterface $field_st
  * Determine the selection handler plugin ID for an entity reference field.
  */
 function field_field_config_create(FieldConfigInterface $field) {
+  if ($field->isSyncing()) {
+    return;
+  }
   // Act on all sub-types of the entity_reference field type.
   /** @var \Drupal\Core\Field\FieldTypePluginManager $field_type_manager */
   $field_type_manager = \Drupal::service('plugin.manager.field.field_type');
diff --git a/web/core/modules/field/tests/src/Functional/Number/NumberFieldTest.php b/web/core/modules/field/tests/src/Functional/Number/NumberFieldTest.php
index 93030b0f9290509951ca3832d763a8364b8d84eb..28e602741c4384e54bcc593ad0fc22a5de9a86f7 100644
--- a/web/core/modules/field/tests/src/Functional/Number/NumberFieldTest.php
+++ b/web/core/modules/field/tests/src/Functional/Number/NumberFieldTest.php
@@ -339,7 +339,7 @@ public function testNumberFloatField() {
     $this->assertSession()->responseContains('placeholder="0.00"');
 
     // Submit a signed decimal value within the allowed precision and scale.
-    $value = '-1234.5678';
+    $value = -1234.5678;
     $edit = [
       "{$field_name}[0][value]" => $value,
     ];
diff --git a/web/core/modules/field/tests/src/Kernel/EntityReference/EntityReferenceItemTest.php b/web/core/modules/field/tests/src/Kernel/EntityReference/EntityReferenceItemTest.php
index 03532ffbce57c17cee5421d42876a71987f82ef5..ef12736e38f2bc3e1bf5b9968f0eb736295a7dcd 100644
--- a/web/core/modules/field/tests/src/Kernel/EntityReference/EntityReferenceItemTest.php
+++ b/web/core/modules/field/tests/src/Kernel/EntityReference/EntityReferenceItemTest.php
@@ -404,6 +404,17 @@ public function testSelectionHandlerSettings() {
     $field_storage->save();
     $field = FieldConfig::load($field->id());
     $this->assertEquals('views', $field->getSetting('handler'));
+
+    // Check that selection handlers aren't changed during sync.
+    $field = FieldConfig::create([
+      'field_storage' => $field_storage,
+      'bundle' => 'entity_test',
+      'settings' => [
+        'handler' => 'fake:thing',
+      ],
+      'isSyncing' => TRUE,
+    ]);
+    $this->assertEquals('fake:thing', $field->getSetting('handler'));
   }
 
   /**
diff --git a/web/core/modules/field_ui/src/Form/FieldConfigEditForm.php b/web/core/modules/field_ui/src/Form/FieldConfigEditForm.php
index 647f0d62aa91930e15a57e7e5388e2d190abcfa6..c374d0ae6cbf293889a4cc6889245723e90c8a5c 100644
--- a/web/core/modules/field_ui/src/Form/FieldConfigEditForm.php
+++ b/web/core/modules/field_ui/src/Form/FieldConfigEditForm.php
@@ -451,7 +451,7 @@ public function save(array $form, FormStateInterface $form_state) {
       }
     }
     catch (\Exception $e) {
-      $this->messenger()->addStatus(
+      $this->messenger()->addError(
         $this->t(
           'Attempt to update field %label failed: %message.',
           [
diff --git a/web/core/modules/field_ui/tests/src/Functional/ManageDisplayTest.php b/web/core/modules/field_ui/tests/src/Functional/ManageDisplayTest.php
index 6da294625c9e6e20f7caf0a56e11a2ed369381c7..d0f9b8a51fcc09a97e24fac727e24d5c90ada0e6 100644
--- a/web/core/modules/field_ui/tests/src/Functional/ManageDisplayTest.php
+++ b/web/core/modules/field_ui/tests/src/Functional/ManageDisplayTest.php
@@ -108,7 +108,7 @@ public function testViewModeCustom() {
     // For this test, use a formatter setting value that is an integer unlikely
     // to appear in a rendered node other than as part of the field being tested
     // (for example, unlikely to be part of the "Submitted by ... on ..." line).
-    $value = 12345;
+    $value = '12345';
     $settings = [
       'type' => $this->type,
       'field_test' => [['value' => $value]],
diff --git a/web/core/modules/field_ui/tests/src/FunctionalJavascript/ManageFieldsTest.php b/web/core/modules/field_ui/tests/src/FunctionalJavascript/ManageFieldsTest.php
index a33d124dee84dae81ef062839bad04d8b874d0c6..d5f36e395f1e9026f2b0be807597c1d15d87473a 100644
--- a/web/core/modules/field_ui/tests/src/FunctionalJavascript/ManageFieldsTest.php
+++ b/web/core/modules/field_ui/tests/src/FunctionalJavascript/ManageFieldsTest.php
@@ -15,6 +15,7 @@
  * Tests the Field UI "Manage Fields" screens.
  *
  * @group field_ui
+ * @group #slow
  */
 class ManageFieldsTest extends WebDriverTestBase {
 
diff --git a/web/core/modules/file/file.api.php b/web/core/modules/file/file.api.php
index fa86532f7c4800748c7304ac18ffbe28896cbbdd..04899c5103212183a7bbab149b954a0c5421b273 100644
--- a/web/core/modules/file/file.api.php
+++ b/web/core/modules/file/file.api.php
@@ -15,7 +15,7 @@
  * Using \Drupal\file\Element\ManagedFile field with a defined list of allowed
  * extensions is best way to provide a file upload field. It will ensure that:
  * - File names are sanitized by the FileUploadSanitizeNameEvent event.
- * - Files are validated by hook implementations of hook_file_validate().
+ * - Files are validated by \Drupal\file\Validation\FileValidatorInterface().
  * - Files with insecure extensions will be blocked by default even if they are
  *   listed. If .txt is an allowed extension such files will be renamed.
  *
@@ -27,14 +27,15 @@
  *   '#type' => 'file',
  *   '#title' => $this->t('Upload file'),
  *   '#upload_validators' => [
- *     'file_validate_extensions' => [
- *       'png gif jpg',
+ *     'FileExtension' => [
+ *        'extensions' => 'png gif jpg',
+ *       ],
  *     ],
  *   ],
  * ];
  * @endcode
  * - Use file_save_upload() to trigger the FileUploadSanitizeNameEvent event and
- *   hook_file_validate().
+ *   \Drupal\file\Validation\FileValidatorInterface::validate().
  *
  * Important considerations, regardless of the form element used:
  * - Always use and validate against a list of allowed extensions.
@@ -43,7 +44,7 @@
  *   recommended.
  *
  * @see https://cheatsheetseries.owasp.org/cheatsheets/File_Upload_Cheat_Sheet.html
- * @see \hook_file_validate()
+ * @see \Drupal\file\Validation\FileValidatorInterface
  * @see file_save_upload()
  * @see \Drupal\Core\File\Event\FileUploadSanitizeNameEvent
  * @see \Drupal\system\EventSubscriber\SecurityFileUploadEventSubscriber
@@ -71,7 +72,11 @@
  *   An array of error messages. If there are no problems with the file return
  *   an empty array.
  *
- * @see file_validate()
+ * @deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use the
+ *    'file.validator' service instead.
+ *
+ * @see https://www.drupal.org/node/3363700
+ * @see \Drupal\file\Validation\FileValidatorInterface
  */
 function hook_file_validate(\Drupal\file\FileInterface $file) {
   $errors = [];
diff --git a/web/core/modules/file/file.module b/web/core/modules/file/file.module
index cad33f62415ccf8cf80103a29c15b41ae046eaf3..a6ca00e44dda63c7153530661107f9067228deb6 100644
--- a/web/core/modules/file/file.module
+++ b/web/core/modules/file/file.module
@@ -295,6 +295,8 @@ function file_validate_image_resolution(FileInterface $file, $maximum_dimensions
         if ($image->scale($width, $height)) {
           $scaling = TRUE;
           $image->save();
+          // Update the file size now that the image has been resized.
+          $file->setSize($image->getFileSize());
           if (!empty($width) && !empty($height)) {
             $message = t('The image was resized to fit within the maximum allowed dimensions of %dimensions pixels. The new dimensions of the resized image are %new_widthx%new_height pixels.',
               [
diff --git a/web/core/modules/file/src/Upload/FileUploadHandler.php b/web/core/modules/file/src/Upload/FileUploadHandler.php
index 6ae390fbce42b4fcc1fe8ffaa5ae27dc9c851666..3b4e951846a27f8195526ddf6269aad97e8c1a1a 100644
--- a/web/core/modules/file/src/Upload/FileUploadHandler.php
+++ b/web/core/modules/file/src/Upload/FileUploadHandler.php
@@ -341,31 +341,43 @@ protected function moveUploadedFile(UploadedFileInterface $uploadedFile, string
    *   The space delimited list of allowed file extensions.
    */
   protected function handleExtensionValidation(array &$validators): string {
-    // Build a list of allowed extensions.
-    if (isset($validators['FileExtension'])) {
-      if (!isset($validators['FileExtension']['extensions'])) {
-        // If 'FileExtension' is set and the list is empty then the caller wants
-        // to allow any extension. In this case we have to remove the validator
-        // or else it will reject all extensions.
-        unset($validators['FileExtension']);
+    // Handle legacy extension validation.
+    if (isset($validators['file_validate_extensions'])) {
+      @trigger_error(
+        '\'file_validate_extensions\' is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use the \'FileExtension\' constraint instead. See https://www.drupal.org/node/3363700',
+        E_USER_DEPRECATED
+      );
+      // Empty string means all extensions are allowed so we should remove the
+      // validator.
+      if (\is_string($validators['file_validate_extensions']) && empty($validators['file_validate_extensions'])) {
+        unset($validators['file_validate_extensions']);
+        return '';
       }
+      // The deprecated 'file_validate_extensions' has configuration, so that
+      // should be used.
+      $validators['FileExtension']['extensions'] = $validators['file_validate_extensions'][0];
+      unset($validators['file_validate_extensions']);
+      return $validators['FileExtension']['extensions'];
     }
-    else {
-      if (!empty($validators['file_validate_extensions'][0])) {
-        // The deprecated 'file_validate_extensions' has configuration, so that
-        // should be used.
-        $validators['FileExtension']['extensions'] = $validators['file_validate_extensions'][0];
-        @trigger_error('\'file_validate_extensions\' is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use the \'FileExtension\' constraint instead. See https://www.drupal.org/node/3363700', E_USER_DEPRECATED);
-        return $validators['FileExtension']['extensions'];
-      }
 
-      // No validator was provided, so add one using the default list.
-      // Build a default non-munged safe list for
-      // \Drupal\system\EventSubscriber\SecurityFileUploadEventSubscriber::sanitizeName().
+    // No validator was provided, so add one using the default list.
+    // Build a default non-munged safe list for
+    // \Drupal\system\EventSubscriber\SecurityFileUploadEventSubscriber::sanitizeName().
+    if (!isset($validators['FileExtension'])) {
       $validators['FileExtension'] = ['extensions' => self::DEFAULT_EXTENSIONS];
+      return self::DEFAULT_EXTENSIONS;
+    }
 
+    // Check if we want to allow all extensions.
+    if (!isset($validators['FileExtension']['extensions'])) {
+      // If 'FileExtension' is set and the list is empty then the caller wants
+      // to allow any extension. In this case we have to remove the validator
+      // or else it will reject all extensions.
+      unset($validators['FileExtension']);
+      return '';
     }
-    return $validators['FileExtension']['extensions'] ?? '';
+
+    return $validators['FileExtension']['extensions'];
   }
 
   /**
diff --git a/web/core/modules/file/src/Validation/FileValidator.php b/web/core/modules/file/src/Validation/FileValidator.php
index 44c4781ee74386ddfdf2ebc45e5e9a082f9c6e4b..4e517e531ad88baee5065c6c0992bbc22c7fb801 100644
--- a/web/core/modules/file/src/Validation/FileValidator.php
+++ b/web/core/modules/file/src/Validation/FileValidator.php
@@ -46,6 +46,9 @@ public function validate(FileInterface $file, array $validators): ConstraintViol
     foreach ($validators as $validator => $options) {
       if (function_exists($validator)) {
         @trigger_error('Support for file validation function ' . $validator . '() is deprecated in drupal:10.2.0 and will be removed in drupal:11.0.0. Use Symfony Constraints instead. See https://www.drupal.org/node/3363700', E_USER_DEPRECATED);
+        if (!is_array($options)) {
+          $options = [$options];
+        }
         array_unshift($options, $file);
         // Call the validation function.
         // Options are a list of function args.
diff --git a/web/core/modules/file/tests/file_test/file_test.services.yml b/web/core/modules/file/tests/file_test/file_test.services.yml
index 51b048997a23de7eb625413c5f78827fd5078dc4..e70db1ebd65173b2480a6c076f5ff8880321b423 100644
--- a/web/core/modules/file/tests/file_test/file_test.services.yml
+++ b/web/core/modules/file/tests/file_test/file_test.services.yml
@@ -15,3 +15,8 @@ services:
     class: Drupal\file_test\StreamWrapper\DummyExternalReadOnlyWrapper
     tags:
       - { name: stream_wrapper, scheme: dummy-external-readonly }
+  stream_wrapper.dummy_multiple:
+    class: Drupal\file_test\StreamWrapper\DummyMultipleStreamWrapper
+    tags:
+      - { name: stream_wrapper, scheme: dummy1 }
+      - { name: stream_wrapper, scheme: dummy2 }
diff --git a/web/core/modules/file/tests/file_test/src/StreamWrapper/DummyMultipleStreamWrapper.php b/web/core/modules/file/tests/file_test/src/StreamWrapper/DummyMultipleStreamWrapper.php
new file mode 100644
index 0000000000000000000000000000000000000000..76ac49d97a5fe302e82f27eeacd65bf777134e29
--- /dev/null
+++ b/web/core/modules/file/tests/file_test/src/StreamWrapper/DummyMultipleStreamWrapper.php
@@ -0,0 +1,10 @@
+<?php
+
+namespace Drupal\file_test\StreamWrapper;
+
+/**
+ * Helper class for testing the stream wrapper registry.
+ *
+ * Dummy stream wrapper implementation (dummy1://, dummy2://).
+ */
+class DummyMultipleStreamWrapper extends DummyStreamWrapper {}
diff --git a/web/core/modules/file/tests/src/Functional/FileOnTranslatedEntityTest.php b/web/core/modules/file/tests/src/Functional/FileOnTranslatedEntityTest.php
index 2ef77344f81547297242d85a4e42045c3252c15e..a533a90ec68d3dce69b620f4d32a3a03b78e5f29 100644
--- a/web/core/modules/file/tests/src/Functional/FileOnTranslatedEntityTest.php
+++ b/web/core/modules/file/tests/src/Functional/FileOnTranslatedEntityTest.php
@@ -72,7 +72,7 @@ protected function setUp(): void {
 
     // Enable translation for "Basic page" nodes.
     static::enableContentTranslation('node', 'page');
-    static::setFieldTranslatable('node', 'page', $this->fieldName, 1);
+    static::setFieldTranslatable('node', 'page', $this->fieldName, TRUE);
   }
 
   /**
diff --git a/web/core/modules/file/tests/src/Functional/PrivateFileOnTranslatedEntityTest.php b/web/core/modules/file/tests/src/Functional/PrivateFileOnTranslatedEntityTest.php
index 3a3b1b04fb0aee90c3aa8cf787ae7e9b5ded3c1b..2ebf180392b6376b64e9d5f6e340b3a18e48d01b 100644
--- a/web/core/modules/file/tests/src/Functional/PrivateFileOnTranslatedEntityTest.php
+++ b/web/core/modules/file/tests/src/Functional/PrivateFileOnTranslatedEntityTest.php
@@ -64,7 +64,7 @@ protected function setUp(): void {
 
     // Enable translation for "Basic page" nodes.
     static::enableContentTranslation('node', 'page');
-    static::setFieldTranslatable('node', 'page', $this->fieldName, 1);
+    static::setFieldTranslatable('node', 'page', $this->fieldName, TRUE);
   }
 
   /**
@@ -79,11 +79,15 @@ public function testPrivateLanguageFile() {
     $default_language_node = $this->drupalCreateNode(['type' => 'page']);
 
     // Edit the node to upload a file.
-    $edit = [];
-    $name = 'files[' . $this->fieldName . '_0]';
-    $edit[$name] = \Drupal::service('file_system')->realpath($this->drupalGetTestFiles('text')[0]->uri);
-    $this->drupalGet('node/' . $default_language_node->id() . '/edit');
-    $this->submitForm($edit, 'Save');
+    $file = File::create(
+      [
+        'uri' => $this->drupalGetTestFiles('text')[0]->uri,
+      ]
+    );
+    $file->save();
+
+    $default_language_node->set($this->fieldName, $file->id());
+    $default_language_node->save();
     $last_fid_prior = $this->getLastFileId();
 
     // Languages are cached on many levels, and we need to clear those caches.
@@ -97,18 +101,31 @@ public function testPrivateLanguageFile() {
     $this->assertSession()->statusCodeEquals(200);
 
     // Translate the node into French.
-    $this->drupalGet('node/' . $default_language_node->id() . '/translations');
-    $this->clickLink('Add');
+    $node->addTranslation(
+      'fr', [
+        'title' => $this->randomString(),
+      ]
+    );
+    $node->save();
 
     // Remove the existing file.
-    $this->submitForm([], 'Remove');
+    $existing_file = $node->{$this->fieldName}->entity;
+    if ($existing_file) {
+      $node->set($this->fieldName, NULL);
+      $existing_file->delete();
+      $node->save();
+    }
 
     // Upload a different file.
-    $edit = [];
-    $edit['title[0][value]'] = $this->randomMachineName();
-    $name = 'files[' . $this->fieldName . '_0]';
-    $edit[$name] = \Drupal::service('file_system')->realpath($this->drupalGetTestFiles('text')[1]->uri);
-    $this->submitForm($edit, 'Save (this translation)');
+    $default_language_node = $node->getTranslation('fr');
+    $file = File::create(
+      [
+        'uri' => $this->drupalGetTestFiles('text')[1]->uri,
+      ]
+    );
+    $file->save();
+    $default_language_node->set($this->fieldName, $file->id());
+    $default_language_node->save();
     $last_fid = $this->getLastFileId();
 
     // Verify the translation was created.
diff --git a/web/core/modules/file/tests/src/FunctionalJavascript/FileFieldWidgetClaroThemeTest.php b/web/core/modules/file/tests/src/FunctionalJavascript/FileFieldWidgetClaroThemeTest.php
index f8c6e315d22be832b3222d438f6f611238398b92..8089031020609f8ca086c8064f7f0b280c904ea3 100644
--- a/web/core/modules/file/tests/src/FunctionalJavascript/FileFieldWidgetClaroThemeTest.php
+++ b/web/core/modules/file/tests/src/FunctionalJavascript/FileFieldWidgetClaroThemeTest.php
@@ -15,6 +15,7 @@
  * @see _claro_preprocess_file_and_image_widget()
  *
  * @group file
+ * @group #slow
  */
 class FileFieldWidgetClaroThemeTest extends FileFieldWidgetTest {
 
diff --git a/web/core/modules/file/tests/src/Kernel/FileSaveUploadTest.php b/web/core/modules/file/tests/src/Kernel/FileSaveUploadTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..d512a0f74272fdf6c0d4426b973b6185b1e4f4c5
--- /dev/null
+++ b/web/core/modules/file/tests/src/Kernel/FileSaveUploadTest.php
@@ -0,0 +1,70 @@
+<?php
+
+namespace Drupal\Tests\file\Kernel;
+
+use Drupal\Core\Messenger\MessengerInterface;
+use Drupal\KernelTests\KernelTestBase;
+use Symfony\Component\HttpFoundation\File\UploadedFile;
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\HttpFoundation\RequestStack;
+
+/**
+ * Tests file_save_upload().
+ *
+ * @group file
+ * @group legacy
+ */
+class FileSaveUploadTest extends KernelTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected static $modules = [
+    'file',
+    'file_test',
+    'file_validator_test',
+    'user',
+  ];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected function setUp(): void {
+    \file_put_contents('test.bbb', 'test');
+
+    parent::setUp();
+    $request = new Request();
+    $request->files->set('files', [
+      'file' => new UploadedFile(
+        path: 'test.bbb',
+        originalName: 'test.bbb',
+        mimeType: 'text/plain',
+        error: \UPLOAD_ERR_OK,
+        test: TRUE
+      ),
+    ]);
+
+    $requestStack = new RequestStack();
+    $requestStack->push($request);
+
+    $this->container->set('request_stack', $requestStack);
+  }
+
+  /**
+   * Tests file_save_upload() with empty extensions.
+   */
+  public function testFileSaveUploadEmptyExtensions(): void {
+    // Allow all extensions.
+    $validators = ['file_validate_extensions' => ''];
+    $this->expectDeprecation('\'file_validate_extensions\' is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use the \'FileExtension\' constraint instead. See https://www.drupal.org/node/3363700');
+    $files = file_save_upload('file', $validators);
+    $this->assertCount(1, $files);
+    $file = $files[0];
+    // @todo work out why move_uploaded_file() is failing.
+    $this->assertFalse($file);
+    $messages = \Drupal::messenger()->messagesByType(MessengerInterface::TYPE_ERROR);
+    $this->assertNotEmpty($messages);
+    $this->assertEquals('File upload error. Could not move uploaded file.', $messages[0]);
+  }
+
+}
diff --git a/web/core/modules/file/tests/src/Kernel/LegacyValidatorTest.php b/web/core/modules/file/tests/src/Kernel/LegacyValidatorTest.php
index 150438c41f23a0d150d8fe686cdf24c84db8c232..be2ca42ce3f57c7aea2ed07143f27749a748e80a 100644
--- a/web/core/modules/file/tests/src/Kernel/LegacyValidatorTest.php
+++ b/web/core/modules/file/tests/src/Kernel/LegacyValidatorTest.php
@@ -37,6 +37,7 @@ protected function setUp(): void {
     /** @var \Drupal\Core\File\FileSystemInterface $file_system */
     $file_system = \Drupal::service('file_system');
     $this->image->setFilename($file_system->basename($this->image->getFileUri()));
+    $this->image->setSize(@filesize($this->image->getFileUri()));
 
     $this->nonImage = File::create();
     $this->nonImage->setFileUri('core/assets/vendor/jquery/jquery.min.js');
@@ -191,6 +192,8 @@ public function testFileValidateImageResolution() {
       // Verify that the image was scaled to the correct width and height.
       $this->assertLessThanOrEqual(10, $image->getWidth());
       $this->assertLessThanOrEqual(5, $image->getHeight());
+      // Verify that the file size has been updated after resizing.
+      $this->assertEquals($this->image->getSize(), $image->getFileSize());
 
       // Once again, now with negative width and height to force an error.
       copy('core/misc/druplicon.png', 'temporary://druplicon.png');
diff --git a/web/core/modules/forum/forum.routing.yml b/web/core/modules/forum/forum.routing.yml
index 14e55e261e08fd0ce13754ec08bdb46bed829c1a..798acbb473cf3f0da53fd28897f36a9418c16666 100644
--- a/web/core/modules/forum/forum.routing.yml
+++ b/web/core/modules/forum/forum.routing.yml
@@ -29,6 +29,7 @@ forum.page:
     _title_callback: '\Drupal\taxonomy\Controller\TaxonomyController::termTitle'
   requirements:
     _permission: 'access content'
+    _entity_access: 'taxonomy_term.view'
 
 forum.add_container:
   path: '/admin/structure/forum/add/container'
diff --git a/web/core/modules/forum/src/ForumManager.php b/web/core/modules/forum/src/ForumManager.php
index 3e9a16e9a6cc07478d6f9a1434c42187b4361113..79b91b1db39f0226bc30e741b8b35dc5f08ec38b 100644
--- a/web/core/modules/forum/src/ForumManager.php
+++ b/web/core/modules/forum/src/ForumManager.php
@@ -415,6 +415,9 @@ public function getChildren($vid, $tid) {
     $forums = [];
     $_forums = $this->entityTypeManager->getStorage('taxonomy_term')->loadTree($vid, $tid, NULL, TRUE);
     foreach ($_forums as $forum) {
+      if (!$forum->access('view')) {
+        continue;
+      }
       // Merge in the topic and post counters.
       if (($count = $this->getForumStatistics($forum->id()))) {
         $forum->num_topics = $count->topic_count;
diff --git a/web/core/modules/forum/tests/src/Functional/ForumTermAccessTest.php b/web/core/modules/forum/tests/src/Functional/ForumTermAccessTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..944b37241ce045badc048b09917af5879ce4278d
--- /dev/null
+++ b/web/core/modules/forum/tests/src/Functional/ForumTermAccessTest.php
@@ -0,0 +1,93 @@
+<?php
+
+namespace Drupal\Tests\forum\Functional;
+
+use Drupal\Tests\BrowserTestBase;
+use Drupal\taxonomy\Entity\Term;
+
+/**
+ * Tests forum taxonomy terms for access.
+ *
+ * @group forum
+ */
+class ForumTermAccessTest extends BrowserTestBase {
+
+  /**
+   * Modules to enable.
+   *
+   * @var array
+   */
+  protected static $modules = [
+    'forum',
+    'taxonomy',
+  ];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'stark';
+
+  /**
+   * Creates some users and creates a public forum and an unpublished forum.
+   *
+   * Adds both published and unpublished forums.
+   * Tests to ensure publish/unpublished forums access is respected.
+   */
+  public function testForumTermAccess(): void {
+    $assert_session = $this->assertSession();
+    // Create some users.
+    $public_user = $this->drupalCreateUser(['access content']);
+    $admin_user = $this->drupalCreateUser([
+      'access administration pages',
+      'administer forums',
+      'administer taxonomy',
+      'access taxonomy overview',
+    ]);
+
+    $this->drupalLogin($admin_user);
+    // The vocabulary for forums.
+    $vid = $this->config('forum.settings')->get('vocabulary');
+    // Create an unpublished forum.
+    $unpublished_forum_name = $this->randomMachineName(8);
+    $unpublished_forum = Term::create([
+      'vid' => $vid,
+      'name' => $unpublished_forum_name,
+      'status' => 0,
+    ]);
+    $unpublished_forum->save();
+
+    // Create a new published forum.
+    $published_forum_name = $this->randomMachineName(8);
+    $published_forum = Term::create([
+      'vid' => $vid,
+      'name' => $published_forum_name,
+      'status' => 1,
+    ]);
+    $published_forum->save();
+
+    // Test for admin user.
+    // Go to the Forum index page.
+    $this->drupalGet('forum');
+    // The unpublished forum should be in this page for an admin user.
+    $assert_session->pageTextContains($unpublished_forum_name);
+    // Go to the unpublished forum page.
+    $this->drupalGet('forum/' . $unpublished_forum->id());
+    $assert_session->statusCodeEquals(200);
+    $assert_session->pageTextContains($unpublished_forum_name);
+
+    // Test for public user.
+    $this->drupalLogin($public_user);
+    // Go to the Forum index page.
+    $this->drupalGet('forum');
+    // The published forum should be in this page.
+    $assert_session->pageTextContains($published_forum_name);
+    // The unpublished forum should not be in this page.
+    $assert_session->pageTextNotContains($unpublished_forum_name);
+    // Go to the unpublished forum page.
+    $this->drupalGet('forum/' . $unpublished_forum->id());
+    // Public should not be able to access the unpublished forum.
+    $assert_session->statusCodeEquals(403);
+    $assert_session->pageTextNotContains($unpublished_forum_name);
+  }
+
+}
diff --git a/web/core/modules/image/image.admin.inc b/web/core/modules/image/image.admin.inc
index 9921e7b94b30e4c8f47a534e46f52e4cbff9b94e..b2ea67a00b08eccc5048c6a3ca3df63ebcf06c5d 100644
--- a/web/core/modules/image/image.admin.inc
+++ b/web/core/modules/image/image.admin.inc
@@ -58,6 +58,11 @@ function template_preprocess_image_style_preview(&$variables) {
     $style->createDerivative($original_path, $preview_file);
   }
   $preview_image = $image_factory->get($preview_file);
+
+  // Generate an itok.
+  $defaultScheme = \Drupal::config('system.file')->get('default_scheme');
+  $variables['itok'] = $style->getPathToken($defaultScheme . '://' . $original_path);
+
   $variables['derivative'] = [
     'url' => $file_url_generator->generateString($preview_file),
     'width' => $preview_image->getWidth(),
@@ -89,7 +94,7 @@ function template_preprocess_image_style_preview(&$variables) {
   // to prevent caching of images on the client side.
   $variables['derivative']['rendered'] = [
     '#theme' => 'image',
-    '#uri' => $variables['derivative']['url'] . '?cache_bypass=' . $variables['cache_bypass'],
+    '#uri' => $variables['derivative']['url'] . '?cache_bypass=' . $variables['cache_bypass'] . '&itok=' . $variables['itok'],
     '#alt' => t('Sample modified image'),
     '#title' => '',
     '#attributes' => [
diff --git a/web/core/modules/image/image.module b/web/core/modules/image/image.module
index ccd4c3e2c4011887ca23a03d5e864a27e8778a89..4203045b5952b4b02e8a3c9aa79e935f3a791acb 100644
--- a/web/core/modules/image/image.module
+++ b/web/core/modules/image/image.module
@@ -167,6 +167,20 @@ function image_file_download($uri) {
     }
     return -1;
   }
+
+  // If it is the sample image we need to grant access.
+  $samplePath = \Drupal::config('image.settings')->get('preview_image');
+  if ($path === $samplePath) {
+    $image = \Drupal::service('image.factory')->get($samplePath);
+    return [
+      // Send headers describing the image's size, and MIME-type.
+      'Content-Type' => $image->getMimeType(),
+      'Content-Length' => $image->getFileSize(),
+      // By not explicitly setting them here, this uses normal Drupal
+      // Expires, Cache-Control and ETag headers to prevent proxy or
+      // browser caching of private images.
+    ];
+  }
 }
 
 /**
diff --git a/web/core/modules/image/src/Controller/ImageStyleDownloadController.php b/web/core/modules/image/src/Controller/ImageStyleDownloadController.php
index 1df6ef1d42ff27c72cfccbf1e25826340d8e2e30..47b5681f1a9657cf086a859f4f90ef151026c9c7 100644
--- a/web/core/modules/image/src/Controller/ImageStyleDownloadController.php
+++ b/web/core/modules/image/src/Controller/ImageStyleDownloadController.php
@@ -110,6 +110,7 @@ public function deliver(Request $request, $scheme, ImageStyleInterface $image_st
     $target = $request->query->get('file');
     $image_uri = $scheme . '://' . $target;
     $image_uri = $this->streamWrapperManager->normalizeUri($image_uri);
+    $sample_image_uri = $scheme . '://' . $this->config('image.settings')->get('preview_image');
 
     if ($this->streamWrapperManager->isValidScheme($scheme)) {
       $normalized_target = $this->streamWrapperManager->getTarget($image_uri);
@@ -175,6 +176,11 @@ public function deliver(Request $request, $scheme, ImageStyleInterface $image_st
       }
     }
 
+    // If it is default sample.png, ignore scheme.
+    if ($image_uri === $sample_image_uri) {
+      $image_uri = $target;
+    }
+
     // Don't try to generate file if source is missing.
     if (!$this->sourceImageExists($image_uri, $token_is_valid)) {
       // If the image style converted the extension, it has been added to the
diff --git a/web/core/modules/image/tests/src/Functional/ImageAdminStylesTest.php b/web/core/modules/image/tests/src/Functional/ImageAdminStylesTest.php
index b603c95021771ba95f43a19c9adfa329d3425f84..b0de9171e35a70d3c4cbda7d1c56f084ae9b1edd 100644
--- a/web/core/modules/image/tests/src/Functional/ImageAdminStylesTest.php
+++ b/web/core/modules/image/tests/src/Functional/ImageAdminStylesTest.php
@@ -518,4 +518,38 @@ public function testImageStyleAccess() {
     $this->assertSession()->pageTextContains("Select a new effect");
   }
 
+  /**
+   * Tests the display of preview images using a private scheme.
+   */
+  public function testPreviewImageShowInPrivateScheme(): void {
+    $this->config('system.file')->set('default_scheme', 'private')->save();
+
+    /** @var \Drupal\Core\File\FileUrlGeneratorInterface $file_url_generator */
+    $file_url_generator = \Drupal::service('file_url_generator');
+
+    // Get the original preview image file in core config.
+    $original_path = $this->config('image.settings')->get('preview_image');
+    $style = ImageStyle::create(['name' => 'test_foo', 'label' => 'test foo']);
+    $style->save();
+
+    // Build the derivative preview image file with the Image Style.
+    // @see template_preprocess_image_style_preview()
+    $preview_file = $style->buildUri($original_path);
+    $style->createDerivative($original_path, $preview_file);
+
+    // Check if the derivative image exists.
+    $this->assertFileExists($preview_file);
+
+    // Generate itok token for the preview image.
+    $itok = $style->getPathToken('private://' . $original_path);
+
+    $url = $file_url_generator->generateAbsoluteString($preview_file);
+    $url .= '?itok=' . $itok;
+
+    // Check if the preview image with style is shown.
+    $this->drupalGet($url);
+    $this->assertSession()->statusCodeEquals(200);
+    $this->assertSession()->responseHeaderContains('Content-Type', 'image/png');
+  }
+
 }
diff --git a/web/core/modules/image/tests/src/Functional/ImageDimensionsTest.php b/web/core/modules/image/tests/src/Functional/ImageDimensionsTest.php
index 83f5dc39db489fa3eb8064ecaa0533658648a338..fcfa3b8d7b7a80735dec621215eb05098832a021 100644
--- a/web/core/modules/image/tests/src/Functional/ImageDimensionsTest.php
+++ b/web/core/modules/image/tests/src/Functional/ImageDimensionsTest.php
@@ -304,7 +304,7 @@ public function testImageDimensions() {
    * altered and the element is re-rendered each time.
    */
   protected function getImageTag($variables) {
-    return str_replace("\n", '', \Drupal::service('renderer')->renderRoot($variables));
+    return str_replace("\n", '', (string) \Drupal::service('renderer')->renderRoot($variables));
   }
 
 }
diff --git a/web/core/modules/image/tests/src/Functional/ImageFieldDisplayTest.php b/web/core/modules/image/tests/src/Functional/ImageFieldDisplayTest.php
index 8cef396210f5dc5e9866cf37a5b72ce647bb0fa3..14ccf54cc92d8424243cd825692b8a1027b6a7ad 100644
--- a/web/core/modules/image/tests/src/Functional/ImageFieldDisplayTest.php
+++ b/web/core/modules/image/tests/src/Functional/ImageFieldDisplayTest.php
@@ -116,7 +116,7 @@ public function _testImageFieldFormatters($scheme) {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->assertSession()->responseContains($default_output);
 
     // Test the image linked to file formatter.
@@ -137,7 +137,7 @@ public function _testImageFieldFormatters($scheme) {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = '<a href="' . $file->createFileUrl() . '">' . $renderer->renderRoot($image) . '</a>';
+    $default_output = '<a href="' . $file->createFileUrl() . '">' . (string) $renderer->renderRoot($image) . '</a>';
     $this->drupalGet('node/' . $nid);
     $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', $file->getCacheTags()[0]);
     // @todo Remove in https://www.drupal.org/node/2646744.
@@ -196,7 +196,7 @@ public function _testImageFieldFormatters($scheme) {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = $renderer->renderRoot($image_style);
+    $default_output = (string) $renderer->renderRoot($image_style);
     $this->drupalGet('node/' . $nid);
     $image_style = ImageStyle::load('thumbnail');
     $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', $image_style->getCacheTags()[0]);
@@ -313,7 +313,7 @@ public function testImageFieldSettings() {
     ];
     $this->drupalGet('node/' . $nid . '/edit');
     $this->submitForm($edit, 'Save');
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->assertSession()->responseContains($default_output);
 
     // Verify that alt/title longer than allowed results in a validation error.
@@ -421,7 +421,7 @@ public function testImageLoadingAttribute(): void {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->assertSession()->responseContains($default_output);
 
     // Test overrides of image loading attribute.
@@ -446,7 +446,7 @@ public function testImageLoadingAttribute(): void {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'eager'],
     ];
-    $default_output = $renderer->renderRoot($image);
+    $default_output = (string) $renderer->renderRoot($image);
     $this->drupalGet('node/' . $nid);
     $this->assertSession()->responseContains($default_output);
 
@@ -467,7 +467,7 @@ public function testImageLoadingAttribute(): void {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'eager'],
     ];
-    $default_output = $renderer->renderRoot($image_style);
+    $default_output = (string) $renderer->renderRoot($image_style);
     $this->drupalGet('node/' . $nid);
     $this->assertSession()->responseContains($default_output);
   }
@@ -521,7 +521,7 @@ public function testImageFieldDefaultImage() {
       '#height' => 20,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->drupalGet('node/' . $node->id());
     $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', $file->getCacheTags()[0]);
     // Verify that no image style cache tags are found.
@@ -547,7 +547,7 @@ public function testImageFieldDefaultImage() {
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $image_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $image_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->drupalGet('node/' . $nid);
     $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', $file->getCacheTags()[0]);
     // Verify that no image style cache tags are found.
@@ -602,7 +602,7 @@ public function testImageFieldDefaultImage() {
       '#height' => 20,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->drupalGet('node/' . $node->id());
     $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', $file->getCacheTags()[0]);
     // Verify that no image style cache tags are found.
diff --git a/web/core/modules/jsonapi/tests/src/Functional/BlockContentTest.php b/web/core/modules/jsonapi/tests/src/Functional/BlockContentTest.php
index dd964304d5ccbcbf6e8e9e3e0f150a1a8904fc1e..901bf7e1055a03ac7b214532f79095b25eb9f160 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/BlockContentTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/BlockContentTest.php
@@ -162,7 +162,7 @@ protected function getExpectedDocument() {
           ],
           'changed' => (new \DateTime())->setTimestamp($this->entity->getChangedTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'info' => 'Llama',
-          'revision_created' => (new \DateTime())->setTimestamp($this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'revision_created' => (new \DateTime())->setTimestamp((int) $this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'revision_translation_affected' => TRUE,
           'status' => FALSE,
           'langcode' => 'en',
diff --git a/web/core/modules/jsonapi/tests/src/Functional/EntityTestComputedFieldTest.php b/web/core/modules/jsonapi/tests/src/Functional/EntityTestComputedFieldTest.php
index 0f22c1187dd40126b0a5ac7c4516c80f73c73122..16904c9e415dd16fbcd24f29cc854dad90f61cae 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/EntityTestComputedFieldTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/EntityTestComputedFieldTest.php
@@ -108,11 +108,12 @@ protected function getExpectedDocument() {
           'self' => ['href' => $self_url],
         ],
         'attributes' => [
-          'created' => (new \DateTime())->setTimestamp($this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'created' => (new \DateTime())->setTimestamp((int) $this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'name' => 'Llama',
           'drupal_internal__id' => 1,
           'computed_string_field' => NULL,
           'computed_test_cacheable_string_field' => 'computed test cacheable string field',
+          'computed_test_cacheable_integer_field' => 0,
         ],
         'relationships' => [
           'computed_reference_field' => [
diff --git a/web/core/modules/jsonapi/tests/src/Functional/EntityTestMapFieldTest.php b/web/core/modules/jsonapi/tests/src/Functional/EntityTestMapFieldTest.php
index 1bb12240520dbc83f89ed414ed6e08592aa57876..5a1d7ab70c8790ef7fce383af417657651a1aeb7 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/EntityTestMapFieldTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/EntityTestMapFieldTest.php
@@ -109,7 +109,7 @@ protected function getExpectedDocument() {
           'self' => ['href' => $self_url],
         ],
         'attributes' => [
-          'created' => (new \DateTime())->setTimestamp($this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'created' => (new \DateTime())->setTimestamp((int) $this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'langcode' => 'en',
           'name' => 'Llama',
           'data' => static::$mapValue,
diff --git a/web/core/modules/jsonapi/tests/src/Functional/EntityTestTest.php b/web/core/modules/jsonapi/tests/src/Functional/EntityTestTest.php
index 6e59823b7aa9639bef7921530e5c02fbc57232a8..8f224a407871a6e5aea868f7910b9e9fc094d686 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/EntityTestTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/EntityTestTest.php
@@ -120,7 +120,7 @@ protected function getExpectedDocument() {
           'self' => ['href' => $self_url],
         ],
         'attributes' => [
-          'created' => (new \DateTime())->setTimestamp($this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'created' => (new \DateTime())->setTimestamp((int) $this->entity->get('created')->value)->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'field_test_text' => NULL,
           'langcode' => 'en',
           'name' => 'Llama',
diff --git a/web/core/modules/jsonapi/tests/src/Functional/JsonApiFunctionalDateFieldTest.php b/web/core/modules/jsonapi/tests/src/Functional/JsonApiFunctionalDateFieldTest.php
index 21b2a7b9a39b6a526050ff94731388a589086660..b38fa6c64f9e463d99422f909a50d23e23a5bc2a 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/JsonApiFunctionalDateFieldTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/JsonApiFunctionalDateFieldTest.php
@@ -57,9 +57,9 @@ public function testRead() {
     /** @var \Drupal\Core\Datetime\DateFormatterInterface $date_formatter */
     $date_formatter = $this->container->get('date.formatter');
 
-    $timestamp_1 = '5000000';
-    $timestamp_2 = '6000000';
-    $timestamp_3 = '7000000';
+    $timestamp_1 = 5000000;
+    $timestamp_2 = 6000000;
+    $timestamp_3 = 7000000;
     // Expected: node 1.
     $timestamp_smaller_than_value = $timestamp_2;
     // Expected: node 1 and node 2.
diff --git a/web/core/modules/jsonapi/tests/src/Functional/MediaTest.php b/web/core/modules/jsonapi/tests/src/Functional/MediaTest.php
index 84ad99b7da93e0313b7cabe33875345fc28cbd4f..8bd69aff1363a5f7670b2318dc0065ed4f2566ec 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/MediaTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/MediaTest.php
@@ -184,7 +184,7 @@ protected function getExpectedDocument() {
           'status' => TRUE,
           'created' => '1973-11-29T21:33:09+00:00',
           'changed' => (new \DateTime())->setTimestamp($this->entity->getChangedTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
-          'revision_created' => (new \DateTime())->setTimestamp($this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'revision_created' => (new \DateTime())->setTimestamp((int) $this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'default_langcode' => TRUE,
           'revision_log_message' => NULL,
           // @todo Attempt to remove this in https://www.drupal.org/project/drupal/issues/2933518.
diff --git a/web/core/modules/jsonapi/tests/src/Functional/MenuLinkContentTest.php b/web/core/modules/jsonapi/tests/src/Functional/MenuLinkContentTest.php
index efc47df28b41790f99c33598c9dda98cfe70d16c..36b90c8f94b1c8c9ad698adafbed805ce02681be 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/MenuLinkContentTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/MenuLinkContentTest.php
@@ -130,7 +130,7 @@ protected function getExpectedDocument() {
           'weight' => 0,
           'drupal_internal__id' => 1,
           'drupal_internal__revision_id' => 1,
-          'revision_created' => (new \DateTime())->setTimestamp($this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'revision_created' => (new \DateTime())->setTimestamp((int) $this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           'revision_log_message' => NULL,
           // @todo Attempt to remove this in https://www.drupal.org/project/drupal/issues/2933518.
           'revision_translation_affected' => TRUE,
diff --git a/web/core/modules/jsonapi/tests/src/Functional/ResourceTestBase.php b/web/core/modules/jsonapi/tests/src/Functional/ResourceTestBase.php
index 35283b83f926ea9fea19c34036ebf1bfb9996fe2..cebb6f2c731fd63cee9e5ae9209c983bbd8584dd 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/ResourceTestBase.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/ResourceTestBase.php
@@ -2741,7 +2741,7 @@ protected function doTestIncluded(Url $url, array $request_options) {
       'all' => $relationship_field_names,
     ];
     if (count($relationship_field_names) > 1) {
-      $about_half_the_fields = floor(count($relationship_field_names) / 2);
+      $about_half_the_fields = (int) floor(count($relationship_field_names) / 2);
       $field_sets['some'] = array_slice($relationship_field_names, $about_half_the_fields);
 
       $nested_includes = $this->getNestedIncludePaths();
@@ -3334,7 +3334,7 @@ protected function getSparseFieldSets() {
     $field_names = array_keys($this->entity->toArray());
     $field_sets = [
       'empty' => [],
-      'some' => array_slice($field_names, floor(count($field_names) / 2)),
+      'some' => array_slice($field_names, (int) floor(count($field_names) / 2)),
       'all' => $field_names,
     ];
     if ($this->entity instanceof EntityOwnerInterface) {
diff --git a/web/core/modules/jsonapi/tests/src/Functional/TermTest.php b/web/core/modules/jsonapi/tests/src/Functional/TermTest.php
index 31a1c71ad067064517415436bb90f79aa0e8202c..98a0bce520d1841d41217a9268ca7f5e132462c8 100644
--- a/web/core/modules/jsonapi/tests/src/Functional/TermTest.php
+++ b/web/core/modules/jsonapi/tests/src/Functional/TermTest.php
@@ -280,7 +280,7 @@ protected function getExpectedDocument() {
           'drupal_internal__tid' => 1,
           'status' => TRUE,
           'drupal_internal__revision_id' => 1,
-          'revision_created' => (new \DateTime())->setTimestamp($this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
+          'revision_created' => (new \DateTime())->setTimestamp((int) $this->entity->getRevisionCreationTime())->setTimezone(new \DateTimeZone('UTC'))->format(\DateTime::RFC3339),
           // @todo Attempt to remove this in https://www.drupal.org/project/drupal/issues/2933518.
           'revision_translation_affected' => TRUE,
         ],
diff --git a/web/core/modules/language/language.module b/web/core/modules/language/language.module
index 4ac86e6802415c6d482d7559f16f94a1f733b39e..88dae43c63ed02e3e4b08ac9fa90dd6fe1917836 100644
--- a/web/core/modules/language/language.module
+++ b/web/core/modules/language/language.module
@@ -7,12 +7,15 @@
 
 use Drupal\Core\Url;
 use Drupal\Core\Access\AccessResult;
+use Drupal\Core\Config\FileStorage;
+use Drupal\Core\Config\InstallStorage;
 use Drupal\Core\Entity\ContentEntityFormInterface;
 use Drupal\Core\Entity\EntityFormInterface;
 use Drupal\Core\Entity\EntityInterface;
 use Drupal\Core\Field\FieldDefinitionInterface;
 use Drupal\Core\Field\FieldItemListInterface;
 use Drupal\Core\Form\FormStateInterface;
+use Drupal\Core\Installer\InstallerKernel;
 use Drupal\Core\Language\LanguageInterface;
 use Drupal\Core\Routing\RouteMatchInterface;
 use Drupal\Core\Session\AccountInterface;
@@ -289,8 +292,26 @@ function language_negotiation_url_prefixes_update() {
 /**
  * Implements hook_modules_installed().
  */
-function language_modules_installed($modules) {
+function language_modules_installed($modules, $is_syncing) {
+  if ($is_syncing) {
+    return;
+  }
+
   if (!in_array('language', $modules)) {
+    if (InstallerKernel::installationAttempted()) {
+      // If the install profile provides its own language.types configuration do
+      // not overwrite it.
+      $profile_directory = \Drupal::service('extension.list.profile')->getPath(\Drupal::installProfile());
+      $profile_storages = [
+        new FileStorage($profile_directory . '/' . InstallStorage::CONFIG_INSTALL_DIRECTORY),
+        new FileStorage($profile_directory . '/' . InstallStorage::CONFIG_OPTIONAL_DIRECTORY),
+      ];
+      foreach ($profile_storages as $storage) {
+        if ($storage->exists('language.types')) {
+          return;
+        }
+      }
+    }
     // Since newly (un)installed modules may change the default settings for
     // non-locked language types (e.g. content language), we need to resave the
     // language type configuration.
@@ -318,8 +339,8 @@ function language_modules_installed($modules) {
 /**
  * Implements hook_modules_uninstalled().
  */
-function language_modules_uninstalled($modules) {
-  language_modules_installed($modules);
+function language_modules_uninstalled($modules, $is_syncing) {
+  language_modules_installed($modules, $is_syncing);
 }
 
 /**
diff --git a/web/core/modules/language/tests/src/Functional/LanguageConfigInstallOverrideExistingTest.php b/web/core/modules/language/tests/src/Functional/LanguageConfigInstallOverrideExistingTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..74a8bd9352c72352fdfe4237d0ea8daaf178eb60
--- /dev/null
+++ b/web/core/modules/language/tests/src/Functional/LanguageConfigInstallOverrideExistingTest.php
@@ -0,0 +1,42 @@
+<?php
+
+namespace Drupal\Tests\language\Functional;
+
+use Drupal\Tests\BrowserTestBase;
+
+/**
+ * Ensures the language config is installed but not altered on install.
+ *
+ * @group language
+ */
+class LanguageConfigInstallOverrideExistingTest extends BrowserTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $profile = 'test_language_negotiation';
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'stark';
+
+  /**
+   * Tests when language config is installed existing config is not overridden.
+   */
+  public function testLanguageConfigInstallOverrideExisting() {
+    /** @var \Drupal\Core\Config\StorageInterface $storage */
+    $storage = $this->container->get('config.storage');
+    $config = $this->config('language.types');
+
+    // The negotiation methods that have been removed should be disabled after
+    // purging if not avoided in language_modules_installed().
+    $language_types_data = $storage->read('language.types');
+    $this->assertTrue(isset($language_types_data['negotiation']['language_content']['enabled']['test_language_negotiation_method']));
+    $this->assertTrue(isset($language_types_data['negotiation']['language_content']['enabled']['language-selected']));
+
+    $this->assertEquals(-10, $config->get('negotiation.language_content.enabled.test_language_negotiation_method'));
+    $this->assertEquals(12, $config->get('negotiation.language_content.enabled.language-selected'));
+  }
+
+}
diff --git a/web/core/modules/language/tests/src/Unit/ContentLanguageSettingsUnitTest.php b/web/core/modules/language/tests/src/Unit/ContentLanguageSettingsUnitTest.php
index 960730908f18fc0ceeccd11bbd31d5b85b5aebed..e3964762d7d34a5f15fefb321ce20256b8eec933 100644
--- a/web/core/modules/language/tests/src/Unit/ContentLanguageSettingsUnitTest.php
+++ b/web/core/modules/language/tests/src/Unit/ContentLanguageSettingsUnitTest.php
@@ -267,7 +267,7 @@ public function testLoadByEntityTypeBundle($config_id, ContentLanguageSettings $
       ->with('language_content_settings')
       ->willReturn($this->configEntityStorageInterface);
 
-    $entity_type_repository = $this->getMockForAbstractClass(EntityTypeRepositoryInterface::class);
+    $entity_type_repository = $this->createMock(EntityTypeRepositoryInterface::class);
     $entity_type_repository->expects($this->any())
       ->method('getEntityTypeFromClass')
       ->with(ContentLanguageSettings::class)
diff --git a/web/core/modules/language/tests/src/Unit/Plugin/LanguageNegotiation/LanguageNegotiationContentEntityTest.php b/web/core/modules/language/tests/src/Unit/Plugin/LanguageNegotiation/LanguageNegotiationContentEntityTest.php
index 324d748828a6c99395414e69d3a7c7860e5dc683..fac7885f7bf1470d8114873fac7be67a89237629 100644
--- a/web/core/modules/language/tests/src/Unit/Plugin/LanguageNegotiation/LanguageNegotiationContentEntityTest.php
+++ b/web/core/modules/language/tests/src/Unit/Plugin/LanguageNegotiation/LanguageNegotiationContentEntityTest.php
@@ -12,7 +12,7 @@
 use Drupal\Core\Url;
 use Drupal\language\ConfigurableLanguageManagerInterface;
 use Drupal\language\Plugin\LanguageNegotiation\LanguageNegotiationContentEntity;
-use Symfony\Component\HttpFoundation\ParameterBag;
+use Symfony\Component\HttpFoundation\InputBag;
 use Symfony\Component\HttpFoundation\Request;
 use Symfony\Component\HttpFoundation\ServerBag;
 use Symfony\Component\Routing\Route;
@@ -106,7 +106,7 @@ public function testGetLangcode() {
     // Case 2: A request is available, but the languageManager is not set and
     // the static::QUERY_PARAMETER is not provided as a named parameter.
     $request = Request::create('/de/foo', 'GET');
-    $request->query = new ParameterBag();
+    $request->query = new InputBag();
     $this->assertEquals(NULL, $languageNegotiationContentEntity->getLangcode($request));
 
     // Case 3: A request is available, the languageManager is set, but the
diff --git a/web/core/modules/layout_builder/src/Plugin/Block/FieldBlock.php b/web/core/modules/layout_builder/src/Plugin/Block/FieldBlock.php
index 578f9348eb72c8d4e2b1f5b954f75e8e552732a3..1d4c5acae12a3a34e7df68ba2cc1f0dfd8d41f6e 100644
--- a/web/core/modules/layout_builder/src/Plugin/Block/FieldBlock.php
+++ b/web/core/modules/layout_builder/src/Plugin/Block/FieldBlock.php
@@ -22,6 +22,7 @@
 use Drupal\Core\Plugin\ContextAwarePluginInterface;
 use Drupal\Core\Session\AccountInterface;
 use Drupal\Core\StringTranslation\TranslatableMarkup;
+use Drupal\field\FieldConfigInterface;
 use Drupal\layout_builder\Plugin\Derivative\FieldBlockDeriver;
 use Psr\Log\LoggerInterface;
 use Symfony\Component\DependencyInjection\ContainerInterface;
@@ -212,13 +213,7 @@ protected function blockAccess(AccountInterface $account) {
     }
 
     // Check to see if the field has any values or a default value.
-    if ($field->isEmpty() && !$field->getFieldDefinition()->getDefaultValue($entity)) {
-      // @todo Remove special handling of image fields after
-      //   https://www.drupal.org/project/drupal/issues/3005528.
-      if ($field->getFieldDefinition()->getType() === 'image' && $field->getFieldDefinition()->getSetting('default_image')) {
-        return $access;
-      }
-
+    if ($field->isEmpty() && !$this->entityFieldHasDefaultValue()) {
       return $access->andIf(AccessResult::forbidden());
     }
     return $access;
@@ -414,4 +409,33 @@ protected function getFormatter(array $parents, FormStateInterface $form_state)
     ]);
   }
 
+  /**
+   * Checks whether there is a default value set on the field.
+   *
+   * @return bool
+   *   TRUE if default value set, FALSE otherwise.
+   */
+  protected function entityFieldHasDefaultValue(): bool {
+    $entity = $this->getEntity();
+    $field = $entity->get($this->fieldName);
+    $definition = $field->getFieldDefinition();
+    if ($definition->getDefaultValue($entity)) {
+      return TRUE;
+    }
+
+    // @todo Remove special handling of image fields after
+    // https://www.drupal.org/project/drupal/issues/3005528.
+    if ($definition->getType() !== 'image') {
+      return FALSE;
+    }
+
+    $default_image = $definition->getSetting('default_image');
+    // If we are dealing with a configurable field, look in both instance-level
+    // and field-level settings.
+    if (empty($default_image['uuid']) && ($definition instanceof FieldConfigInterface)) {
+      $default_image = $definition->getFieldStorageDefinition()->getSetting('default_image');
+    }
+    return !empty($default_image['uuid']);
+  }
+
 }
diff --git a/web/core/modules/layout_builder/src/Plugin/Layout/MultiWidthLayoutBase.php b/web/core/modules/layout_builder/src/Plugin/Layout/MultiWidthLayoutBase.php
index 1693a6de143557c6c788a63cf5f1302280ed7082..2a5d43a84980b594c1f33b45cb6f2e91937e2b46 100644
--- a/web/core/modules/layout_builder/src/Plugin/Layout/MultiWidthLayoutBase.php
+++ b/web/core/modules/layout_builder/src/Plugin/Layout/MultiWidthLayoutBase.php
@@ -8,9 +8,6 @@
 
 /**
  * Base class of layouts with configurable widths.
- *
- * @internal
- *   Plugin classes are internal.
  */
 abstract class MultiWidthLayoutBase extends LayoutDefault implements PluginFormInterface {
 
diff --git a/web/core/modules/layout_builder/tests/src/Functional/LayoutBuilderDefaultValuesTest.php b/web/core/modules/layout_builder/tests/src/Functional/LayoutBuilderDefaultValuesTest.php
index d65fb822179cd40bb5c51144c338391fd7a9ab0e..8e8f40d903b49e82cb316ba225911102dedf34d1 100644
--- a/web/core/modules/layout_builder/tests/src/Functional/LayoutBuilderDefaultValuesTest.php
+++ b/web/core/modules/layout_builder/tests/src/Functional/LayoutBuilderDefaultValuesTest.php
@@ -13,6 +13,8 @@
 use Drupal\Tests\image\Kernel\ImageFieldCreationTrait;
 use Drupal\Tests\TestFileCreationTrait;
 
+// cspell:ignore blocknodetest typefield
+
 /**
  * Tests rendering default field values in Layout Builder.
  *
@@ -62,14 +64,22 @@ protected function setUp(): void {
       'field_string_with_default' => 'It is ok to be different',
       'field_string_with_callback' => 'Not from a callback',
       'field_string_late_default' => 'I am way ahead of you.',
-      'field_image_with_default' => [
-        'target_id' => 2,
-        'alt' => 'My different alt text',
-      ],
-      'field_image_no_default' => [
+      'field_image_storage_default' => [
         'target_id' => 3,
         'alt' => 'My third alt text',
       ],
+      'field_image_instance_default' => [
+        'target_id' => 4,
+        'alt' => 'My fourth alt text',
+      ],
+      'field_image_both_defaults' => [
+        'target_id' => 5,
+        'alt' => 'My fifth alt text',
+      ],
+      'field_image_no_default' => [
+        'target_id' => 6,
+        'alt' => 'My sixth alt text',
+      ],
     ]);
 
     // Create node 2 relying on defaults.
@@ -123,22 +133,46 @@ protected function assertNodeWithValues() {
     $assert_session->pageTextContains('field_string_late_default');
     $assert_session->pageTextNotContains('Too late!');
     $assert_session->pageTextContains('I am way ahead of you');
-    // Image field with default should render non-default value.
-    $assert_session->pageTextContains('field_image_with_default');
-    $assert_session->responseNotContains('My default alt text');
+    // Image field with storage default should render non-default value.
+    $assert_session->pageTextContains('field_image_storage_default');
+    $assert_session->responseNotContains('My storage default alt text');
     $assert_session->responseNotContains('test-file-1');
-    $assert_session->responseContains('My different alt text');
-    $assert_session->responseContains('test-file-2');
-    // Image field with no default should render a value.
-    $assert_session->pageTextContains('field_image_no_default');
     $assert_session->responseContains('My third alt text');
     $assert_session->responseContains('test-file-3');
+    // Image field with instance default should render non-default value.
+    $assert_session->pageTextContains('field_image_instance_default');
+    $assert_session->responseNotContains('My instance default alt text');
+    $assert_session->responseNotContains('test-file-1');
+    $assert_session->responseContains('My fourth alt text');
+    $assert_session->responseContains('test-file-4');
+    // Image field with both storage and instance defaults should render
+    // non-default value.
+    $assert_session->pageTextContains('field_image_both_defaults');
+    $assert_session->responseNotContains('My storage default alt text');
+    $assert_session->responseNotContains('My instance default alt text');
+    $assert_session->responseNotContains('test-file-1');
+    $assert_session->responseNotContains('test-file-2');
+    $assert_session->responseContains('My fifth alt text');
+    $assert_session->responseContains('test-file-5');
+    // Image field with no default should render a value.
+    $assert_session->pageTextContains('field_image_no_default');
+    $assert_session->responseContains('My sixth alt text');
+    $assert_session->responseContains('test-file-6');
   }
 
   /**
    * Test for expected text on node 2.
    */
   protected function assertNodeWithDefaultValues() {
+    // Switch theme to starterkit_theme so that layout builder components will
+    // have block classes.
+    /** @var \Drupal\Core\Extension\ThemeInstallerInterface $theme_installer */
+    $theme_installer = $this->container->get('theme_installer');
+    $theme_installer->install(['starterkit_theme']);
+    $this->config('system.theme')
+      ->set('default', 'starterkit_theme')
+      ->save();
+
     $this->drupalGet('node/2');
     $assert_session = $this->assertSession();
     // String field with no default should not render.
@@ -153,11 +187,20 @@ protected function assertNodeWithDefaultValues() {
     $assert_session->pageTextNotContains('field_string_late_default');
     $assert_session->pageTextNotContains('Too late!');
     // Image field with default should render default value.
-    $assert_session->pageTextContains('field_image_with_default');
-    $assert_session->responseContains('My default alt text');
+    $assert_session->pageTextContains('field_image_storage_default');
+    $assert_session->responseContains('My storage default alt text');
+    $assert_session->responseContains('test-file-1');
+    $assert_session->pageTextContains('field_image_instance_default');
+    $assert_session->responseContains('My instance default alt text');
     $assert_session->responseContains('test-file-1');
+    $assert_session->pageTextContains('field_image_both_defaults');
+    $assert_session->responseContains('My instance default alt text');
+    $assert_session->responseContains('test-file-2');
     // Image field with no default should not render.
     $assert_session->pageTextNotContains('field_image_no_default');
+    // Confirm that there is no DOM element for the field_image_with_no_default
+    // field block.
+    $assert_session->elementNotExists('css', '.block-field-blocknodetest-node-typefield-image-no-default');
   }
 
   /**
@@ -243,7 +286,7 @@ protected function addImageFields() {
     // Create files to use as the default images.
     $files = $this->drupalGetTestFiles('image');
     $images = [];
-    for ($i = 1; $i <= 3; $i++) {
+    for ($i = 1; $i <= 6; $i++) {
       $filename = "test-file-$i";
       $desired_filepath = 'public://' . $filename;
       \Drupal::service('file_system')->copy($files[0]->uri, $desired_filepath, FileSystemInterface::EXISTS_ERROR);
@@ -256,17 +299,57 @@ protected function addImageFields() {
       $images[] = $file;
     }
 
-    $field_name = 'field_image_with_default';
+    $field_name = 'field_image_storage_default';
     $storage_settings['default_image'] = [
       'uuid' => $images[0]->uuid(),
-      'alt' => 'My default alt text',
+      'alt' => 'My storage default alt text',
       'title' => '',
       'width' => 0,
       'height' => 0,
     ];
     $field_settings['default_image'] = [
+      'uuid' => NULL,
+      'alt' => '',
+      'title' => '',
+      'width' => NULL,
+      'height' => NULL,
+    ];
+    $widget_settings = [
+      'preview_image_style' => 'medium',
+    ];
+    $this->createImageField($field_name, 'test_node_type', $storage_settings, $field_settings, $widget_settings);
+
+    $field_name = 'field_image_instance_default';
+    $storage_settings['default_image'] = [
+      'uuid' => NULL,
+      'alt' => '',
+      'title' => '',
+      'width' => NULL,
+      'height' => NULL,
+    ];
+    $field_settings['default_image'] = [
+      'uuid' => $images[0]->uuid(),
+      'alt' => 'My instance default alt text',
+      'title' => '',
+      'width' => 0,
+      'height' => 0,
+    ];
+    $widget_settings = [
+      'preview_image_style' => 'medium',
+    ];
+    $this->createImageField($field_name, 'test_node_type', $storage_settings, $field_settings, $widget_settings);
+
+    $field_name = 'field_image_both_defaults';
+    $storage_settings['default_image'] = [
       'uuid' => $images[0]->uuid(),
-      'alt' => 'My default alt text',
+      'alt' => 'My storage default alt text',
+      'title' => '',
+      'width' => 0,
+      'height' => 0,
+    ];
+    $field_settings['default_image'] = [
+      'uuid' => $images[1]->uuid(),
+      'alt' => 'My instance default alt text',
       'title' => '',
       'width' => 0,
       'height' => 0,
diff --git a/web/core/modules/layout_builder/tests/src/Kernel/EntityViewAlterTest.php b/web/core/modules/layout_builder/tests/src/Kernel/EntityViewAlterTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..48f829a30836fba5917a80e0765d2a3e89066d7a
--- /dev/null
+++ b/web/core/modules/layout_builder/tests/src/Kernel/EntityViewAlterTest.php
@@ -0,0 +1,64 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\layout_builder\Kernel;
+
+use Drupal\Core\Routing\RouteObjectInterface;
+use Drupal\entity_test\Entity\EntityTest;
+use Drupal\KernelTests\KernelTestBase;
+use Drupal\layout_builder\Entity\LayoutBuilderEntityViewDisplay;
+use Symfony\Component\HttpFoundation\Request;
+use Symfony\Component\HttpFoundation\Session\Session;
+use Symfony\Component\HttpFoundation\Session\Storage\MockArraySessionStorage;
+use Symfony\Component\Routing\Route;
+
+/**
+ * @covers layout_builder_entity_view_alter
+ *
+ * @group layout_builder
+ */
+class EntityViewAlterTest extends KernelTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected static $modules = [
+    'layout_discovery',
+    'layout_builder',
+    'layout_builder_defaults_test',
+    'entity_test',
+    'user',
+  ];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected function setUp(): void {
+    parent::setUp();
+    entity_test_create_bundle('bundle_with_extra_fields');
+    $this->installEntitySchema('entity_test');
+    $this->installConfig(['layout_builder_defaults_test']);
+  }
+
+  /**
+   * Tests that contextual links are removed when rendering Layout Builder.
+   */
+  public function testContextualLinksRemoved(): void {
+    $display = LayoutBuilderEntityViewDisplay::load('entity_test.bundle_with_extra_fields.default');
+    $entity = EntityTest::create();
+    $build = [
+      '#contextual_links' => ['entity.node.canonical'],
+    ];
+    // Create a fake request that starts with layout_builder.
+    $request = Request::create('<front>');
+    $request->attributes->set(RouteObjectInterface::ROUTE_NAME, 'layout_builder.test');
+    $request->attributes->set(RouteObjectInterface::ROUTE_OBJECT, new Route('/'));
+    $request->setSession(new Session(new MockArraySessionStorage()));
+    \Drupal::requestStack()->push($request);
+    // Assert the contextual links are removed.
+    layout_builder_entity_view_alter($build, $entity, $display);
+    $this->assertArrayNotHasKey('#contextual_links', $build);
+  }
+
+}
diff --git a/web/core/modules/locale/locale.install b/web/core/modules/locale/locale.install
index 97f4327face7a456bc7e8b46fde454b1f0d5d368..4c995841a6445305a09c7f2c2141a80f16714c4e 100644
--- a/web/core/modules/locale/locale.install
+++ b/web/core/modules/locale/locale.install
@@ -21,6 +21,12 @@ function locale_install() {
     \Drupal::configFactory()->getEditable('locale.settings')->set('translation.path', $directory)->save();
   }
   \Drupal::service('file_system')->prepareDirectory($directory, FileSystemInterface::CREATE_DIRECTORY | FileSystemInterface::MODIFY_PERMISSIONS);
+
+  $t_args = [
+    ':translate_status' => base_path() . 'admin/reports/translations/check?destination=' . urlencode(base_path() . 'admin/reports/translations'),
+  ];
+  $message = t('Check <a href=":translate_status">available translations</a> for your language(s).', $t_args);
+  \Drupal::messenger()->addStatus($message);
 }
 
 /**
diff --git a/web/core/modules/locale/tests/src/Functional/LocaleInstallTest.php b/web/core/modules/locale/tests/src/Functional/LocaleInstallTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..776509cbc3a2daf21de7fbe46e70bb89881b51a2
--- /dev/null
+++ b/web/core/modules/locale/tests/src/Functional/LocaleInstallTest.php
@@ -0,0 +1,47 @@
+<?php
+
+declare(strict_types=1);
+namespace Drupal\Tests\locale\Functional;
+
+use Drupal\Tests\BrowserTestBase;
+
+/**
+ * Test installation of Locale module.
+ *
+ * @group locale
+ */
+class LocaleInstallTest extends BrowserTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected static $modules = [
+    'system',
+    'file',
+    'language',
+  ];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'stark';
+
+  /**
+   * Tests Locale install message.
+   */
+  public function testLocaleInstallMessage(): void {
+    $admin_user = $this->drupalCreateUser([
+      'access administration pages',
+      'administer modules',
+    ]);
+    $this->drupalLogin($admin_user);
+
+    $edit = [];
+    $edit['modules[locale][enable]'] = 'locale';
+    $this->drupalGet('admin/modules');
+    $this->submitForm($edit, 'Install');
+
+    $this->assertSession()->statusMessageContains('available translations', 'status');
+  }
+
+}
diff --git a/web/core/modules/locale/tests/src/Functional/LocalePluralFormatTest.php b/web/core/modules/locale/tests/src/Functional/LocalePluralFormatTest.php
index 27761996620bf3b3097de54ac85e81ec4f45c613..6cfc2b344dd04ab82e54f1e645c2bd392a967a18 100644
--- a/web/core/modules/locale/tests/src/Functional/LocalePluralFormatTest.php
+++ b/web/core/modules/locale/tests/src/Functional/LocalePluralFormatTest.php
@@ -144,7 +144,7 @@ public function testGetPluralFormat() {
         // Assert that the we get the right translation for that. Change the
         // expected index as per the logic for translation lookups.
         $expected_plural_index = ($count == 1) ? 0 : $expected_plural_index;
-        $expected_plural_string = str_replace('@count', $count, $plural_strings[$langcode][$expected_plural_index]);
+        $expected_plural_string = str_replace('@count', (string) $count, $plural_strings[$langcode][$expected_plural_index]);
         $this->assertSame($expected_plural_string, \Drupal::translation()->formatPlural($count, '@count hour', '@count hours', [], ['langcode' => $langcode])->render(), 'Plural translation of @count hour / @count hours for count ' . $count . ' in ' . $langcode . ' is ' . $expected_plural_string);
         // DO NOT use translation to pass translated strings into
         // PluralTranslatableMarkup::createFromTranslatedString() this way. It
diff --git a/web/core/modules/locale/tests/src/Kernel/LocaleConfigSubscriberTest.php b/web/core/modules/locale/tests/src/Kernel/LocaleConfigSubscriberTest.php
index b7bfe21112592500f9cf7a78db039c713e97bdd6..70c2b5309776f7c86dbd41dc914061a7cdbae6b4 100644
--- a/web/core/modules/locale/tests/src/Kernel/LocaleConfigSubscriberTest.php
+++ b/web/core/modules/locale/tests/src/Kernel/LocaleConfigSubscriberTest.php
@@ -458,7 +458,7 @@ protected function assertNoTranslation(string $config_name, string $langcode): v
   }
 
   /**
-   * Ensures a translation exists and is marked as customized.
+   * Asserts if a specific translation exists and its customization status.
    *
    * @param string $config_name
    *   The configuration name.
@@ -467,8 +467,7 @@ protected function assertNoTranslation(string $config_name, string $langcode): v
    * @param string $langcode
    *   The language code.
    * @param bool $customized
-   *   Whether or not the string should be asserted to be customized or not
-   *   customized.
+   *   (optional) Asserts if the translation is customized or not.
    *
    * @internal
    */
diff --git a/web/core/modules/media/src/OEmbed/UrlResolver.php b/web/core/modules/media/src/OEmbed/UrlResolver.php
index 716745ab7624c83afb9a2fc88a1f7a26b496edd2..340d15056f507dd493f3b8547754974c1643dc01 100644
--- a/web/core/modules/media/src/OEmbed/UrlResolver.php
+++ b/web/core/modules/media/src/OEmbed/UrlResolver.php
@@ -176,7 +176,7 @@ public function getResourceUrl($url, $max_width = NULL, $max_height = NULL) {
     // provide extra parameters in the query string. For example, Instagram also
     // supports the 'omitscript' parameter.
     $this->moduleHandler->alter('oembed_resource_url', $parsed_url, $provider);
-    $resource_url = $parsed_url['path'] . '?' . rawurldecode(UrlHelper::buildQuery($parsed_url['query']));
+    $resource_url = $parsed_url['path'] . '?' . UrlHelper::buildQuery($parsed_url['query']);
 
     $this->urlCache[$url] = $resource_url;
     $this->cacheBackend->set($cache_id, $resource_url);
diff --git a/web/core/modules/media/tests/src/Functional/MediaOverviewPageTest.php b/web/core/modules/media/tests/src/Functional/MediaOverviewPageTest.php
index 1f272ee2392174e0537928a37210a3df4c29ff80..ac2bb016fa6a1940d84cfe230c778f4b3503ba4c 100644
--- a/web/core/modules/media/tests/src/Functional/MediaOverviewPageTest.php
+++ b/web/core/modules/media/tests/src/Functional/MediaOverviewPageTest.php
@@ -86,6 +86,9 @@ public function testMediaOverviewPage() {
     ]);
     $media3->save();
 
+    // Make sure the role save below properly invalidates cache tags.
+    $this->refreshVariables();
+
     // Verify the view is now correctly populated. The non-admin user can only
     // view published media.
     $this->grantPermissions($role, [
@@ -138,6 +141,9 @@ public function testMediaOverviewPage() {
     $assert_session->elementExists('css', 'td.views-field-operations li a:contains("Delete")', $row1);
     $assert_session->linkByHrefExists('/media/' . $media1->id() . '/delete');
 
+    // Make sure the role save below properly invalidates cache tags.
+    $this->refreshVariables();
+
     // Make the user the owner of the unpublished media item and assert the
     // media item is only visible with the 'view own unpublished media'
     // permission.
diff --git a/web/core/modules/media/tests/src/Functional/Rest/MediaResourceTestBase.php b/web/core/modules/media/tests/src/Functional/Rest/MediaResourceTestBase.php
index f34844aedd6c8574eff8f7887dfbb04d09a3c44b..b0d5c2087753c1783f122345b3414c90b9367bb3 100644
--- a/web/core/modules/media/tests/src/Functional/Rest/MediaResourceTestBase.php
+++ b/web/core/modules/media/tests/src/Functional/Rest/MediaResourceTestBase.php
@@ -375,6 +375,9 @@ protected function uploadFile() {
     static::recursiveKSort($actual);
     $this->assertSame($expected, $actual);
 
+    // Make sure the role save below properly invalidates cache tags.
+    $this->refreshVariables();
+
     // To still run the complete test coverage for POSTing a Media entity, we
     // must revoke the additional permissions that we granted.
     $role = Role::load(static::$auth ? RoleInterface::AUTHENTICATED_ID : RoleInterface::ANONYMOUS_ID);
diff --git a/web/core/modules/media/tests/src/Functional/UrlResolverTest.php b/web/core/modules/media/tests/src/Functional/UrlResolverTest.php
index beb88d0de879dc82ce4d9708b7b5a3d0d59fa5e5..6c9ca1ebb6ee8f7c90e527ec2de566fd195b7128 100644
--- a/web/core/modules/media/tests/src/Functional/UrlResolverTest.php
+++ b/web/core/modules/media/tests/src/Functional/UrlResolverTest.php
@@ -41,19 +41,19 @@ public function providerEndpointMatching() {
     return [
       'match by endpoint: Twitter' => [
         'https://twitter.com/Dries/status/999985431595880448',
-        'https://publish.twitter.com/oembed?url=https://twitter.com/Dries/status/999985431595880448',
+        'https://publish.twitter.com/oembed?url=https%3A//twitter.com/Dries/status/999985431595880448',
       ],
       'match by endpoint: Vimeo' => [
         'https://vimeo.com/14782834',
-        'https://vimeo.com/api/oembed.json?url=https://vimeo.com/14782834',
+        'https://vimeo.com/api/oembed.json?url=https%3A//vimeo.com/14782834',
       ],
       'match by endpoint: Dailymotion' => [
         'https://www.dailymotion.com/video/x2vzluh',
-        'https://www.dailymotion.com/services/oembed?url=https://www.dailymotion.com/video/x2vzluh',
+        'https://www.dailymotion.com/services/oembed?url=https%3A//www.dailymotion.com/video/x2vzluh',
       ],
       'match by endpoint: Facebook' => [
         'https://www.facebook.com/facebook/videos/10153231379946729/',
-        'https://www.facebook.com/plugins/video/oembed.json?url=https://www.facebook.com/facebook/videos/10153231379946729/',
+        'https://www.facebook.com/plugins/video/oembed.json?url=https%3A//www.facebook.com/facebook/videos/10153231379946729/',
       ],
     ];
   }
diff --git a/web/core/modules/media_library/tests/src/Unit/MediaLibrarySelectFormTest.php b/web/core/modules/media_library/tests/src/Unit/MediaLibrarySelectFormTest.php
index c188a57a400ee74b05c37bc8d16caaa331299112..9207e5500ead890820e771fe26def5bb325b969d 100644
--- a/web/core/modules/media_library/tests/src/Unit/MediaLibrarySelectFormTest.php
+++ b/web/core/modules/media_library/tests/src/Unit/MediaLibrarySelectFormTest.php
@@ -14,7 +14,7 @@
 use Drupal\views\ResultRow;
 use Drupal\views\ViewExecutable;
 use Symfony\Component\DependencyInjection\ContainerBuilder;
-use Symfony\Component\HttpFoundation\ParameterBag;
+use Symfony\Component\HttpFoundation\InputBag;
 use Symfony\Component\HttpFoundation\Request;
 
 /**
@@ -50,18 +50,10 @@ public function testViewsForm(): void {
     $container->set('string_translation', $this->createMock(TranslationInterface::class));
     \Drupal::setContainer($container);
 
-    $query = $this->getMockBuilder(ParameterBag::class)
-      ->onlyMethods(['all'])
-      ->disableOriginalConstructor()
-      ->getMock();
-    $query->expects($this->any())
-      ->method('all')
-      ->willReturn([]);
-
     $request = $this->getMockBuilder(Request::class)
       ->disableOriginalConstructor()
       ->getMock();
-    $request->query = $query;
+    $request->query = new InputBag();
 
     $view = $this->getMockBuilder(ViewExecutable::class)
       ->onlyMethods(['getRequest', 'initStyle', 'getDisplay'])
diff --git a/web/core/modules/menu_link_content/src/Form/MenuLinkContentForm.php b/web/core/modules/menu_link_content/src/Form/MenuLinkContentForm.php
index b429213ee05a4425b428d684624308d21bfed484..ffdeb3595662a7c17280e3a23689e4867002686e 100644
--- a/web/core/modules/menu_link_content/src/Form/MenuLinkContentForm.php
+++ b/web/core/modules/menu_link_content/src/Form/MenuLinkContentForm.php
@@ -11,6 +11,7 @@
 use Drupal\Core\Language\LanguageManagerInterface;
 use Drupal\Core\Menu\MenuParentFormSelectorInterface;
 use Drupal\Core\Path\PathValidatorInterface;
+use Drupal\system\MenuInterface;
 use Symfony\Component\DependencyInjection\ContainerInterface;
 
 /**
@@ -92,9 +93,9 @@ public function form(array $form, FormStateInterface $form_state) {
     $parent_id = $this->entity->getParentId() ?: $this->getRequest()->query->get('parent');
     $default = $this->entity->getMenuName() . ':' . $parent_id;
     $id = $this->entity->isNew() ? '' : $this->entity->getPluginId();
-    if ($this->entity->isNew()) {
-      $menu_id = $this->entity->getMenuName();
-      $menu = $this->entityTypeManager->getStorage('menu')->load($menu_id);
+    $menu_id = $this->entity->getMenuName();
+    $menu = $this->entityTypeManager->getStorage('menu')->load($menu_id);
+    if ($menu instanceof MenuInterface && $this->entity->isNew()) {
       $form['menu_parent'] = $this->menuParentSelector->parentSelectElement($default, $id, [
         $menu_id => $menu->label(),
       ]);
diff --git a/web/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php b/web/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php
index 528c2bbf62cc14cbf18bfee5ddd1dc50a0d34b78..00d73a73f0ca61cd809c669f70eecd4c2184c3a3 100644
--- a/web/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php
+++ b/web/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php
@@ -459,4 +459,20 @@ public function testMenuLinkContentGetEntity(): void {
     $this->assertEquals($menu_link->id(), $tree_element->link->getEntity()->id());
   }
 
+  /**
+   * Tests that the form doesn't break for links with arbitrary menu names.
+   */
+  public function testMenuLinkContentFormInvalidParentMenu(): void {
+    $menu_link = MenuLinkContent::create([
+      'title' => 'Menu link test',
+      'provider' => 'menu_link_content',
+      'menu_name' => 'non-existent',
+      'link' => ['uri' => 'internal:/user/login'],
+    ]);
+    // Get the form for a new link, assert that building it doesn't break if
+    // the links menu name doesn't exist.
+    $build = \Drupal::service('entity.form_builder')->getForm($menu_link);
+    static::assertIsArray($build);
+  }
+
 }
diff --git a/web/core/modules/menu_ui/tests/src/Functional/MenuUiTest.php b/web/core/modules/menu_ui/tests/src/Functional/MenuUiTest.php
index 586e545a1888dd4f231c61e38023a09c3fb0e18a..5a6621b4e3b8278037062045225f73c5378f3678 100644
--- a/web/core/modules/menu_ui/tests/src/Functional/MenuUiTest.php
+++ b/web/core/modules/menu_ui/tests/src/Functional/MenuUiTest.php
@@ -1130,21 +1130,21 @@ private function verifyAccess($response = 200) {
     $this->drupalGet('admin/help/menu');
     $this->assertSession()->statusCodeEquals($response);
     if ($response == 200) {
-      $this->assertSession()->pageTextContains('Menu', 'Menu help was displayed');
+      $this->assertSession()->pageTextContains('Menu');
     }
 
     // View menu build overview page.
     $this->drupalGet('admin/structure/menu');
     $this->assertSession()->statusCodeEquals($response);
     if ($response == 200) {
-      $this->assertSession()->pageTextContains('Menus', 'Menu build overview page was displayed');
+      $this->assertSession()->pageTextContains('Menus');
     }
 
     // View tools menu customization page.
     $this->drupalGet('admin/structure/menu/manage/' . $this->menu->id());
     $this->assertSession()->statusCodeEquals($response);
     if ($response == 200) {
-      $this->assertSession()->pageTextContains('Tools', 'Tools menu page was displayed');
+      $this->assertSession()->pageTextContains('Tools');
     }
 
     // View menu edit page for a static link.
@@ -1152,14 +1152,14 @@ private function verifyAccess($response = 200) {
     $this->drupalGet('admin/structure/menu/link/' . $item->getPluginId() . '/edit');
     $this->assertSession()->statusCodeEquals($response);
     if ($response == 200) {
-      $this->assertSession()->pageTextContains('Edit menu item', 'Menu edit page was displayed');
+      $this->assertSession()->pageTextContains('Edit menu item');
     }
 
     // View add menu page.
     $this->drupalGet('admin/structure/menu/add');
     $this->assertSession()->statusCodeEquals($response);
     if ($response == 200) {
-      $this->assertSession()->pageTextContains('Menus', 'Add menu page was displayed');
+      $this->assertSession()->pageTextContains('Menus');
     }
   }
 
diff --git a/web/core/modules/migrate/src/Plugin/migrate/id_map/Sql.php b/web/core/modules/migrate/src/Plugin/migrate/id_map/Sql.php
index 52b89c9999da84daf3007f6c42709dcea3d3a7dc..54d55cfb0332567419525b80bb62ffa1025b07f3 100644
--- a/web/core/modules/migrate/src/Plugin/migrate/id_map/Sql.php
+++ b/web/core/modules/migrate/src/Plugin/migrate/id_map/Sql.php
@@ -590,14 +590,23 @@ public function getRowsNeedingUpdate($count) {
   public function lookupSourceId(array $destination_id_values) {
     $source_id_fields = $this->sourceIdFields();
     $query = $this->getDatabase()->select($this->mapTableName(), 'map');
+    // To allow source field names to be defined with spaces and special
+    // characters, create an alias map of column alias to source field name,
+    // since SQL column aliases do not support spaces or special characters.
+    $alias_map = [];
     foreach ($source_id_fields as $source_field_name => $id_map_field_name) {
-      $query->addField('map', $id_map_field_name, $source_field_name);
+      $alias = $query->addField('map', $id_map_field_name);
+      $alias_map[$alias] = $source_field_name;
     }
     foreach ($this->destinationIdFields() as $field_name => $destination_id) {
       $query->condition("map.$destination_id", $destination_id_values[$field_name], '=');
     }
-    $result = $query->execute();
-    return $result->fetchAssoc() ?: [];
+    $result = $query->execute()->fetchAssoc() ?: [];
+    $source_ids = [];
+    foreach ($result as $alias => $id) {
+      $source_ids[$alias_map[$alias]] = $id;
+    }
+    return $source_ids;
   }
 
   /**
diff --git a/web/core/modules/migrate/tests/src/Unit/MigrateSqlIdMapTest.php b/web/core/modules/migrate/tests/src/Unit/MigrateSqlIdMapTest.php
index 0ba79e1aab5d9f90bb18b901e7bc7024ed9923c2..afcb0cde8dced1a581f6fd1a11e500bac141cf1c 100644
--- a/web/core/modules/migrate/tests/src/Unit/MigrateSqlIdMapTest.php
+++ b/web/core/modules/migrate/tests/src/Unit/MigrateSqlIdMapTest.php
@@ -625,6 +625,42 @@ public function lookupSourceIdMappingDataProvider() {
    * @dataProvider lookupSourceIdMappingDataProvider
    */
   public function testLookupSourceIdMapping($num_source_fields, $num_destination_fields) {
+    $source_id_property_prefix = 'source_id_property_';
+    $this->doTestLookupSourceIdMapping($num_source_fields, $num_destination_fields, $source_id_property_prefix);
+  }
+
+  /**
+   * Performs the source ID test on source and destination fields.
+   *
+   * This performs same test as ::testLookupSourceIdMapping, except with source
+   * property names including spaces and special characters not allowed in SQL
+   * column aliases.
+   *
+   * @param int $num_source_fields
+   *   Number of source fields to test.
+   * @param int $num_destination_fields
+   *   Number of destination fields to test.
+   *
+   * @dataProvider lookupSourceIdMappingDataProvider
+   */
+  public function testLookupSourceIdMappingNonSqlCharacters($num_source_fields, $num_destination_fields) {
+    $source_id_property_prefix = '$ource id property * ';
+    $this->doTestLookupSourceIdMapping($num_source_fields, $num_destination_fields, $source_id_property_prefix);
+  }
+
+  /**
+   * Performs the source ID test on source and destination fields.
+   *
+   * @param int $num_source_fields
+   *   Number of source fields to test.
+   * @param int $num_destination_fields
+   *   Number of destination fields to test.
+   * @param string $source_id_property_prefix
+   *   Prefix for the source ID properties.
+   *
+   * @dataProvider lookupSourceIdMappingDataProvider
+   */
+  public function doTestLookupSourceIdMapping(int $num_source_fields, int $num_destination_fields, string $source_id_property_prefix): void {
     // Adjust the migration configuration according to the number of source and
     // destination fields.
     $this->sourceIds = [];
@@ -635,8 +671,8 @@ public function testLookupSourceIdMapping($num_source_fields, $num_destination_f
     for ($i = 1; $i <= $num_source_fields; $i++) {
       $row["sourceid$i"] = "source_id_value_$i";
       $source_ids_values = [$row["sourceid$i"]];
-      $expected_result["source_id_property_$i"] = "source_id_value_$i";
-      $this->sourceIds["source_id_property_$i"] = [];
+      $expected_result[$source_id_property_prefix . $i] = "source_id_value_$i";
+      $this->sourceIds[$source_id_property_prefix . $i] = [];
     }
     $destination_id_values = [];
     $nonexistent_id_values = [];
diff --git a/web/core/modules/node/migrations/d6_node_type.yml b/web/core/modules/node/migrations/d6_node_type.yml
index 3afe4bc475891e54411f7aca415bca9cc3e4ed6a..5c138c4683f1cda478b5d20cd4bc470a9fa000c7 100644
--- a/web/core/modules/node/migrations/d6_node_type.yml
+++ b/web/core/modules/node/migrations/d6_node_type.yml
@@ -21,7 +21,23 @@ process:
   'settings/node/options': options
   create_body: has_body
   create_body_label: body_label
-  'third_party_settings/menu_ui/available_menus': available_menus
-  'third_party_settings/menu_ui/parent': parent
+  'third_party_settings/menu_ui/available_menus':
+    plugin: static_map
+    bypass: true
+    source: available_menus
+    map:
+      main-menu: main
+      management: admin
+      navigation: tools
+      user-menu: account
+  'third_party_settings/menu_ui/parent':
+    plugin: static_map
+    bypass: true
+    source: parent
+    map:
+      'main-menu:': 'main:'
+      'management:': 'admin:'
+      'navigation:': 'tools:'
+      'user-menu:': 'account:'
 destination:
   plugin: entity:node_type
diff --git a/web/core/modules/node/migrations/d7_node_type.yml b/web/core/modules/node/migrations/d7_node_type.yml
index 1be9cd1ccc3af3f8094bc900b893e35e87407998..bd9c727f4358cc7fee18a3674b2809de5a204988 100644
--- a/web/core/modules/node/migrations/d7_node_type.yml
+++ b/web/core/modules/node/migrations/d7_node_type.yml
@@ -18,7 +18,23 @@ process:
   new_revision: 'options/revision'
   create_body: create_body
   create_body_label: body_label
-  'third_party_settings/menu_ui/available_menus': available_menus
-  'third_party_settings/menu_ui/parent': parent
+  'third_party_settings/menu_ui/available_menus':
+    plugin: static_map
+    bypass: true
+    source: available_menus
+    map:
+      main-menu: main
+      management: admin
+      navigation: tools
+      user-menu: account
+  'third_party_settings/menu_ui/parent':
+    plugin: static_map
+    bypass: true
+    source: parent
+    map:
+      'main-menu:0:': 'main:'
+      'management:0:': 'admin:'
+      'navigation:0:': 'tools:'
+      'user-menu:0:': 'account:'
 destination:
   plugin: entity:node_type
diff --git a/web/core/modules/node/src/NodeViewBuilder.php b/web/core/modules/node/src/NodeViewBuilder.php
index c10a75b71cd0491c67bdf39b4f79b9799f03b75f..b4ab0b5d0f908bc5df99b8d7662bc4e4098ac625 100644
--- a/web/core/modules/node/src/NodeViewBuilder.php
+++ b/web/core/modules/node/src/NodeViewBuilder.php
@@ -119,7 +119,9 @@ public static function renderLinks($node_entity_id, $view_mode, $langcode, $is_i
    *   A view mode identifier.
    *
    * @return array
-   *   An array that can be processed by drupal_pre_render_links().
+   *   An array that can be processed by Link::preRenderLinks().
+   *
+   * @see \Drupal\Core\Render\Element\Link::preRenderLinks()
    */
   protected static function buildLinks(NodeInterface $entity, $view_mode) {
     $links = [];
diff --git a/web/core/modules/node/tests/src/Functional/NodeRevisionsAllTest.php b/web/core/modules/node/tests/src/Functional/NodeRevisionsAllTest.php
index b496cf6beb63ffbaf16420ec51a6dd92255554b9..641fd709a058dc4c26cb03b01d5171c8ec60017b 100644
--- a/web/core/modules/node/tests/src/Functional/NodeRevisionsAllTest.php
+++ b/web/core/modules/node/tests/src/Functional/NodeRevisionsAllTest.php
@@ -63,9 +63,6 @@ protected function setUp(): void {
     // This must be different from user performing revert.
     $this->revisionUser = $this->drupalCreateUser();
 
-    $settings = get_object_vars($node);
-    $settings['revision'] = 1;
-
     $nodes = [];
     $logs = [];
 
diff --git a/web/core/modules/node/tests/src/Functional/NodeRevisionsTest.php b/web/core/modules/node/tests/src/Functional/NodeRevisionsTest.php
index d9df596421a628888a797b9897f21ede9e552b18..fd0e3332b2b13a14852b95641626cbc49e1150ac 100644
--- a/web/core/modules/node/tests/src/Functional/NodeRevisionsTest.php
+++ b/web/core/modules/node/tests/src/Functional/NodeRevisionsTest.php
@@ -95,9 +95,6 @@ protected function setUp(): void {
 
     // Create initial node.
     $node = $this->drupalCreateNode();
-    $settings = get_object_vars($node);
-    $settings['revision'] = 1;
-    $settings['isDefaultRevision'] = TRUE;
 
     $nodes = [];
     $logs = [];
diff --git a/web/core/modules/node/tests/src/Functional/Rest/NodeResourceTestBase.php b/web/core/modules/node/tests/src/Functional/Rest/NodeResourceTestBase.php
index 05ced94c98cd04cbe39ce95c5fda34d893440e9e..8f780ed07b439626f023deec663a9ee4137f8b15 100644
--- a/web/core/modules/node/tests/src/Functional/Rest/NodeResourceTestBase.php
+++ b/web/core/modules/node/tests/src/Functional/Rest/NodeResourceTestBase.php
@@ -255,6 +255,9 @@ public function testPatchPath() {
     $this->assertSame('/llama', $this->entityStorage->loadUnchanged($this->entity->id())->get('path')->alias);
     $this->assertResourceErrorResponse(403, "Access denied on updating field 'path'. " . static::$patchProtectedFieldNames['path'], $response);
 
+    // Make sure the role save below properly invalidates cache tags.
+    $this->refreshVariables();
+
     // Grant permission to create URL aliases.
     $this->grantPermissionsToTestedRole(['create url aliases']);
 
diff --git a/web/core/modules/node/tests/src/Kernel/Migrate/d6/MigrateNodeTypeTest.php b/web/core/modules/node/tests/src/Kernel/Migrate/d6/MigrateNodeTypeTest.php
index e42867f33defee5805e677905319d8989a5ece66..71e27caf827c8e933c27f1d508642293118b59d8 100644
--- a/web/core/modules/node/tests/src/Kernel/Migrate/d6/MigrateNodeTypeTest.php
+++ b/web/core/modules/node/tests/src/Kernel/Migrate/d6/MigrateNodeTypeTest.php
@@ -45,9 +45,9 @@ public function testNodeType() {
     $this->assertSame('This is the body field label', $field->getLabel(), 'Body field was found.');
 
     // Test default menus.
-    $expected_available_menus = ['navigation'];
+    $expected_available_menus = ['tools'];
     $this->assertSame($expected_available_menus, $node_type_page->getThirdPartySetting('menu_ui', 'available_menus'));
-    $expected_parent = 'navigation:';
+    $expected_parent = 'tools:';
     $this->assertSame($expected_parent, $node_type_page->getThirdPartySetting('menu_ui', 'parent'));
 
     // Test the test_story content type.
@@ -64,9 +64,9 @@ public function testNodeType() {
     $this->assertNull($field, 'No body field found');
 
     // Test default menus.
-    $expected_available_menus = ['navigation'];
+    $expected_available_menus = ['tools'];
     $this->assertSame($expected_available_menus, $node_type_story->getThirdPartySetting('menu_ui', 'available_menus'));
-    $expected_parent = 'navigation:';
+    $expected_parent = 'tools:';
     $this->assertSame($expected_parent, $node_type_story->getThirdPartySetting('menu_ui', 'parent'));
 
     // Test the test_event content type.
@@ -82,9 +82,9 @@ public function testNodeType() {
     $field = FieldConfig::loadByName('node', 'test_event', 'body');
     $this->assertSame('Body', $field->getLabel(), 'Body field was found.');
 
-    $expected_available_menus = ['navigation'];
+    $expected_available_menus = ['tools'];
     $this->assertSame($expected_available_menus, $node_type_event->getThirdPartySetting('menu_ui', 'available_menus'));
-    $expected_parent = 'navigation:';
+    $expected_parent = 'tools:';
     $this->assertSame($expected_parent, $node_type_event->getThirdPartySetting('menu_ui', 'parent'));
 
     // Test the 32 character type name exists.
diff --git a/web/core/modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTypeTest.php b/web/core/modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTypeTest.php
index 70f2a26e1b52af31cd1930b9b8d3c60baf3cfd78..fce725328c21178231d78d24a5f1e58a6c1d9db3 100644
--- a/web/core/modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTypeTest.php
+++ b/web/core/modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTypeTest.php
@@ -81,8 +81,8 @@ protected function assertEntity(string $id, string $label, string $description,
    * Tests Drupal 7 node type to Drupal 8 migration.
    */
   public function testNodeType() {
-    $expected_available_menus = ['main-menu'];
-    $expected_parent = 'main-menu:0:';
+    $expected_available_menus = ['main'];
+    $expected_parent = 'main:';
 
     $this->assertEntity('article', 'Article', 'Use <em>articles</em> for time-sensitive content like news, press releases or blog posts.', 'Help text for articles', TRUE, FALSE, $expected_available_menus, $expected_parent, "Body");
     $this->assertEntity('blog', 'Blog entry', 'Use for multi-user blogs. Every user gets a personal blog.', 'Blog away, good sir!', TRUE, FALSE, $expected_available_menus, $expected_parent, 'Body');
@@ -95,10 +95,10 @@ public function testNodeType() {
 
     // This node type does not carry a body field.
     $expected_available_menus = [
-      'main-menu',
-      'management',
-      'navigation',
-      'user-menu',
+      'main',
+      'admin',
+      'tools',
+      'account',
     ];
     $this->assertEntity('test_content_type', 'Test content type', 'This is the description of the test content type.', 'Help text for test content type', FALSE, TRUE, $expected_available_menus, $expected_parent);
   }
diff --git a/web/core/modules/responsive_image/tests/src/Functional/ResponsiveImageFieldDisplayTest.php b/web/core/modules/responsive_image/tests/src/Functional/ResponsiveImageFieldDisplayTest.php
index 6a2a42eff1696135560481c426e50bb0a372cf4e..ccf3c9577ae0a547b46f1ee310e0d9818e4c91cd 100644
--- a/web/core/modules/responsive_image/tests/src/Functional/ResponsiveImageFieldDisplayTest.php
+++ b/web/core/modules/responsive_image/tests/src/Functional/ResponsiveImageFieldDisplayTest.php
@@ -213,7 +213,7 @@ protected function doTestResponsiveImageFieldFormatters($scheme, $empty_styles =
       '#alt' => $alt,
       '#attributes' => ['loading' => 'lazy'],
     ];
-    $default_output = str_replace("\n", '', $renderer->renderRoot($image));
+    $default_output = str_replace("\n", '', (string) $renderer->renderRoot($image));
     $this->assertSession()->responseContains($default_output);
 
     // Test field not being configured. This should not cause a fatal error.
@@ -341,7 +341,7 @@ protected function doTestResponsiveImageFieldFormatters($scheme, $empty_styles =
     // The image.html.twig template has a newline after the <img> tag but
     // responsive-image.html.twig doesn't have one after the fallback image, so
     // we remove it here.
-    $default_output = trim($renderer->renderRoot($fallback_image));
+    $default_output = trim((string) $renderer->renderRoot($fallback_image));
     $this->assertSession()->responseContains($default_output);
 
     if ($scheme == 'private') {
diff --git a/web/core/modules/responsive_image/tests/src/Unit/ResponsiveImageStyleConfigEntityUnitTest.php b/web/core/modules/responsive_image/tests/src/Unit/ResponsiveImageStyleConfigEntityUnitTest.php
index cf2ff03c4aa42f9de3dd93d106ff00218f25b42c..5eaea98aacc644d6a466787b991df7a496168a5c 100644
--- a/web/core/modules/responsive_image/tests/src/Unit/ResponsiveImageStyleConfigEntityUnitTest.php
+++ b/web/core/modules/responsive_image/tests/src/Unit/ResponsiveImageStyleConfigEntityUnitTest.php
@@ -86,7 +86,7 @@ public function testCalculateDependencies() {
       ->with('image_style')
       ->willReturn($storage);
 
-    $entity_type_repository = $this->getMockForAbstractClass(EntityTypeRepositoryInterface::class);
+    $entity_type_repository = $this->createMock(EntityTypeRepositoryInterface::class);
     $entity_type_repository->expects($this->any())
       ->method('getEntityTypeFromClass')
       ->with('Drupal\image\Entity\ImageStyle')
diff --git a/web/core/modules/rest/tests/src/Functional/CookieResourceTestTrait.php b/web/core/modules/rest/tests/src/Functional/CookieResourceTestTrait.php
index 2d25b946a54317b478dfecd190a84822cb316c01..b2d076dedb9e50da57e1df0169235734879ec3cf 100644
--- a/web/core/modules/rest/tests/src/Functional/CookieResourceTestTrait.php
+++ b/web/core/modules/rest/tests/src/Functional/CookieResourceTestTrait.php
@@ -109,10 +109,6 @@ protected function assertResponseWhenMissingAuthentication($method, ResponseInte
       if (in_array('user.permissions', $expected_cookie_403_cacheability->getCacheContexts(), TRUE)) {
         $expected_cookie_403_cacheability->addCacheTags(['config:user.role.anonymous']);
       }
-      // @todo Fix \Drupal\block\BlockAccessControlHandler::mergeCacheabilityFromConditions() in https://www.drupal.org/node/2867881
-      if (static::$entityTypeId === 'block') {
-        $expected_cookie_403_cacheability->setCacheTags(str_replace('user:2', 'user:0', $expected_cookie_403_cacheability->getCacheTags()));
-      }
       $this->assertResourceErrorResponse(403, FALSE, $response, $expected_cookie_403_cacheability->getCacheTags(), $expected_cookie_403_cacheability->getCacheContexts(), 'MISS', FALSE);
     }
     else {
diff --git a/web/core/modules/rest/tests/src/Functional/ResourceTest.php b/web/core/modules/rest/tests/src/Functional/ResourceTest.php
index 23e7fa5fb1a919aee24ed7eaf15cbff49e4879fc..64ec7ed09bdf431514ce26c1ba6f63456d1c3318 100644
--- a/web/core/modules/rest/tests/src/Functional/ResourceTest.php
+++ b/web/core/modules/rest/tests/src/Functional/ResourceTest.php
@@ -15,6 +15,7 @@
  * Tests the structure of a REST resource.
  *
  * @group rest
+ * @group #slow
  */
 class ResourceTest extends BrowserTestBase {
 
diff --git a/web/core/modules/rest/tests/src/Unit/CollectRoutesTest.php b/web/core/modules/rest/tests/src/Unit/CollectRoutesTest.php
index b70073e238158f519e4ba74205d157369f4475e3..7ef03be11164f813203fd897de937ada2aec26d1 100644
--- a/web/core/modules/rest/tests/src/Unit/CollectRoutesTest.php
+++ b/web/core/modules/rest/tests/src/Unit/CollectRoutesTest.php
@@ -7,6 +7,7 @@
 use Drupal\Tests\UnitTestCase;
 use Drupal\Core\DependencyInjection\ContainerBuilder;
 use Drupal\rest\Plugin\views\display\RestExport;
+use Drupal\views\Entity\View;
 use Symfony\Component\Routing\Route;
 use Symfony\Component\Routing\RouteCollection;
 
@@ -41,10 +42,7 @@ protected function setUp(): void {
       ->disableOriginalConstructor()
       ->getMock();
 
-    $view = $this->getMockBuilder('\Drupal\views\Entity\View')
-      ->addMethods(['initHandlers'])
-      ->setConstructorArgs([['id' => 'test_view'], 'view'])
-      ->getMock();
+    $view = new View(['id' => 'test_view'], 'view');
 
     $view_executable = $this->getMockBuilder('\Drupal\views\ViewExecutable')
       ->onlyMethods(['initHandlers', 'getTitle'])
diff --git a/web/core/modules/rest/tests/src/Unit/EntityResourceValidationTraitTest.php b/web/core/modules/rest/tests/src/Unit/EntityResourceValidationTraitTest.php
index 1814b113a2bd507ab4f0b2fb1b3f3cbc0b6d70dc..e809f8eba00dfc8fa1005fd380e5408c6bd8d9db 100644
--- a/web/core/modules/rest/tests/src/Unit/EntityResourceValidationTraitTest.php
+++ b/web/core/modules/rest/tests/src/Unit/EntityResourceValidationTraitTest.php
@@ -75,7 +75,6 @@ public function testFailedValidate() {
 /**
  * A test class to use to test EntityResourceValidationTrait.
  *
- * Using ->getMockForTrait is problematic, as this trait is marked internal.
  * Because the mock doesn't use the \Drupal namespace, the Symfony 4+ class
  * loader will throw a deprecation error.
  */
diff --git a/web/core/modules/search/tests/src/Functional/SearchMultilingualEntityTest.php b/web/core/modules/search/tests/src/Functional/SearchMultilingualEntityTest.php
index b6a939b0b831fc7d9e014bc07e7cd5137f375a39..55855f00c775c54826f7ab7ea985e3c84568d5f6 100644
--- a/web/core/modules/search/tests/src/Functional/SearchMultilingualEntityTest.php
+++ b/web/core/modules/search/tests/src/Functional/SearchMultilingualEntityTest.php
@@ -159,7 +159,7 @@ public function testMultilingualSearch() {
     // Make sure index throttle is high enough, via the UI.
     $this->drupalGet('admin/config/search/pages');
     $this->submitForm(['cron_limit' => 20], 'Save configuration');
-    $this->assertEquals(20, $this->config('search.settings')->get('index.cron_limit', 100), 'Config setting was saved correctly');
+    $this->assertEquals(20, $this->config('search.settings')->get('index.cron_limit'), 'Config setting was saved correctly');
     // Get a new search plugin, to make sure it has this setting.
     $this->plugin = $this->container->get('plugin.manager.search')->createInstance('node_search');
 
diff --git a/web/core/modules/shortcut/tests/src/Functional/ShortcutLinksTest.php b/web/core/modules/shortcut/tests/src/Functional/ShortcutLinksTest.php
index 59170147e80ae32f66f6718f5d55c035f8f6e8f5..7f652abc880891017feaf87199cf61a03ebcf2bb 100644
--- a/web/core/modules/shortcut/tests/src/Functional/ShortcutLinksTest.php
+++ b/web/core/modules/shortcut/tests/src/Functional/ShortcutLinksTest.php
@@ -466,7 +466,7 @@ public function testShortcutBlockAccess() {
    */
   protected function assertShortcutQuickLink(string $label, int $index = 0, string $message = ''): void {
     $links = $this->xpath('//a[normalize-space()=:label]', [':label' => $label]);
-    $message = ($message ? $message : new FormattableMarkup('Shortcut quick link with label %label found.', ['%label' => $label]));
+    $message = ($message ? $message : (string) new FormattableMarkup('Shortcut quick link with label %label found.', ['%label' => $label]));
     $this->assertArrayHasKey($index, $links, $message);
   }
 
diff --git a/web/core/modules/system/src/PathBasedBreadcrumbBuilder.php b/web/core/modules/system/src/PathBasedBreadcrumbBuilder.php
index 64985ed1ed9219d7ae4481a94b6d5813928526e5..749dad24f7c9f78a118a3d43b9177b1afcb889f4 100644
--- a/web/core/modules/system/src/PathBasedBreadcrumbBuilder.php
+++ b/web/core/modules/system/src/PathBasedBreadcrumbBuilder.php
@@ -226,19 +226,7 @@ protected function getRequestForPath($path, array $exclude) {
       $request->attributes->add($this->router->matchRequest($request));
       return $request;
     }
-    catch (ParamNotConvertedException $e) {
-      return NULL;
-    }
-    catch (ResourceNotFoundException $e) {
-      return NULL;
-    }
-    catch (MethodNotAllowedException $e) {
-      return NULL;
-    }
-    catch (AccessDeniedHttpException $e) {
-      return NULL;
-    }
-    catch (NotFoundHttpException $e) {
+    catch (ParamNotConvertedException | ResourceNotFoundException | MethodNotAllowedException | AccessDeniedHttpException | NotFoundHttpException $e) {
       return NULL;
     }
   }
diff --git a/web/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestComputedField.php b/web/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestComputedField.php
index 6cf035700278023e5c6cffe144da93b1fc1a394c..9ade6b8344a5b5d9eafb0c0cdeaaa321f9dfa91f 100644
--- a/web/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestComputedField.php
+++ b/web/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestComputedField.php
@@ -6,6 +6,7 @@
 use Drupal\Core\Field\BaseFieldDefinition;
 use Drupal\Core\StringTranslation\TranslatableMarkup;
 use Drupal\entity_test\Plugin\Field\ComputedReferenceTestFieldItemList;
+use Drupal\entity_test\Plugin\Field\ComputedTestCacheableIntegerItemList;
 use Drupal\entity_test\Plugin\Field\ComputedTestCacheableStringItemList;
 use Drupal\entity_test\Plugin\Field\ComputedTestFieldItemList;
 
@@ -49,12 +50,22 @@ public static function baseFieldDefinitions(EntityTypeInterface $entity_type) {
       ->setSetting('target_type', 'entity_test')
       ->setClass(ComputedReferenceTestFieldItemList::class);
 
+    // Cacheable metadata can either be provided via the field item properties
+    // or via the field item list class directly. Add a computed string field
+    // which does the former and a computed integer field which does the latter.
     $fields['computed_test_cacheable_string_field'] = BaseFieldDefinition::create('computed_test_cacheable_string_item')
       ->setLabel(new TranslatableMarkup('Computed Cacheable String Field Test'))
       ->setComputed(TRUE)
       ->setClass(ComputedTestCacheableStringItemList::class)
       ->setReadOnly(FALSE)
       ->setInternal(FALSE);
+    $fields['computed_test_cacheable_integer_field'] = BaseFieldDefinition::create('integer')
+      ->setLabel(new TranslatableMarkup('Computed Cacheable Integer Field Test'))
+      ->setComputed(TRUE)
+      ->setClass(ComputedTestCacheableIntegerItemList::class)
+      ->setReadOnly(FALSE)
+      ->setInternal(FALSE)
+      ->setDisplayOptions('view', ['weight' => 10]);
 
     return $fields;
   }
diff --git a/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableIntegerItemList.php b/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableIntegerItemList.php
new file mode 100644
index 0000000000000000000000000000000000000000..6c9a85b9aed741b34ee481fb9bfe51d606edf8fb
--- /dev/null
+++ b/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableIntegerItemList.php
@@ -0,0 +1,36 @@
+<?php
+
+namespace Drupal\entity_test\Plugin\Field;
+
+use Drupal\Core\Cache\CacheableDependencyInterface;
+use Drupal\Core\Cache\CacheableDependencyTrait;
+use Drupal\Core\Cache\CacheableMetadata;
+use Drupal\Core\Field\FieldItemList;
+use Drupal\Core\TypedData\ComputedItemListTrait;
+
+/**
+ * Item list class for computed cacheable string field.
+ *
+ * This class sets the cacheable metadata on the field item list directly.
+ *
+ * @see \Drupal\entity_test\Plugin\Field\ComputedTestCacheableStringItemList
+ */
+class ComputedTestCacheableIntegerItemList extends FieldItemList implements CacheableDependencyInterface {
+
+  use CacheableDependencyTrait, ComputedItemListTrait;
+
+  /**
+   * {@inheritdoc}
+   */
+  protected function computeValue() {
+    $value = \Drupal::state()->get('entity_test_computed_integer_value', 0);
+    $item = $this->createItem(0, $value);
+    $cacheability = (new CacheableMetadata())
+      ->setCacheContexts(['url.query_args:computed_test_cacheable_integer_field'])
+      ->setCacheTags(['field:computed_test_cacheable_integer_field'])
+      ->setCacheMaxAge(31536000);
+    $this->setCacheability($cacheability);
+    $this->list[0] = $item;
+  }
+
+}
diff --git a/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableStringItemList.php b/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableStringItemList.php
index 21aaa9f7b0c7a990d384d78b3c11152f46f69deb..307409babcee5d89bdf0b4ece28fc9c52073bcc0 100644
--- a/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableStringItemList.php
+++ b/web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableStringItemList.php
@@ -8,6 +8,10 @@
 
 /**
  * Item list class for computed cacheable string field.
+ *
+ *  This class sets the cacheable metadata on the field item properties.
+ *
+ * @see \Drupal\entity_test\Plugin\Field\ComputedTestCacheableIntegerItemList
  */
 class ComputedTestCacheableStringItemList extends FieldItemList {
 
diff --git a/web/core/modules/system/tests/modules/entity_test/tests/src/Functional/Rest/EntityTestComputedFieldNormalizerTest.php b/web/core/modules/system/tests/modules/entity_test/tests/src/Functional/Rest/EntityTestComputedFieldNormalizerTest.php
index b6c914e32d091d240dc58ff43f4b8b4b093f750c..2090db49aa60b40b0ac424c4363b5e24cf98ab62 100644
--- a/web/core/modules/system/tests/modules/entity_test/tests/src/Functional/Rest/EntityTestComputedFieldNormalizerTest.php
+++ b/web/core/modules/system/tests/modules/entity_test/tests/src/Functional/Rest/EntityTestComputedFieldNormalizerTest.php
@@ -56,6 +56,12 @@ protected function getExpectedNormalizedEntity() {
         'value' => 'computed test cacheable string field',
       ],
     ];
+    // @see \Drupal\entity_test\Plugin\Field\ComputedTestCacheableIntegerItemList::computeValue().
+    $expected['computed_test_cacheable_integer_field'] = [
+      [
+        'value' => 0,
+      ],
+    ];
 
     $expected['uuid'] = [
       0 => [
diff --git a/web/core/modules/system/tests/modules/form_test/form_test.routing.yml b/web/core/modules/system/tests/modules/form_test/form_test.routing.yml
index 80542e6153457407759b8aae60565fd56aab0a60..be0a1a34a8ba89c55338bb2681017d6fcf546feb 100644
--- a/web/core/modules/system/tests/modules/form_test/form_test.routing.yml
+++ b/web/core/modules/system/tests/modules/form_test/form_test.routing.yml
@@ -433,6 +433,15 @@ form_test.details_form:
   requirements:
     _access: 'TRUE'
 
+form_test.details_contains_required_textfield:
+  path: '/form_test/details-contains-required-textfield/{use_ajax}'
+  defaults:
+    _form: '\Drupal\form_test\Form\FormTestDetailsContainsRequiredTextfieldForm'
+    _title: 'Form details contains required textfield test'
+    use_ajax: FALSE
+  requirements:
+    _access: 'TRUE'
+
 form_test.description_display:
   path: '/form_test/form-descriptions'
   defaults:
diff --git a/web/core/modules/system/tests/modules/form_test/src/Form/FormTestDetailsContainsRequiredTextfieldForm.php b/web/core/modules/system/tests/modules/form_test/src/Form/FormTestDetailsContainsRequiredTextfieldForm.php
new file mode 100644
index 0000000000000000000000000000000000000000..2ed323039062db4c7b8be1180fe110e8e9f5b8c2
--- /dev/null
+++ b/web/core/modules/system/tests/modules/form_test/src/Form/FormTestDetailsContainsRequiredTextfieldForm.php
@@ -0,0 +1,64 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\form_test\Form;
+
+use Drupal\Core\Form\FormBase;
+use Drupal\Core\Form\FormStateInterface;
+
+/**
+ * Builds a form to test a required textfield within a details element.
+ *
+ * @internal
+ */
+class FormTestDetailsContainsRequiredTextfieldForm extends FormBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  public function getFormId(): string {
+    return 'form_test_details_form';
+  }
+
+  /**
+   * {@inheritdoc}
+   */
+  public function buildForm(array $form, FormStateInterface $form_state, $use_ajax = FALSE): array {
+
+    $form['meta'] = [
+      '#type' => 'details',
+      '#title' => 'Details element',
+      '#open' => FALSE,
+    ];
+    $form['meta']['required_textfield_in_details'] = [
+      '#type' => 'textfield',
+      '#required' => TRUE,
+      '#title' => 'Required textfield',
+    ];
+    $form['submit'] = [
+      '#type' => 'submit',
+      '#value' => 'Submit',
+    ];
+    if ($use_ajax) {
+      $form['submitAjax'] = [
+        '#type' => 'submit',
+        '#value' => 'Submit Ajax',
+        '#ajax' => [
+          'callback' => '::submitForm',
+          'event' => 'click',
+          'wrapper' => 'form-test-details-form',
+        ],
+      ];
+    }
+    return $form;
+  }
+
+  /**
+   * {@inheritdoc}
+   */
+  public function submitForm(array &$form, FormStateInterface $form_state) {
+    return $form;
+  }
+
+}
diff --git a/web/core/modules/system/tests/modules/form_test/src/Form/JavascriptStatesForm.php b/web/core/modules/system/tests/modules/form_test/src/Form/JavascriptStatesForm.php
index 91e5540fda2ea230f85802a6d9a6ef6db38c27a6..0677df3bd06e3a2be32510d7208f670e6cba5ab7 100644
--- a/web/core/modules/system/tests/modules/form_test/src/Form/JavascriptStatesForm.php
+++ b/web/core/modules/system/tests/modules/form_test/src/Form/JavascriptStatesForm.php
@@ -24,6 +24,12 @@ public function getFormId() {
    * {@inheritdoc}
    */
   public function buildForm(array $form, FormStateInterface $form_state) {
+
+    $form['header_triggers'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h2',
+      '#value' => 'Triggers',
+    ];
     $form['checkbox_trigger'] = [
       '#type' => 'checkbox',
       '#title' => 'Checkbox trigger',
@@ -112,8 +118,30 @@ public function buildForm(array $form, FormStateInterface $form_state) {
       '#title' => 'Number trigger',
     ];
 
+    $form['multiple_select_trigger'] = [
+      '#type' => 'select',
+      '#multiple' => TRUE,
+      '#title' => 'Multiple select trigger',
+      '#options' => [
+        'value1' => 'Value 1',
+        'value2' => 'Value 2',
+        'value3' => 'Value 3',
+      ],
+    ];
+
     // Tested fields.
+    $form['header_tested_elements'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h2',
+      '#value' => 'Tested elements',
+    ];
+
     // Checkbox trigger.
+    $form['header_checkbox'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Checkbox tests',
+    ];
     $form['textfield_invisible_when_checkbox_trigger_checked'] = [
       '#type' => 'textfield',
       '#title' => 'Textfield invisible when checkbox trigger checked',
@@ -318,6 +346,11 @@ public function buildForm(array $form, FormStateInterface $form_state) {
     ];
 
     // Checkboxes trigger.
+    $form['header_checkboxes'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Checkboxes tests',
+    ];
     $form['textfield_visible_when_checkboxes_trigger_value2_checked'] = [
       '#type' => 'textfield',
       '#title' => 'Textfield visible when checkboxes trigger value2 checked',
@@ -338,6 +371,11 @@ public function buildForm(array $form, FormStateInterface $form_state) {
     ];
 
     // Radios trigger.
+    $form['header_radios'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Radios tests',
+    ];
     $form['fieldset_visible_when_radios_trigger_has_value2'] = [
       '#type' => 'fieldset',
       '#title' => 'Fieldset visible when radio trigger has value2',
@@ -407,6 +445,11 @@ public function buildForm(array $form, FormStateInterface $form_state) {
     ];
 
     // Select trigger
+    $form['header_select'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Select tests',
+    ];
     $form['item_visible_when_select_trigger_has_value2'] = [
       '#type' => 'item',
       '#title' => 'Item visible when select trigger has value2',
@@ -438,7 +481,72 @@ public function buildForm(array $form, FormStateInterface $form_state) {
       ],
     ];
 
+    // Multiple select trigger.
+    $form['header_multiple_select'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Multiple select tests',
+    ];
+    $form['item_visible_when_multiple_select_trigger_has_value2'] = [
+      '#type' => 'item',
+      '#title' => 'Item visible when multiple select trigger has value2',
+      '#states' => [
+        'visible' => [
+          'select[name="multiple_select_trigger[]"]' => ['value' => ['value2']],
+        ],
+      ],
+    ];
+    $form['item_visible_when_multiple_select_trigger_has_no_value'] = [
+      '#type' => 'item',
+      '#title' => 'Item visible when multiple select trigger has no value',
+      '#states' => [
+        'visible' => [
+          'select[name="multiple_select_trigger[]"]' => ['value' => []],
+        ],
+      ],
+    ];
+    $form['textfield_visible_when_multiple_select_trigger_has_value3'] = [
+      '#type' => 'textfield',
+      '#title' => 'Textfield visible when multiple select trigger has value3',
+      '#states' => [
+        'visible' => [
+          'select[name="multiple_select_trigger[]"]' => ['value' => ['value3']],
+        ],
+      ],
+    ];
+    $form['textfield_visible_when_multiple_select_trigger_has_value2_or_value3'] = [
+      '#type' => 'textfield',
+      '#title' => 'Textfield visible when multiple select trigger has value2 OR value3',
+      '#states' => [
+        'visible' => [
+          'select[name="multiple_select_trigger[]"]' => [
+            ['value' => ['value2']],
+            ['value' => ['value3']],
+          ],
+        ],
+      ],
+    ];
+    $form['textfield_visible_when_multiple_select_trigger_has_value2_and_value3'] = [
+      '#type' => 'textfield',
+      '#title' => 'Textfield visible when multiple select trigger has value2 AND value3',
+      '#states' => [
+        'visible' => [
+          'select[name="multiple_select_trigger[]"]' => [
+            'value' => [
+              'value3',
+              'value2',
+            ],
+          ],
+        ],
+      ],
+    ];
+
     // Textfield trigger.
+    $form['header_textfield'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Textfield tests',
+    ];
     $form['checkbox_checked_when_textfield_trigger_filled'] = [
       '#type' => 'checkbox',
       '#title' => 'Checkbox checked when textfield trigger filled',
@@ -503,6 +611,11 @@ public function buildForm(array $form, FormStateInterface $form_state) {
     ];
 
     // Multiple triggers.
+    $form['header_multiple_triggers'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Multiple triggers tests',
+    ];
     $form['item_visible_when_select_trigger_has_value2_and_textfield_trigger_filled'] = [
       '#type' => 'item',
       '#title' => 'Item visible when select trigger has value2 and textfield trigger filled',
@@ -515,6 +628,11 @@ public function buildForm(array $form, FormStateInterface $form_state) {
     ];
 
     // Number triggers.
+    $form['header_number'] = [
+      '#type' => 'html_tag',
+      '#tag' => 'h3',
+      '#value' => 'Number tests',
+    ];
     $form['item_visible_when_number_trigger_filled_by_spinner'] = [
       '#type' => 'item',
       '#title' => 'Item visible when number trigger filled by spinner widget',
@@ -557,6 +675,61 @@ public function buildForm(array $form, FormStateInterface $form_state) {
       ],
     ];
 
+    $form['test_button_disabled'] = [
+      '#type' => 'container',
+    ];
+
+    $form['test_button_disabled']['submit_button'] = [
+      '#type' => 'submit',
+      '#value' => 'Submit button disabled when checkbox not checked',
+      '#states' => [
+        'disabled' => [':input[name="checkbox_enable_submit_button"]' => ['checked' => FALSE]],
+      ],
+    ];
+    $form['test_button_disabled']['checkbox_enable_submit_button'] = [
+      '#type' => 'checkbox',
+      '#title' => 'Enable input submit',
+    ];
+
+    $form['test_button_disabled']['input_textfield'] = [
+      '#type' => 'textfield',
+      '#title' => 'Text field disabled when checkbox not checked',
+      '#states' => [
+        'disabled' => [':input[name="checkbox_enable_input_textfield"]' => ['checked' => FALSE]],
+      ],
+    ];
+    $form['test_button_disabled']['checkbox_enable_input_textfield'] = [
+      '#type' => 'checkbox',
+      '#title' => 'Enable text field',
+    ];
+
+    $form['test_button_disabled']['test_select_disabled'] = [
+      '#type' => 'select',
+      '#title' => 'Select disabled when checkbox not checked',
+      '#options' => [
+        0 => 0,
+        1 => 1,
+      ],
+      '#states' => [
+        'disabled' => [':input[name="checkbox_enable_select"]' => ['checked' => FALSE]],
+      ],
+    ];
+    $form['test_button_disabled']['checkbox_enable_select'] = [
+      '#type' => 'checkbox',
+      '#title' => 'Enable select',
+    ];
+    $form['test_button_disabled']['test_textarea_disabled'] = [
+      '#type' => 'textarea',
+      '#title' => 'Textarea disabled when checkbox not checked',
+      '#states' => [
+        'disabled' => [':input[name="checkbox_enable_textarea"]' => ['checked' => FALSE]],
+      ],
+    ];
+    $form['test_button_disabled']['checkbox_enable_textarea'] = [
+      '#type' => 'checkbox',
+      '#title' => 'Enable textarea',
+    ];
+
     return $form;
   }
 
diff --git a/web/core/modules/system/tests/src/Functional/Entity/EntityComputedFieldTest.php b/web/core/modules/system/tests/src/Functional/Entity/EntityComputedFieldTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..56e939986f7f33b26bc5916d1b388466267dbc3c
--- /dev/null
+++ b/web/core/modules/system/tests/src/Functional/Entity/EntityComputedFieldTest.php
@@ -0,0 +1,76 @@
+<?php
+
+namespace Drupal\Tests\system\Functional\Entity;
+
+use Drupal\Core\Cache\Cache;
+use Drupal\Core\State\StateInterface;
+use Drupal\entity_test\Entity\EntityTestComputedField;
+use Drupal\Tests\BrowserTestBase;
+
+/**
+ * Tests that entities with computed fields work correctly.
+ *
+ * @group Entity
+ */
+class EntityComputedFieldTest extends BrowserTestBase {
+
+  /**
+   * Modules to enable.
+   *
+   * @var array
+   */
+  protected static $modules = ['entity_test'];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'olivero';
+
+  /**
+   * The state service.
+   *
+   * @var \Drupal\Core\State\StateInterface
+   */
+  protected StateInterface $state;
+
+  protected function setUp(): void {
+    parent::setUp();
+
+    $this->state = $this->container->get('state');
+  }
+
+  /**
+   * Tests that formatters bubble the cacheable metadata of computed fields.
+   */
+  public function testFormatterComputedFieldCacheableMetadata() {
+    $this->drupalLogin($this->drupalCreateUser(['administer entity_test content']));
+
+    $entity = EntityTestComputedField::create([
+      'name' => 'Test entity with a cacheable, computed field',
+    ]);
+    $entity->save();
+
+    $this->state->set('entity_test_computed_integer_value', 2024);
+    $this->drupalGet($entity->toUrl('canonical')->toString());
+    $field_item_selector = '.field--name-computed-test-cacheable-integer-field .field__item';
+    $this->assertSession()->elementTextEquals('css', $field_item_selector, 2024);
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Contexts', 'url.query_args:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', 'field:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderEquals('X-Drupal-Cache-Max-Age', "31536000");
+
+    $this->state->set('entity_test_computed_integer_value', 2025);
+    $this->drupalGet($entity->toUrl('canonical')->toString());
+    $this->assertSession()->elementTextEquals('css', $field_item_selector, 2024);
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Contexts', 'url.query_args:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', 'field:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderEquals('X-Drupal-Cache-Max-Age', "31536000");
+
+    Cache::invalidateTags(['field:computed_test_cacheable_integer_field']);
+    $this->drupalGet($entity->toUrl('canonical')->toString());
+    $this->assertSession()->elementTextEquals('css', $field_item_selector, 2025);
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Contexts', 'url.query_args:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderContains('X-Drupal-Cache-Tags', 'field:computed_test_cacheable_integer_field');
+    $this->assertSession()->responseHeaderEquals('X-Drupal-Cache-Max-Age', "31536000");
+  }
+
+}
diff --git a/web/core/modules/system/tests/src/Functional/Form/CheckboxTest.php b/web/core/modules/system/tests/src/Functional/Form/CheckboxTest.php
index 4e425343e2ba3becd78e5305a1271e653e5cc2bd..4bd82849b0378fb53e9b9bd5becc239d9f53d2fc 100644
--- a/web/core/modules/system/tests/src/Functional/Form/CheckboxTest.php
+++ b/web/core/modules/system/tests/src/Functional/Form/CheckboxTest.php
@@ -2,7 +2,6 @@
 
 namespace Drupal\Tests\system\Functional\Form;
 
-use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Tests\BrowserTestBase;
 
 /**
@@ -35,7 +34,7 @@ public function testFormCheckbox() {
       // @see \Drupal\Core\Render\Element\Checkbox::processCheckbox().
       foreach (['0', '', 1, '1', 'foobar', '1foobar'] as $return_value) {
         $form_array = \Drupal::formBuilder()->getForm('\Drupal\form_test\Form\FormTestCheckboxTypeJugglingForm', $default_value, $return_value);
-        $form = \Drupal::service('renderer')->renderRoot($form_array);
+        $form = (string) \Drupal::service('renderer')->renderRoot($form_array);
         if ($default_value === TRUE) {
           $checked = TRUE;
         }
@@ -55,7 +54,7 @@ public function testFormCheckbox() {
           $checked = ($default_value === '1foobar');
         }
         $checked_in_html = str_contains($form, 'checked');
-        $message = new FormattableMarkup('#default_value is %default_value #return_value is %return_value.', ['%default_value' => var_export($default_value, TRUE), '%return_value' => var_export($return_value, TRUE)]);
+        $message = '#default_value is ' . var_export($default_value, TRUE) . ' #return_value is ' . var_export($return_value, TRUE) . '.';
         $this->assertSame($checked, $checked_in_html, $message);
       }
     }
diff --git a/web/core/modules/system/tests/src/Functional/Form/StorageTest.php b/web/core/modules/system/tests/src/Functional/Form/StorageTest.php
index 2d3199f48e8bd16efccae4b981bf9efc330cdd08..57f3e286447f9f453d8c0977174cd9a1dceb7ada 100644
--- a/web/core/modules/system/tests/src/Functional/Form/StorageTest.php
+++ b/web/core/modules/system/tests/src/Functional/Form/StorageTest.php
@@ -16,6 +16,7 @@
  * values are not lost due to a wrong form rebuild.
  *
  * @group Form
+ * @group #slow
  */
 class StorageTest extends BrowserTestBase {
 
diff --git a/web/core/modules/system/tests/src/Functional/Form/ValidationTest.php b/web/core/modules/system/tests/src/Functional/Form/ValidationTest.php
index 328fca30be0affd8c6d56af64a69ee77bba5eaf9..4d28dd997e4b6b08516ae189a3d5a7bbb749623c 100644
--- a/web/core/modules/system/tests/src/Functional/Form/ValidationTest.php
+++ b/web/core/modules/system/tests/src/Functional/Form/ValidationTest.php
@@ -9,6 +9,7 @@
  * Tests form processing and alteration via form validation handlers.
  *
  * @group Form
+ * @group #slow
  */
 class ValidationTest extends BrowserTestBase {
 
diff --git a/web/core/modules/system/tests/src/Functional/Menu/MenuRouterTest.php b/web/core/modules/system/tests/src/Functional/Menu/MenuRouterTest.php
index 06980db0efd1cc9e20900a06639e63dbeb39d7ba..6724fc7cd5259097aed902e28d183bc916fc547f 100644
--- a/web/core/modules/system/tests/src/Functional/Menu/MenuRouterTest.php
+++ b/web/core/modules/system/tests/src/Functional/Menu/MenuRouterTest.php
@@ -82,8 +82,8 @@ protected function doTestHookMenuIntegration() {
    */
   protected function doTestTitleCallbackFalse() {
     $this->drupalGet('test-page');
-    $this->assertSession()->pageTextContains('A title with @placeholder', 'Raw text found on the page');
-    $this->assertSession()->pageTextNotContains('A title with some other text', 'Text with placeholder substitutions not found.');
+    $this->assertSession()->pageTextContains('A title with @placeholder');
+    $this->assertSession()->pageTextNotContains('A title with some other text');
   }
 
   /**
diff --git a/web/core/modules/system/tests/src/Functional/System/SitesDirectoryHardeningTest.php b/web/core/modules/system/tests/src/Functional/System/SitesDirectoryHardeningTest.php
index 112ad1266565e6f115976e3bfd909df626f76ec5..4bed0be43cc06bec2f5c0fc917d59490343e8f02 100644
--- a/web/core/modules/system/tests/src/Functional/System/SitesDirectoryHardeningTest.php
+++ b/web/core/modules/system/tests/src/Functional/System/SitesDirectoryHardeningTest.php
@@ -58,7 +58,7 @@ public function testSitesDirectoryHardeningConfig() {
     $requirements = $this->checkSystemRequirements();
     $this->assertEquals(REQUIREMENT_WARNING, $requirements['configuration_files']['severity'], 'Warning severity is properly set.');
     $this->assertEquals('Protection disabled', (string) $requirements['configuration_files']['value']);
-    $description = strip_tags(\Drupal::service('renderer')->renderPlain($requirements['configuration_files']['description']));
+    $description = strip_tags((string) \Drupal::service('renderer')->renderPlain($requirements['configuration_files']['description']));
     $this->assertStringContainsString('settings.php is not protected from modifications and poses a security risk.', $description);
     $this->assertStringContainsString('services.yml is not protected from modifications and poses a security risk.', $description);
 
diff --git a/web/core/modules/system/tests/src/Functional/Theme/NodeTitleTestBase.php b/web/core/modules/system/tests/src/Functional/Theme/NodeTitleTestBase.php
new file mode 100644
index 0000000000000000000000000000000000000000..212fc250a88aa80c1efffb16e9345eb89ba9168d
--- /dev/null
+++ b/web/core/modules/system/tests/src/Functional/Theme/NodeTitleTestBase.php
@@ -0,0 +1,78 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\system\Functional\Theme;
+
+use Drupal\Tests\node\Functional\NodeTestBase;
+
+/**
+ * Tests node title for a theme.
+ */
+abstract class NodeTitleTestBase extends NodeTestBase {
+
+  /**
+   * {@inheritdoc}
+   */
+  protected $defaultTheme = 'stark';
+
+  /**
+   * Modules to enable.
+   *
+   * @var array
+   */
+  protected static $modules = ['block'];
+
+  /**
+   * {@inheritdoc}
+   */
+  protected function setUp(): void {
+    parent::setUp();
+    $this->drupalPlaceBlock('page_title_block');
+
+    $adminUser = $this->drupalCreateUser([
+      'administer themes',
+      'administer nodes',
+      'create article content',
+      'create page content',
+    ]);
+    $this->drupalLogin($adminUser);
+  }
+
+  /**
+   * Get the theme name.
+   *
+   * @return string
+   *   The theme to test.
+   */
+  protected function getTheme(): string {
+    return explode('\\', get_class($this))[2];
+  }
+
+  /**
+   * Creates one node with title 0 and tests if the node title has the correct value.
+   */
+  public function testNodeWithTitle0(): void {
+    $theme = $this->getTheme();
+    if ($theme !== $this->defaultTheme) {
+      $system_theme_config = $this->container->get('config.factory')
+        ->getEditable('system.theme');
+      $system_theme_config
+        ->set('default', $theme)
+        ->save();
+      \Drupal::service('theme_installer')->install([$theme]);
+    }
+
+    // Create "Basic page" content with title 0.
+    $settings = [
+      'title' => 0,
+    ];
+    $node = $this->drupalCreateNode($settings);
+    // Test that 0 appears as <title>.
+    $this->drupalGet('node/' . $node->id());
+    $this->assertSession()->titleEquals('0 | Drupal');
+    // Test that 0 appears in the template <h1>.
+    $this->assertSession()->elementTextEquals('xpath', '//h1', '0');
+  }
+
+}
diff --git a/web/core/modules/system/tests/src/Functional/Theme/TwigDebugMarkupTest.php b/web/core/modules/system/tests/src/Functional/Theme/TwigDebugMarkupTest.php
index 409a729aa4dacf7a46384c3e7c7c1415162e2b64..9e9dfd62aa7a839b12d6373d4a7f4202a8870082 100644
--- a/web/core/modules/system/tests/src/Functional/Theme/TwigDebugMarkupTest.php
+++ b/web/core/modules/system/tests/src/Functional/Theme/TwigDebugMarkupTest.php
@@ -50,7 +50,7 @@ public function testTwigDebugMarkup() {
     $node = $this->drupalCreateNode();
     $builder = \Drupal::entityTypeManager()->getViewBuilder('node');
     $build = $builder->view($node);
-    $output = $renderer->renderRoot($build);
+    $output = (string) $renderer->renderRoot($build);
     $this->assertStringContainsString('<!-- THEME DEBUG -->', $output, 'Twig debug markup found in theme output when debug is enabled.');
     $this->assertStringContainsString("THEME HOOK: 'node'", $output, 'Theme call information found.');
     $this->assertStringContainsString('* node--1--full' . $extension . PHP_EOL . '   x node--1' . $extension . PHP_EOL . '   * node--page--full' . $extension . PHP_EOL . '   * node--page' . $extension . PHP_EOL . '   * node--full' . $extension . PHP_EOL . '   * node' . $extension, $output, 'Suggested template files found in order and node ID specific template shown as current template.');
@@ -63,7 +63,7 @@ public function testTwigDebugMarkup() {
     // debug markup are correct.
     $node2 = $this->drupalCreateNode();
     $build = $builder->view($node2);
-    $output = $renderer->renderRoot($build);
+    $output = (string) $renderer->renderRoot($build);
     $this->assertStringContainsString('* node--2--full' . $extension . PHP_EOL . '   * node--2' . $extension . PHP_EOL . '   * node--page--full' . $extension . PHP_EOL . '   * node--page' . $extension . PHP_EOL . '   * node--full' . $extension . PHP_EOL . '   x node' . $extension, $output, 'Suggested template files found in order and base template shown as current template.');
 
     // Create another node and make sure the template suggestions shown in the
@@ -71,7 +71,7 @@ public function testTwigDebugMarkup() {
     $node3 = $this->drupalCreateNode();
     $build = ['#theme' => 'node__foo__bar'];
     $build += $builder->view($node3);
-    $output = $renderer->renderRoot($build);
+    $output = (string) $renderer->renderRoot($build);
     $this->assertStringContainsString("THEME HOOK: 'node__foo__bar'", $output, 'Theme call information found.');
     $this->assertStringContainsString('* node--foo--bar' . $extension . PHP_EOL . '   * node--foo' . $extension . PHP_EOL . '   * node--&lt;script type=&quot;text/javascript&quot;&gt;alert(&#039;yo&#039;);&lt;/script&gt;' . $extension . PHP_EOL . '   * node--3--full' . $extension . PHP_EOL . '   * node--3' . $extension . PHP_EOL . '   * node--page--full' . $extension . PHP_EOL . '   * node--page' . $extension . PHP_EOL . '   * node--full' . $extension . PHP_EOL . '   x node' . $extension, $output, 'Suggested template files found in order and base template shown as current template.');
 
@@ -83,7 +83,7 @@ public function testTwigDebugMarkup() {
     $this->resetAll();
 
     $build = $builder->view($node);
-    $output = $renderer->renderRoot($build);
+    $output = (string) $renderer->renderRoot($build);
     $this->assertStringNotContainsString('<!-- THEME DEBUG -->', $output, 'Twig debug markup not found in theme output when debug is disabled.');
   }
 
diff --git a/web/core/modules/system/tests/src/Functional/Theme/TwigTransTest.php b/web/core/modules/system/tests/src/Functional/Theme/TwigTransTest.php
index 6b7d74da7beb894c089f06de18bd1f0ba1a9a4a9..a5516a94912d2141c9e6224f13da9ee0d67dea44 100644
--- a/web/core/modules/system/tests/src/Functional/Theme/TwigTransTest.php
+++ b/web/core/modules/system/tests/src/Functional/Theme/TwigTransTest.php
@@ -182,7 +182,7 @@ protected function assertTwigTransTags(): void {
     // Makes sure https://www.drupal.org/node/2489024 doesn't happen without
     // twig debug.
     // Ensure that running php code inside a Twig trans is not possible.
-    $this->assertSession()->pageTextNotContains(pi());
+    $this->assertSession()->pageTextNotContains((string) pi());
   }
 
   /**
diff --git a/web/core/modules/system/tests/src/FunctionalJavascript/ModuleFilterTest.php b/web/core/modules/system/tests/src/FunctionalJavascript/ModuleFilterTest.php
index 02115807ddd85e489a95e86f9526ecf79b26dc3f..308fa70a84c9417757561c98894e18ac04c11c7e 100644
--- a/web/core/modules/system/tests/src/FunctionalJavascript/ModuleFilterTest.php
+++ b/web/core/modules/system/tests/src/FunctionalJavascript/ModuleFilterTest.php
@@ -10,6 +10,7 @@
  * Tests the JavaScript functionality of the module filter.
  *
  * @group system
+ * @group #slow
  */
 class ModuleFilterTest extends WebDriverTestBase {
 
diff --git a/web/core/modules/system/tests/src/FunctionalJavascript/System/DateFormatTest.php b/web/core/modules/system/tests/src/FunctionalJavascript/System/DateFormatTest.php
index f7113a619da67ef6688aefa3b6eb76eb4c5049dd..0bc84181d1059fa2766600b16149609af1e3fde7 100644
--- a/web/core/modules/system/tests/src/FunctionalJavascript/System/DateFormatTest.php
+++ b/web/core/modules/system/tests/src/FunctionalJavascript/System/DateFormatTest.php
@@ -51,9 +51,9 @@ public function testDateFormatXss() {
     ]);
     $date_format->save();
     $this->drupalGet('admin/config/regional/date-time');
-    $assert->assertEscaped('<script>alert("XSS");</script>', 'The date format was properly escaped');
+    $assert->assertEscaped('<script>alert("XSS");</script>');
     $this->drupalGet('admin/config/regional/date-time/formats/manage/xss_short');
-    $assert->assertEscaped('<script>alert("XSS");</script>', 'The date format was properly escaped');
+    $assert->assertEscaped('<script>alert("XSS");</script>');
 
     // Add a new date format with HTML in it.
     $this->drupalGet('admin/config/regional/date-time/formats/add');
diff --git a/web/core/modules/system/tests/src/Kernel/Extension/ModuleHandlerTest.php b/web/core/modules/system/tests/src/Kernel/Extension/ModuleHandlerTest.php
index d9b213f45a722c88c9c6757c049b4e334151822a..09718581e4c3614a4cc179ae82d39c213603751c 100644
--- a/web/core/modules/system/tests/src/Kernel/Extension/ModuleHandlerTest.php
+++ b/web/core/modules/system/tests/src/Kernel/Extension/ModuleHandlerTest.php
@@ -324,6 +324,8 @@ public function testModuleStreamWrappers() {
     file_exists('dummy://');
     $stream_wrappers = \Drupal::service('stream_wrapper_manager')->getWrappers();
     $this->assertTrue(isset($stream_wrappers['dummy']));
+    $this->assertTrue(isset($stream_wrappers['dummy1']));
+    $this->assertTrue(isset($stream_wrappers['dummy2']));
   }
 
   /**
diff --git a/web/core/modules/taxonomy/migrations/d6_taxonomy_term.yml b/web/core/modules/taxonomy/migrations/d6_taxonomy_term.yml
index 497d7e7e8dbbe6a6b50fad9eeda1f2cba1af8266..bebb262ebdb7d1d4b6759fbeb271709529ae46fd 100644
--- a/web/core/modules/taxonomy/migrations/d6_taxonomy_term.yml
+++ b/web/core/modules/taxonomy/migrations/d6_taxonomy_term.yml
@@ -8,8 +8,9 @@ source:
   plugin: d6_taxonomy_term
 process:
   # If you are using this file to build a custom migration consider removing
-  # the tid field to allow incremental migrations.
+  # the tid and revision_id fields to allow incremental migrations.
   tid: tid
+  revision_id: tid
   vid:
     plugin: migration_lookup
     migration: d6_taxonomy_vocabulary
diff --git a/web/core/modules/taxonomy/migrations/d7_taxonomy_term.yml b/web/core/modules/taxonomy/migrations/d7_taxonomy_term.yml
index 163dd454409d419698e76799b38599bff5e753ae..f7dcfa2dc5e410ff7902b6bfe577a8618a42bded 100644
--- a/web/core/modules/taxonomy/migrations/d7_taxonomy_term.yml
+++ b/web/core/modules/taxonomy/migrations/d7_taxonomy_term.yml
@@ -9,8 +9,9 @@ source:
   plugin: d7_taxonomy_term
 process:
   # If you are using this file to build a custom migration consider removing
-  # the tid field to allow incremental migrations.
+  # the tid and revision_id fields to allow incremental migrations.
   tid: tid
+  revision_id: tid
   vid:
     plugin: migration_lookup
     migration: d7_taxonomy_vocabulary
diff --git a/web/core/modules/telephone/tests/src/Functional/TelephoneFieldTest.php b/web/core/modules/telephone/tests/src/Functional/TelephoneFieldTest.php
index 6ef20bc9f062e06f25ae45ee49e84e1a24370a47..ebb5e60015f8235c35530e16e0c4675f0464664f 100644
--- a/web/core/modules/telephone/tests/src/Functional/TelephoneFieldTest.php
+++ b/web/core/modules/telephone/tests/src/Functional/TelephoneFieldTest.php
@@ -91,7 +91,7 @@ protected function setUp(): void {
   public function testTelephoneWidget() {
     $this->drupalGet('node/add/article');
     $this->assertSession()->fieldValueEquals("field_telephone[0][value]", '');
-    $this->assertSession()->elementAttributeContains('css', 'input[name="field_telephone[0][value]"]', 'maxlength', TelephoneItem::MAX_LENGTH);
+    $this->assertSession()->elementAttributeContains('css', 'input[name="field_telephone[0][value]"]', 'maxlength', (string) TelephoneItem::MAX_LENGTH);
     $this->assertSession()->responseContains('placeholder="123-456-7890"');
   }
 
diff --git a/web/core/modules/toolbar/js/toolbar.anti-flicker.js b/web/core/modules/toolbar/js/toolbar.anti-flicker.js
index 43946ba8dc647e470811c7ce98dc2109654734f1..b5e368df257c793bbbeddb04331e80178d88af2a 100644
--- a/web/core/modules/toolbar/js/toolbar.anti-flicker.js
+++ b/web/core/modules/toolbar/js/toolbar.anti-flicker.js
@@ -63,7 +63,7 @@
       if (userButtonMinWidth) {
         const userButtonStyle = document.createElement('style');
         userButtonStyle.textContent = `
-        #toolbar-item-user {min-width: ${userButtonMinWidth}.px;}`;
+        #toolbar-item-user {min-width: ${userButtonMinWidth}px;}`;
         document.querySelector('head').appendChild(userButtonStyle);
       }
     }
diff --git a/web/core/modules/tour/tests/src/Functional/TourTestBase.php b/web/core/modules/tour/tests/src/Functional/TourTestBase.php
index 6fabf4c7ec2a2e073e1bc986142cff8186213a6d..80ccd424dd1a19d59547bd754ddc619ce8aae41c 100644
--- a/web/core/modules/tour/tests/src/Functional/TourTestBase.php
+++ b/web/core/modules/tour/tests/src/Functional/TourTestBase.php
@@ -2,7 +2,6 @@
 
 namespace Drupal\Tests\tour\Functional;
 
-use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Tests\BrowserTestBase;
 
 /**
@@ -61,7 +60,7 @@ public function assertTourTips(array $tips = [], bool $expectEmpty = FALSE) {
     foreach ($tips as $tip) {
       if (!empty($tip['data-id'])) {
         $elements = $this->getSession()->getPage()->findAll('css', '#' . $tip['data-id']);
-        $this->assertCount(1, $elements, new FormattableMarkup('Found corresponding page element for tour tip with id #%data-id', ['%data-id' => $tip['data-id']]));
+        $this->assertCount(1, $elements, sprintf('Found corresponding page element for tour tip with id #%s', $tip['data-id']));
       }
       elseif (!empty($tip['data-class'])) {
         $elements = $this->getSession()->getPage()->findAll('css', '.' . $tip['data-class']);
diff --git a/web/core/modules/tracker/tests/src/Functional/TrackerTest.php b/web/core/modules/tracker/tests/src/Functional/TrackerTest.php
index 8c2f82af4aedf2df3e357e92cc5b1a5293e7738c..106c09f746f0b86a5e4de8fd46e249674d7ea9c1 100644
--- a/web/core/modules/tracker/tests/src/Functional/TrackerTest.php
+++ b/web/core/modules/tracker/tests/src/Functional/TrackerTest.php
@@ -269,19 +269,19 @@ public function testTrackerHistoryMetadata() {
 
     // Verify that the history metadata is updated.
     $this->drupalGet('activity');
-    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), $node->get('comment')->last_comment_timestamp);
+    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), (int) $node->get('comment')->last_comment_timestamp);
     $this->drupalGet('activity/' . $this->user->id());
-    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), $node->get('comment')->last_comment_timestamp);
+    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), (int) $node->get('comment')->last_comment_timestamp);
     $this->drupalGet('user/' . $this->user->id() . '/activity');
-    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), $node->get('comment')->last_comment_timestamp);
+    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), (int) $node->get('comment')->last_comment_timestamp);
 
     // Log out, now verify that the metadata is still there, but the library is
     // not.
     $this->drupalLogout();
     $this->drupalGet('activity');
-    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), $node->get('comment')->last_comment_timestamp, FALSE);
+    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), (int) $node->get('comment')->last_comment_timestamp, FALSE);
     $this->drupalGet('user/' . $this->user->id() . '/activity');
-    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), $node->get('comment')->last_comment_timestamp, FALSE);
+    $this->assertHistoryMetadata($node->id(), $node->getChangedTime(), (int) $node->get('comment')->last_comment_timestamp, FALSE);
   }
 
   /**
@@ -459,7 +459,7 @@ public function testTrackerAdminUnpublish() {
    * indicators, as well as the "x new" replies link to the tracker.
    * We do this in JavaScript to prevent breaking the render cache.
    *
-   * @param int $node_id
+   * @param string|int $node_id
    *   A node ID, that must exist as a data-history-node-id attribute
    * @param int $node_timestamp
    *   A node timestamp, that must exist as a data-history-node-timestamp
@@ -472,7 +472,7 @@ public function testTrackerAdminUnpublish() {
    *
    * @internal
    */
-  public function assertHistoryMetadata(int $node_id, int $node_timestamp, int $node_last_comment_timestamp, bool $library_is_present = TRUE): void {
+  public function assertHistoryMetadata(string|int $node_id, int $node_timestamp, int $node_last_comment_timestamp, bool $library_is_present = TRUE): void {
     $settings = $this->getDrupalSettings();
     $this->assertSame($library_is_present, isset($settings['ajaxPageState']) && in_array('tracker/history', explode(',', $settings['ajaxPageState']['libraries'])), 'drupal.tracker-history library is present.');
     $this->assertSession()->elementsCount('xpath', '//table/tbody/tr/td[@data-history-node-id="' . $node_id . '" and @data-history-node-timestamp="' . $node_timestamp . '"]', 1);
diff --git a/web/core/modules/update/tests/src/Functional/UpdateSemverTestBaselineTrait.php b/web/core/modules/update/tests/src/Functional/UpdateSemverTestBaselineTrait.php
index b9b86fd6a451d2b3d3d26709819bd7b22882a476..ef2a965c4b146af198fc6cb30d30650f4316036a 100644
--- a/web/core/modules/update/tests/src/Functional/UpdateSemverTestBaselineTrait.php
+++ b/web/core/modules/update/tests/src/Functional/UpdateSemverTestBaselineTrait.php
@@ -121,8 +121,8 @@ public function testMajorUpdateAvailable() {
           $this->refreshUpdateStatus([$this->updateProject => '9']);
           $this->standardTests();
           $this->assertUpdateTableTextNotContains('Security update required!');
-          $this->assertUpdateTableElementContains(Link::fromTextAndUrl('9.0.0', Url::fromUri("http://example.com/{$this->updateProject}-9-0-0-release"))->toString());
-          $this->assertUpdateTableElementContains(Link::fromTextAndUrl('Release notes', Url::fromUri("http://example.com/{$this->updateProject}-9-0-0-release"))->toString());
+          $this->assertUpdateTableElementContains((string) Link::fromTextAndUrl('9.0.0', Url::fromUri("http://example.com/{$this->updateProject}-9-0-0-release"))->toString());
+          $this->assertUpdateTableElementContains((string) Link::fromTextAndUrl('Release notes', Url::fromUri("http://example.com/{$this->updateProject}-9-0-0-release"))->toString());
           $this->assertUpdateTableTextNotContains('Up to date');
           $this->assertUpdateTableTextContains('Not supported!');
           $this->assertUpdateTableTextContains('Recommended version:');
diff --git a/web/core/modules/user/src/Plugin/EntityReferenceSelection/UserSelection.php b/web/core/modules/user/src/Plugin/EntityReferenceSelection/UserSelection.php
index b3a616c3dc2d67fe262d16c6296ab7aa0eef6b81..d9a9f54fddfafc0fefb4a14e895479d12d0d8cbc 100644
--- a/web/core/modules/user/src/Plugin/EntityReferenceSelection/UserSelection.php
+++ b/web/core/modules/user/src/Plugin/EntityReferenceSelection/UserSelection.php
@@ -117,6 +117,9 @@ public function buildConfigurationForm(array $form, FormStateInterface $form_sta
         '_none' => $this->t('- None -'),
         'role' => $this->t('User role'),
       ],
+      // Use a form process callback to build #ajax property properly and also
+      // to avoid code duplication.
+      // @see \Drupal\Core\Field\Plugin\Field\FieldType\EntityReferenceItem::fieldSettingsAjaxProcess()
       '#ajax' => TRUE,
       '#limit_validation_errors' => [],
       '#default_value' => $configuration['filter']['type'],
diff --git a/web/core/modules/user/tests/src/Functional/UserLoginHttpTest.php b/web/core/modules/user/tests/src/Functional/UserLoginHttpTest.php
index 3e018ae11c5075d120541e2d34f2879041d9e352..0a4273d236e6083d1d4b1019565045efde134d92 100644
--- a/web/core/modules/user/tests/src/Functional/UserLoginHttpTest.php
+++ b/web/core/modules/user/tests/src/Functional/UserLoginHttpTest.php
@@ -130,7 +130,7 @@ protected function doTestLogin($format) {
 
     $login_status_url = $this->getLoginStatusUrlString($format);
     $response = $client->get($login_status_url);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_OUT);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_OUT);
 
     // Flooded.
     $this->config('user.flood')
@@ -183,7 +183,7 @@ protected function doTestLogin($format) {
 
     $response = $this->loginRequest($name, $pass, $format);
     $this->assertEquals(200, $response->getStatusCode());
-    $result_data = $this->serializer->decode($response->getBody(), $format);
+    $result_data = $this->serializer->decode((string) $response->getBody(), $format);
     $this->assertEquals($name, $result_data['current_user']['name']);
     $this->assertEquals($account->id(), $result_data['current_user']['uid']);
     $this->assertEquals($account->getRoles(), $result_data['current_user']['roles']);
@@ -192,16 +192,16 @@ protected function doTestLogin($format) {
     // Logging in while already logged in results in a 403 with helpful message.
     $response = $this->loginRequest($name, $pass, $format);
     $this->assertSame(403, $response->getStatusCode());
-    $this->assertSame(['message' => 'This route can only be accessed by anonymous users.'], $this->serializer->decode($response->getBody(), $format));
+    $this->assertSame(['message' => 'This route can only be accessed by anonymous users.'], $this->serializer->decode((string) $response->getBody(), $format));
 
     $response = $client->get($login_status_url, ['cookies' => $this->cookies]);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_IN);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_IN);
 
     $response = $this->logoutRequest($format, $logout_token);
     $this->assertEquals(204, $response->getStatusCode());
 
     $response = $client->get($login_status_url, ['cookies' => $this->cookies]);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_OUT);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_OUT);
 
     $this->resetFlood();
   }
@@ -315,7 +315,7 @@ public function doTestGlobalLoginFloodControl(string $format): void {
 
     // IP limit has reached to its limit. Even valid user credentials will fail.
     $response = $this->loginRequest($user->getAccountName(), $user->passRaw, $format);
-    $this->assertHttpResponseWithMessage($response, '403', 'Access is blocked because of IP based flood prevention.', $format);
+    $this->assertHttpResponseWithMessage($response, 403, 'Access is blocked because of IP based flood prevention.', $format);
     $last_log = $database->select('watchdog', 'w')
       ->fields('w', ['message'])
       ->condition('type', 'user')
@@ -392,7 +392,7 @@ public function doTestPerUserLoginFloodControl($format): void {
 
       // A successful login will reset the per-user flood control count.
       $response = $this->loginRequest($user1->getAccountName(), $user1->passRaw, $format);
-      $result_data = $this->serializer->decode($response->getBody(), $format);
+      $result_data = $this->serializer->decode((string) $response->getBody(), $format);
       $this->logoutRequest($format, $result_data['logout_token']);
 
       // Try 3 failed logins for user 1, they will not trigger flood control.
@@ -475,7 +475,7 @@ public function doTestLogoutCsrfProtection(string $format): void {
 
     $response = $this->loginRequest($name, $pass, $format);
     $this->assertEquals(200, $response->getStatusCode());
-    $result_data = $this->serializer->decode($response->getBody(), $format);
+    $result_data = $this->serializer->decode((string) $response->getBody(), $format);
 
     $logout_token = $result_data['logout_token'];
 
@@ -487,7 +487,7 @@ public function doTestLogoutCsrfProtection(string $format): void {
 
     // Ensure still logged in.
     $response = $client->get($login_status_url, ['cookies' => $this->cookies]);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_IN);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_IN);
 
     // Try with an incorrect token.
     $response = $this->logoutRequest($format, 'not-the-correct-token');
@@ -495,7 +495,7 @@ public function doTestLogoutCsrfProtection(string $format): void {
 
     // Ensure still logged in.
     $response = $client->get($login_status_url, ['cookies' => $this->cookies]);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_IN);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_IN);
 
     // Try a logout request with correct token.
     $response = $this->logoutRequest($format, $logout_token);
@@ -503,7 +503,7 @@ public function doTestLogoutCsrfProtection(string $format): void {
 
     // Ensure actually logged out.
     $response = $client->get($login_status_url, ['cookies' => $this->cookies]);
-    $this->assertHttpResponse($response, 200, UserAuthenticationController::LOGGED_OUT);
+    $this->assertHttpResponse($response, 200, (string) UserAuthenticationController::LOGGED_OUT);
   }
 
   /**
diff --git a/web/core/modules/user/tests/src/Functional/Views/HandlerFieldUserNameTest.php b/web/core/modules/user/tests/src/Functional/Views/HandlerFieldUserNameTest.php
index 62ce4a08d616a89bc79f520ec39585fd7246a9ca..ff330bd5346041adb4c8e33d36ff5fc67bbd0143 100644
--- a/web/core/modules/user/tests/src/Functional/Views/HandlerFieldUserNameTest.php
+++ b/web/core/modules/user/tests/src/Functional/Views/HandlerFieldUserNameTest.php
@@ -44,12 +44,12 @@ public function testUserName() {
     $anon_name = $this->config('user.settings')->get('anonymous');
     $view->result[0]->_entity->setUsername('');
     $view->result[0]->_entity->uid->value = 0;
-    $render = $renderer->executeInRenderContext(new RenderContext(), function () use ($view) {
+    $render = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($view) {
       return $view->field['name']->advancedRender($view->result[0]);
     });
     $this->assertStringContainsString($anon_name, $render, 'For user 0 it should use the default anonymous name by default.');
 
-    $render = $renderer->executeInRenderContext(new RenderContext(), function () use ($view, $new_user) {
+    $render = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($view, $new_user) {
       return $view->field['name']->advancedRender($view->result[$new_user->id()]);
     });
     $this->assertStringContainsString($new_user->getDisplayName(), $render, 'If link to user is checked the username should be part of the output.');
@@ -57,7 +57,7 @@ public function testUserName() {
 
     $view->field['name']->options['link_to_user'] = FALSE;
     $view->field['name']->options['type'] = 'string';
-    $render = $renderer->executeInRenderContext(new RenderContext(), function () use ($view, $new_user) {
+    $render = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($view, $new_user) {
       return $view->field['name']->advancedRender($view->result[$new_user->id()]);
     });
     $this->assertEquals($new_user->getDisplayName(), $render, 'If the user is not linked the username should be printed out for a normal user.');
@@ -77,7 +77,7 @@ public function testNoAdditionalFields() {
     $username = $this->randomMachineName();
     $view->result[0]->_entity->setUsername($username);
     $view->result[0]->_entity->uid->value = 1;
-    $render = $renderer->executeInRenderContext(new RenderContext(), function () use ($view) {
+    $render = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($view) {
       return $view->field['name']->advancedRender($view->result[0]);
     });
     $this->assertStringContainsString($username, $render, 'If link to user is checked the username should be part of the output.');
diff --git a/web/core/modules/user/tests/src/Unit/Views/Argument/RolesRidTest.php b/web/core/modules/user/tests/src/Unit/Views/Argument/RolesRidTest.php
index 7e5bebfbf2e4ec7fef6f98751050c36f1e3b69e5..f46b8932033a166785bf2a7e8deb799538ead682 100644
--- a/web/core/modules/user/tests/src/Unit/Views/Argument/RolesRidTest.php
+++ b/web/core/modules/user/tests/src/Unit/Views/Argument/RolesRidTest.php
@@ -32,7 +32,7 @@ public function testTitleQuery() {
     ], 'user_role');
 
     // Creates a stub entity storage;
-    $role_storage = $this->getMockForAbstractClass('Drupal\Core\Entity\EntityStorageInterface');
+    $role_storage = $this->createMock('Drupal\Core\Entity\EntityStorageInterface');
     $role_storage->expects($this->any())
       ->method('loadMultiple')
       ->willReturnMap([
diff --git a/web/core/modules/views/js/base.js b/web/core/modules/views/js/base.js
index 31a0147c4c0fe8c776412b804d9bfbeeaf01826c..f844ddb9366faeb652c9949b84ccc44de197544f 100644
--- a/web/core/modules/views/js/base.js
+++ b/web/core/modules/views/js/base.js
@@ -106,7 +106,7 @@
     const chars = ['#', '?', '&'];
     for (let i = 0; i < chars.length; i++) {
       if (href.includes(chars[i])) {
-        href = href.substr(0, href.indexOf(chars[i]));
+        href = href.substring(0, href.indexOf(chars[i]));
       }
     }
     return href;
diff --git a/web/core/modules/views/src/Plugin/views/cache/CachePluginBase.php b/web/core/modules/views/src/Plugin/views/cache/CachePluginBase.php
index d372baedc2050d7c670c97a2925b3b17e84de228..6cd39aa1a31cdf959ee77e1ab7960a677af17200 100644
--- a/web/core/modules/views/src/Plugin/views/cache/CachePluginBase.php
+++ b/web/core/modules/views/src/Plugin/views/cache/CachePluginBase.php
@@ -146,7 +146,7 @@ public function cacheGet($type) {
             // Load entities for each result.
             $this->view->query->loadEntities($this->view->result);
             $this->view->total_rows = $cache->data['total_rows'];
-            $this->view->setCurrentPage($cache->data['current_page'], TRUE);
+            $this->view->setCurrentPage($cache->data['current_page']);
             $this->view->execute_time = 0;
             return TRUE;
           }
diff --git a/web/core/modules/views/src/Plugin/views/display/DisplayPluginBase.php b/web/core/modules/views/src/Plugin/views/display/DisplayPluginBase.php
index ef24bb6eee649d0994c9e751152bffcb7ac4369e..dd2014e86a986ab12b1e79f3e4ff380b2930f3b2 100644
--- a/web/core/modules/views/src/Plugin/views/display/DisplayPluginBase.php
+++ b/web/core/modules/views/src/Plugin/views/display/DisplayPluginBase.php
@@ -2171,7 +2171,7 @@ protected function getMoreUrl() {
    * {@inheritdoc}
    */
   public function render() {
-    $rows = (!empty($this->view->result) || $this->view->style_plugin->evenEmpty()) ? $this->view->style_plugin->render($this->view->result) : [];
+    $rows = (!empty($this->view->result) || $this->view->style_plugin->evenEmpty()) ? $this->view->style_plugin->render() : [];
 
     $element = [
       '#theme' => $this->themeFunctions(),
diff --git a/web/core/modules/views/src/Plugin/views/filter/Combine.php b/web/core/modules/views/src/Plugin/views/filter/Combine.php
index bffce7a8962c2b61ff98c36dbb361ecc5d16a63a..439888273817a182ce816ce0c2fc7ef341168594 100644
--- a/web/core/modules/views/src/Plugin/views/filter/Combine.php
+++ b/web/core/modules/views/src/Plugin/views/filter/Combine.php
@@ -210,7 +210,8 @@ protected function opNotLike($expression) {
 
   protected function opRegex($expression) {
     $placeholder = $this->placeholder();
-    $this->query->addWhereExpression($this->options['group'], "$expression REGEXP $placeholder", [$placeholder => $this->value]);
+    $operator = $this->getConditionOperator('REGEXP');
+    $this->query->addWhereExpression($this->options['group'], "$expression $operator $placeholder", [$placeholder => $this->value]);
   }
 
   protected function opEmpty($expression) {
diff --git a/web/core/modules/views/src/Plugin/views/filter/NumericFilter.php b/web/core/modules/views/src/Plugin/views/filter/NumericFilter.php
index 2e34e069cf18f15c94ab472f6e1776a4d8e42b1e..68612c8b203e65e2440b4453b6635efd5d7a851e 100644
--- a/web/core/modules/views/src/Plugin/views/filter/NumericFilter.php
+++ b/web/core/modules/views/src/Plugin/views/filter/NumericFilter.php
@@ -420,15 +420,18 @@ public function acceptExposedInput($input) {
       return TRUE;
     }
 
-    // rewrite the input value so that it's in the correct format so that
+    // Rewrite the input value so that it's in the correct format so that
     // the parent gets the right data.
-    if (!empty($this->options['expose']['identifier'])) {
-      $value = &$input[$this->options['expose']['identifier']];
-      if (!is_array($value)) {
-        $value = [
-          'value' => $value,
-        ];
-      }
+    $key = $this->isAGroup() ? 'group_info' : 'expose';
+    if (empty($this->options[$key]['identifier'])) {
+      // Invalid identifier configuration. Value can't be resolved.
+      return FALSE;
+    }
+    $value = &$input[$this->options[$key]['identifier']];
+    if (!is_array($value)) {
+      $value = [
+        'value' => $value,
+      ];
     }
 
     $rc = parent::acceptExposedInput($input);
diff --git a/web/core/modules/views/src/ViewExecutable.php b/web/core/modules/views/src/ViewExecutable.php
index 673721a301c3c08afba9d764f172050209f28f9c..b76f10ea7d2accddb3d1fa865f8718f255623433 100644
--- a/web/core/modules/views/src/ViewExecutable.php
+++ b/web/core/modules/views/src/ViewExecutable.php
@@ -1956,17 +1956,6 @@ public function getUrl($args = NULL, $display_id = NULL) {
 
     if (!isset($args)) {
       $args = $this->args;
-
-      // Exclude arguments that were computed, not passed on the URL.
-      $position = 0;
-      if (!empty($this->argument)) {
-        foreach ($this->argument as $argument) {
-          if (!empty($argument->is_default)) {
-            unset($args[$position]);
-          }
-          $position++;
-        }
-      }
     }
 
     $path = $this->getPath();
diff --git a/web/core/modules/views/tests/modules/views_test_config/test_views/views.view.test_argument_default_node_with_page.yml b/web/core/modules/views/tests/modules/views_test_config/test_views/views.view.test_argument_default_node_with_page.yml
new file mode 100644
index 0000000000000000000000000000000000000000..0d1739a220cdd590a150492d78440c1dae90f866
--- /dev/null
+++ b/web/core/modules/views/tests/modules/views_test_config/test_views/views.view.test_argument_default_node_with_page.yml
@@ -0,0 +1,243 @@
+langcode: en
+status: true
+dependencies:
+  config:
+    - node.type.page
+  module:
+    - node
+    - user
+id: test_argument_default_node_with_page
+label: 'Test argument_default node with page'
+module: views
+description: ''
+tag: ''
+base_table: node_field_data
+base_field: nid
+display:
+  default:
+    id: default
+    display_title: Default
+    display_plugin: default
+    position: 0
+    display_options:
+      title: 'Test argument_default node'
+      fields:
+        title:
+          id: title
+          table: node_field_data
+          field: title
+          relationship: none
+          group_type: group
+          admin_label: ''
+          plugin_id: field
+          label: ''
+          exclude: false
+          alter:
+            alter_text: false
+            text: ''
+            make_link: false
+            path: ''
+            absolute: false
+            external: false
+            replace_spaces: false
+            path_case: none
+            trim_whitespace: false
+            alt: ''
+            rel: ''
+            link_class: ''
+            prefix: ''
+            suffix: ''
+            target: ''
+            nl2br: false
+            max_length: 0
+            word_boundary: true
+            ellipsis: true
+            more_link: false
+            more_link_text: ''
+            more_link_path: ''
+            strip_tags: false
+            trim: false
+            preserve_tags: ''
+            html: false
+          element_type: ''
+          element_class: ''
+          element_label_type: ''
+          element_label_class: ''
+          element_label_colon: true
+          element_wrapper_type: ''
+          element_wrapper_class: ''
+          element_default_classes: true
+          empty: ''
+          hide_empty: false
+          empty_zero: false
+          hide_alter_empty: true
+          click_sort_column: value
+          type: string
+          settings:
+            link_to_entity: true
+          group_column: value
+          group_columns: {  }
+          group_rows: true
+          delta_limit: 0
+          delta_offset: 0
+          delta_reversed: false
+          delta_first_last: false
+          multi_type: separator
+          separator: ', '
+          field_api_classes: false
+      pager:
+        type: none
+        options:
+          offset: 0
+          items_per_page: null
+      exposed_form:
+        type: basic
+        options:
+          submit_button: Apply
+          reset_button: false
+          reset_button_label: Reset
+          exposed_sorts_label: 'Sort by'
+          expose_sort_order: true
+          sort_asc_label: Asc
+          sort_desc_label: Desc
+      access:
+        type: perm
+        options:
+          perm: 'access content'
+      cache:
+        type: tag
+        options: {  }
+      empty: {  }
+      sorts:
+        title:
+          id: title
+          table: node_field_data
+          field: title
+          relationship: none
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          entity_field: title
+          plugin_id: standard
+          order: DESC
+          expose:
+            label: ''
+          exposed: false
+      arguments:
+        nid:
+          id: nid
+          table: node_field_data
+          field: nid
+          relationship: none
+          group_type: group
+          admin_label: ''
+          entity_type: node
+          entity_field: nid
+          plugin_id: node_nid
+          default_action: default
+          exception:
+            value: all
+            title_enable: false
+            title: All
+          title_enable: false
+          title: ''
+          default_argument_type: node
+          default_argument_options: {  }
+          summary_options:
+            base_path: ''
+            count: true
+            override: false
+            items_per_page: 25
+          summary:
+            sort_order: asc
+            number_of_records: 0
+            format: default_summary
+          specify_validation: false
+          validate:
+            type: none
+            fail: 'not found'
+          validate_options: {  }
+          break_phrase: false
+          not: false
+      filters:
+        status:
+          id: status
+          table: node_field_data
+          field: status
+          entity_type: node
+          entity_field: status
+          plugin_id: boolean
+          value: '1'
+          group: 1
+          expose:
+            operator: ''
+        type:
+          id: type
+          table: node_field_data
+          field: type
+          entity_type: node
+          entity_field: type
+          plugin_id: bundle
+          value:
+            page: page
+      style:
+        type: default
+      row:
+        type: fields
+      query:
+        type: views_query
+        options:
+          query_comment: ''
+          disable_sql_rewrite: false
+          distinct: false
+          replica: false
+          query_tags: {  }
+      relationships: {  }
+      use_more: true
+      use_more_always: true
+      use_more_text: more
+      header: {  }
+      footer: {  }
+      display_extenders: {  }
+    cache_metadata:
+      max-age: -1
+      contexts:
+        - 'languages:language_content'
+        - 'languages:language_interface'
+        - url
+        - 'user.node_grants:view'
+        - user.permissions
+      tags: {  }
+  block_1:
+    id: block_1
+    display_title: Block
+    display_plugin: block
+    position: 1
+    display_options:
+      display_extenders: {  }
+    cache_metadata:
+      max-age: -1
+      contexts:
+        - 'languages:language_content'
+        - 'languages:language_interface'
+        - url
+        - 'user.node_grants:view'
+        - user.permissions
+      tags: {  }
+  page_1:
+    id: page_1
+    display_title: Page
+    display_plugin: page
+    position: 2
+    display_options:
+      display_extenders: {  }
+      path: test-argument-default/%
+    cache_metadata:
+      max-age: -1
+      contexts:
+        - 'languages:language_content'
+        - 'languages:language_interface'
+        - url
+        - 'user.node_grants:view'
+        - user.permissions
+      tags: {  }
diff --git a/web/core/modules/views/tests/src/Functional/Handler/AreaTest.php b/web/core/modules/views/tests/src/Functional/Handler/AreaTest.php
index 62cdcee36ee0b97f35a9979ca40a14a27feff08c..9c4f6c2ffe4bea8668945cf77d97d99a4ffcfed2 100644
--- a/web/core/modules/views/tests/src/Functional/Handler/AreaTest.php
+++ b/web/core/modules/views/tests/src/Functional/Handler/AreaTest.php
@@ -128,7 +128,7 @@ public function testRenderAreaToken() {
 
     // Test we have the site:name token in the output.
     $output = $view->preview();
-    $output = $this->container->get('renderer')->renderRoot($output);
+    $output = (string) $this->container->get('renderer')->renderRoot($output);
     $expected = \Drupal::token()->replace('[site:name]');
     $this->assertStringContainsString($expected, $output);
   }
diff --git a/web/core/modules/views/tests/src/Functional/Handler/FieldWebTest.php b/web/core/modules/views/tests/src/Functional/Handler/FieldWebTest.php
index fcd0e0ead9270a8446e54511feb76b0425aab326..d55853dbc81360ca6b86a4642e328f6a99cb3796 100644
--- a/web/core/modules/views/tests/src/Functional/Handler/FieldWebTest.php
+++ b/web/core/modules/views/tests/src/Functional/Handler/FieldWebTest.php
@@ -2,7 +2,6 @@
 
 namespace Drupal\Tests\views\Functional\Handler;
 
-use Drupal\Component\Render\FormattableMarkup;
 use Drupal\Component\Utility\Html;
 use Drupal\Component\Utility\UrlHelper;
 use Drupal\Core\Render\RenderContext;
@@ -235,7 +234,7 @@ public function testAlterUrl() {
     // Tests that the suffix/prefix appears on the output.
     $id_field->options['alter']['prefix'] = $prefix = $this->randomMachineName();
     $id_field->options['alter']['suffix'] = $suffix = $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, $prefix);
@@ -243,7 +242,7 @@ public function testAlterUrl() {
     unset($id_field->options['alter']['prefix']);
     unset($id_field->options['alter']['suffix']);
 
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, $path, 'Make sure that the path is part of the output');
@@ -256,28 +255,28 @@ public function testAlterUrl() {
 
       $expected_result = Url::fromRoute('entity.node.canonical', ['node' => '123'], ['absolute' => $absolute])->toString();
       $alter['absolute'] = $absolute;
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString($result, $expected_result);
 
       $expected_result = Url::fromRoute('entity.node.canonical', ['node' => '123'], ['fragment' => 'foo', 'absolute' => $absolute])->toString();
       $alter['path'] = 'node/123#foo';
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString($result, $expected_result);
 
       $expected_result = Url::fromRoute('entity.node.canonical', ['node' => '123'], ['query' => ['foo' => NULL], 'absolute' => $absolute])->toString();
       $alter['path'] = 'node/123?foo';
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString($result, $expected_result);
 
       $expected_result = Url::fromRoute('entity.node.canonical', ['node' => '123'], ['query' => ['foo' => 'bar', 'bar' => 'baz'], 'absolute' => $absolute])->toString();
       $alter['path'] = 'node/123?foo=bar&bar=baz';
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString(Html::decodeEntities($result), Html::decodeEntities($expected_result));
@@ -286,14 +285,14 @@ public function testAlterUrl() {
       // $expected_result = Url::fromRoute('entity.node.canonical', ['node' => '123'], ['query' => ['foo' => NULL], 'fragment' => 'bar', 'absolute' => $absolute])->toString();
       $expected_result = Url::fromUserInput('/node/123', ['query' => ['foo' => NULL], 'fragment' => 'bar', 'absolute' => $absolute])->toString();
       $alter['path'] = 'node/123?foo#bar';
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString(Html::decodeEntities($result), Html::decodeEntities($expected_result));
 
       $expected_result = Url::fromRoute('<front>', [], ['absolute' => $absolute])->toString();
       $alter['path'] = '<front>';
-      $result = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+      $result = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
         return $id_field->theme($row);
       });
       $this->assertSubString($result, $expected_result);
@@ -302,12 +301,12 @@ public function testAlterUrl() {
     // Tests the replace spaces with dashes feature.
     $id_field->options['alter']['replace_spaces'] = TRUE;
     $id_field->options['alter']['path'] = $path = $this->randomMachineName() . ' ' . $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, str_replace(' ', '-', $path));
     $id_field->options['alter']['replace_spaces'] = FALSE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     // The URL has a space in it, so to check we have to decode the URL output.
@@ -317,7 +316,7 @@ public function testAlterUrl() {
     // Switch on the external flag should output an external URL as well.
     $id_field->options['alter']['external'] = TRUE;
     $id_field->options['alter']['path'] = $path = 'www.example.com';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, 'http://www.example.com');
@@ -325,7 +324,7 @@ public function testAlterUrl() {
     // Setup a not external URL, which shouldn't lead to an external URL.
     $id_field->options['alter']['external'] = FALSE;
     $id_field->options['alter']['path'] = $path = 'www.example.com';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertNotSubString($output, 'http://www.example.com');
@@ -333,19 +332,19 @@ public function testAlterUrl() {
     // Tests the transforming of the case setting.
     $id_field->options['alter']['path'] = $path = $this->randomMachineName();
     $id_field->options['alter']['path_case'] = 'none';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, $path);
 
     // Switch to uppercase and lowercase.
     $id_field->options['alter']['path_case'] = 'upper';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, strtoupper($path));
     $id_field->options['alter']['path_case'] = 'lower';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, strtolower($path));
@@ -353,13 +352,13 @@ public function testAlterUrl() {
     // Switch to ucfirst and ucwords.
     $id_field->options['alter']['path_case'] = 'ucfirst';
     $id_field->options['alter']['path'] = 'drupal has a great community';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, UrlHelper::encodePath('Drupal has a great community'));
 
     $id_field->options['alter']['path_case'] = 'ucwords';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $this->assertSubString($output, UrlHelper::encodePath('Drupal Has A Great Community'));
@@ -368,7 +367,7 @@ public function testAlterUrl() {
     // Tests the link_class setting and see whether it actually exists in the
     // output.
     $id_field->options['alter']['link_class'] = $class = $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $elements = $this->xpathContent($output, '//a[contains(@class, :class)]', [':class' => $class]);
@@ -378,7 +377,7 @@ public function testAlterUrl() {
 
     // Tests the alt setting.
     $id_field->options['alter']['alt'] = $rel = $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $elements = $this->xpathContent($output, '//a[contains(@title, :alt)]', [':alt' => $rel]);
@@ -387,7 +386,7 @@ public function testAlterUrl() {
 
     // Tests the rel setting.
     $id_field->options['alter']['rel'] = $rel = $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $elements = $this->xpathContent($output, '//a[contains(@rel, :rel)]', [':rel' => $rel]);
@@ -396,7 +395,7 @@ public function testAlterUrl() {
 
     // Tests the target setting.
     $id_field->options['alter']['target'] = $target = $this->randomMachineName();
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($id_field, $row) {
       return $id_field->theme($row);
     });
     $elements = $this->xpathContent($output, '//a[contains(@target, :target)]', [':target' => $target]);
@@ -420,13 +419,13 @@ public function testFieldClasses() {
     // Setup some kind of label by default.
     $id_field->options['label'] = $this->randomMachineName();
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertEmpty($this->xpathContent($output, '//div[contains(@class, :class)]', [':class' => 'field-content']));
     $this->assertEmpty($this->xpathContent($output, '//div[contains(@class, :class)]', [':class' => 'field__label']));
 
     $id_field->options['element_default_classes'] = TRUE;
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     // Per default the label and the element of the field are spans.
     $this->assertNotEmpty($this->xpathContent($output, '//span[contains(@class, :class)]', [':class' => 'field-content']));
     $this->assertNotEmpty($this->xpathContent($output, '//span[contains(@class, :class)]', [':class' => 'views-label']));
@@ -442,13 +441,13 @@ public function testFieldClasses() {
       // Set a custom wrapper element css class.
       $id_field->options['element_wrapper_class'] = $random_class;
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertNotEmpty($this->xpathContent($output, "//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
 
       // Set no custom css class.
       $id_field->options['element_wrapper_class'] = '';
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertEmpty($this->xpathContent($output, "//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
       $this->assertNotEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]/{$element_type}"));
     }
@@ -462,13 +461,13 @@ public function testFieldClasses() {
       // Set a custom label element css class.
       $id_field->options['element_label_class'] = $random_class;
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertNotEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
 
       // Set no custom css class.
       $id_field->options['element_label_class'] = '';
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
       $this->assertNotEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//{$element_type}"));
     }
@@ -482,13 +481,13 @@ public function testFieldClasses() {
       // Set a custom label element css class.
       $id_field->options['element_class'] = $random_class;
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertNotEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//div[contains(@class, views-field)]//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
 
       // Set no custom css class.
       $id_field->options['element_class'] = '';
       $output = $view->preview();
-      $output = $renderer->renderRoot($output);
+      $output = (string) $renderer->renderRoot($output);
       $this->assertEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//div[contains(@class, views-field)]//{$element_type}[contains(@class, :class)]", [':class' => $random_class]));
       $this->assertNotEmpty($this->xpathContent($output, "//li[contains(@class, views-row)]//div[contains(@class, views-field)]//{$element_type}"));
     }
@@ -534,7 +533,7 @@ public function testTextRendering() {
     $row = $view->result[0];
 
     $name_field->options['alter']['strip_tags'] = TRUE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $random_text, 'Find text without html if stripping of views field output is enabled.');
@@ -542,14 +541,14 @@ public function testTextRendering() {
 
     // Tests preserving of html tags.
     $name_field->options['alter']['preserve_tags'] = '<div>';
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $random_text, 'Find text without html if stripping of views field output is enabled but a div is allowed.');
     $this->assertSubString($output, $html_text, 'Find text with the html if stripping of views field output is enabled but a div is allowed.');
 
     $name_field->options['alter']['strip_tags'] = FALSE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $random_text, 'Find text without html if stripping of views field output is disabled.');
@@ -560,7 +559,7 @@ public function testTextRendering() {
     $views_test_data_name = $row->views_test_data_name;
     $row->views_test_data_name = '  ' . $views_test_data_name . '     ';
     $name_field->options['alter']['trim_whitespace'] = TRUE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
 
@@ -568,7 +567,7 @@ public function testTextRendering() {
     $this->assertNotSubString($output, $row->views_test_data_name, 'Make sure the untrimmed text can be found if trimming is enabled.');
 
     $name_field->options['alter']['trim_whitespace'] = FALSE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $views_test_data_name, 'Make sure the trimmed text can be found if trimming is disabled.');
@@ -583,14 +582,14 @@ public function testTextRendering() {
     $name_field->options['alter']['max_length'] = 5;
     $trimmed_name = mb_substr($row->views_test_data_name, 0, 5);
 
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $trimmed_name, "Make sure the trimmed output ($trimmed_name) appears in the rendered output ($output).");
     $this->assertNotSubString($output, $row->views_test_data_name, "Make sure the untrimmed value ($row->views_test_data_name) shouldn't appear in the rendered output ($output).");
 
     $name_field->options['alter']['max_length'] = 9;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $trimmed_name, "Make sure the untrimmed ($trimmed_name) output appears in the rendered output  ($output).");
@@ -632,15 +631,15 @@ public function testTextRendering() {
 
     foreach ($tuples as $tuple) {
       $row->views_test_data_name = $tuple['value'];
-      $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+      $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
         return $name_field->advancedRender($row);
       });
 
       if ($tuple['trimmed']) {
-        $this->assertNotSubString($output, $tuple['value'], new FormattableMarkup('The untrimmed value (@untrimmed) should not appear in the trimmed output (@output).', ['@untrimmed' => $tuple['value'], '@output' => $output]));
+        $this->assertNotSubString($output, $tuple['value'], "The untrimmed value ({$tuple['value']}) should not appear in the trimmed output ($output).");
       }
       if (!empty($tuple['trimmed_value'])) {
-        $this->assertSubString($output, $tuple['trimmed_value'], new FormattableMarkup('The trimmed value (@trimmed) should appear in the trimmed output (@output).', ['@trimmed' => $tuple['trimmed_value'], '@output' => $output]));
+        $this->assertSubString($output, $tuple['trimmed_value'], "The trimmed value ({$tuple['trimmed_value']}) should appear in the trimmed output ($output).");
       }
     }
 
@@ -651,14 +650,14 @@ public function testTextRendering() {
     $name_field->options['alter']['more_link_text'] = $more_text = $this->randomMachineName();
     $name_field->options['alter']['more_link_path'] = $more_path = $this->randomMachineName();
 
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, $more_text, 'Make sure a read more text is displayed if the output got trimmed');
     $this->assertNotEmpty($this->xpathContent($output, '//a[contains(@href, :path)]', [':path' => $more_path]), 'Make sure the read more link points to the right destination.');
 
     $name_field->options['alter']['more_link'] = FALSE;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertNotSubString($output, $more_text, 'Make sure no read more text appears.');
@@ -667,12 +666,12 @@ public function testTextRendering() {
     // Check for the ellipses.
     $row->views_test_data_name = $this->randomMachineName(8);
     $name_field->options['alter']['max_length'] = 5;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertSubString($output, '…', 'An ellipsis should appear if the output is trimmed');
     $name_field->options['alter']['max_length'] = 10;
-    $output = $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
+    $output = (string) $renderer->executeInRenderContext(new RenderContext(), function () use ($name_field, $row) {
       return $name_field->advancedRender($row);
     });
     $this->assertNotSubString($output, '…', 'No ellipsis should appear if the output is not trimmed');
diff --git a/web/core/modules/views/tests/src/Functional/Plugin/ArgumentDefaultTest.php b/web/core/modules/views/tests/src/Functional/Plugin/ArgumentDefaultTest.php
index dfca6c0d37210e9ee7ad58d687e006a3f9335016..3ee85dc35f4cffe408dbf76cfc47d9164860c0f7 100644
--- a/web/core/modules/views/tests/src/Functional/Plugin/ArgumentDefaultTest.php
+++ b/web/core/modules/views/tests/src/Functional/Plugin/ArgumentDefaultTest.php
@@ -28,6 +28,7 @@ class ArgumentDefaultTest extends ViewTestBase {
     'test_argument_default_current_user',
     'test_argument_default_node',
     'test_argument_default_query_param',
+    'test_argument_default_node_with_page',
   ];
 
   /**
@@ -190,4 +191,33 @@ public function testArgumentDefaultQueryParameter() {
     $this->assertEquals('page', $view->argument['type']->getDefaultArgument());
   }
 
+  /**
+   * Tests the more line generation if a default argument is provided.
+   */
+  public function testArgumentDefaultUrlGeneration() {
+    // Create a user that has permission to place a view block.
+    $permissions = [
+      'administer views',
+      'administer blocks',
+      'bypass node access',
+      'access user profiles',
+      'view all revisions',
+    ];
+    $views_admin = $this->drupalCreateUser($permissions);
+    $this->drupalLogin($views_admin);
+
+    // Create nodes where should show themselves again as view block.
+    $node_type = NodeType::create(['type' => 'page', 'name' => 'Page']);
+    $node_type->save();
+    $node = Node::create(['title' => 'Test node 1', 'type' => 'page']);
+    $node->save();
+
+    // Place the block, visit the page that displays the block, and check that
+    // the more link takes the node ID into account and does not ignore
+    // the default argument.
+    $this->drupalPlaceBlock("views_block:test_argument_default_node_with_page-block_1", ['id' => 'view_block_id']);
+    $this->drupalGet('node/' . $node->id());
+    $this->assertSession()->linkByHrefExists('/test-argument-default/' . $node->id());
+  }
+
 }
diff --git a/web/core/modules/views/tests/src/Functional/Plugin/DisplayPageWebTest.php b/web/core/modules/views/tests/src/Functional/Plugin/DisplayPageWebTest.php
index b2ca2f10315ea2f3bd6393936224fb8b58c9fff0..e68cf66b7596618243afed639f51a6ba4642b592 100644
--- a/web/core/modules/views/tests/src/Functional/Plugin/DisplayPageWebTest.php
+++ b/web/core/modules/views/tests/src/Functional/Plugin/DisplayPageWebTest.php
@@ -63,13 +63,13 @@ public function testArguments() {
     $this->assertSession()->statusCodeEquals(200);
     $this->assertCacheContexts(['languages:language_interface', 'route', 'theme', 'url']);
     $this->assertSession()->elementsCount('xpath', $xpath, 1);
-    $this->assertSession()->elementTextEquals('xpath', $xpath, 1);
+    $this->assertSession()->elementTextEquals('xpath', $xpath, '1');
 
     // Ensure that just the filtered entry is returned.
     $this->drupalGet('test_route_with_suffix/1/suffix');
     $this->assertSession()->statusCodeEquals(200);
     $this->assertSession()->elementsCount('xpath', $xpath, 1);
-    $this->assertSession()->elementTextEquals('xpath', $xpath, 1);
+    $this->assertSession()->elementTextEquals('xpath', $xpath, '1');
 
     // Ensure that no result is returned.
     $this->drupalGet('test_route_with_suffix_and_argument/1/suffix/2');
@@ -80,13 +80,13 @@ public function testArguments() {
     $this->drupalGet('test_route_with_suffix_and_argument/1/suffix/1');
     $this->assertSession()->statusCodeEquals(200);
     $this->assertSession()->elementsCount('xpath', $xpath, 1);
-    $this->assertSession()->elementTextEquals('xpath', $xpath, 1);
+    $this->assertSession()->elementTextEquals('xpath', $xpath, '1');
 
     // Ensure that just the filtered entry is returned.
     $this->drupalGet('test_route_with_long_argument/1');
     $this->assertSession()->statusCodeEquals(200);
     $this->assertSession()->elementsCount('xpath', $xpath, 1);
-    $this->assertSession()->elementTextEquals('xpath', $xpath, 1);
+    $this->assertSession()->elementTextEquals('xpath', $xpath, '1');
   }
 
   /**
diff --git a/web/core/modules/views/tests/src/Functional/Plugin/DisplayTest.php b/web/core/modules/views/tests/src/Functional/Plugin/DisplayTest.php
index 97d2ffc2c91b824d100f22600878a1e07e0ea0a5..dd3e2286ba0a50f256f57ea452554493aefc8cda 100644
--- a/web/core/modules/views/tests/src/Functional/Plugin/DisplayTest.php
+++ b/web/core/modules/views/tests/src/Functional/Plugin/DisplayTest.php
@@ -110,7 +110,7 @@ public function testDisplayPlugin() {
     $view->style_plugin->setUsesRowPlugin(FALSE);
 
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
 
     $this->assertStringContainsString('<h1></h1>', $output, 'An empty value for test_option found in output.');
 
@@ -119,7 +119,7 @@ public function testDisplayPlugin() {
     $view->save();
 
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
 
     // Test we have our custom <h1> tag in the output of the view.
     $this->assertStringContainsString('<h1>Test option title</h1>', $output, 'The test_option value found in display output title.');
@@ -218,7 +218,7 @@ public function testReadMoreCustomURL() {
     $view->display_handler->setOption('link_url', 'node');
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node', $output, 'The read more link with href "/node" was found.');
 
     // Test more link with leading slash.
@@ -226,7 +226,7 @@ public function testReadMoreCustomURL() {
     $view->display_handler->setOption('link_url', '/node');
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node', $output, 'The read more link with href "/node" was found.');
 
     // Test more link with absolute URL.
@@ -234,7 +234,7 @@ public function testReadMoreCustomURL() {
     $view->display_handler->setOption('link_url', 'http://example.com');
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('http://example.com', $output, 'The read more link with href "http://example.com" was found.');
 
     // Test more link with query parameters in the URL.
@@ -242,7 +242,7 @@ public function testReadMoreCustomURL() {
     $view->display_handler->setOption('link_url', 'node?page=1&foo=bar');
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node?page=1&amp;foo=bar', $output, 'The read more link with href "/node?page=1&foo=bar" was found.');
 
     // Test more link with fragment in the URL.
@@ -250,7 +250,7 @@ public function testReadMoreCustomURL() {
     $view->display_handler->setOption('link_url', 'node#target');
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node#target', $output, 'The read more link with href "/node#target" was found.');
 
     // Test more link with arguments.
@@ -263,7 +263,7 @@ public function testReadMoreCustomURL() {
     $view->setArguments([22]);
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node?date=22&amp;foo=bar', $output, 'The read more link with href "/node?date=22&foo=bar" was found.');
 
     // Test more link with 1 dimension array query parameters with arguments.
@@ -276,7 +276,7 @@ public function testReadMoreCustomURL() {
     $view->setArguments([22]);
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node?f%5B0%5D=foo%3Abar&amp;f%5B1%5D=foo%3A22', $output, 'The read more link with href "/node?f[0]=foo:bar&f[1]=foo:22" was found.');
 
     // Test more link with arguments in path.
@@ -284,7 +284,7 @@ public function testReadMoreCustomURL() {
     $view->setArguments([22]);
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node/22?date=22&amp;foo=bar', $output, 'The read more link with href "/node/22?date=22&foo=bar" was found.');
 
     // Test more link with arguments in fragment.
@@ -292,7 +292,7 @@ public function testReadMoreCustomURL() {
     $view->setArguments([22]);
     $this->executeView($view);
     $output = $view->preview();
-    $output = $renderer->renderRoot($output);
+    $output = (string) $renderer->renderRoot($output);
     $this->assertStringContainsString('/node?date=22&amp;foo=bar#22', $output, 'The read more link with href "/node?date=22&foo=bar#22" was found.');
   }
 
diff --git a/web/core/modules/views/tests/src/Functional/Plugin/PagerTest.php b/web/core/modules/views/tests/src/Functional/Plugin/PagerTest.php
index b9c2d6694538b9784fee646efe9d8d946d34d58e..0d63cfd04e128ebd84093607a1162fa1c2de2b03 100644
--- a/web/core/modules/views/tests/src/Functional/Plugin/PagerTest.php
+++ b/web/core/modules/views/tests/src/Functional/Plugin/PagerTest.php
@@ -386,7 +386,7 @@ public function testRenderNullPager() {
     $view->setAjaxEnabled(TRUE);
     $view->pager = NULL;
     $output = $view->render();
-    $output = \Drupal::service('renderer')->renderRoot($output);
+    $output = (string) \Drupal::service('renderer')->renderRoot($output);
     $this->assertEquals(0, preg_match('/<ul class="pager">/', $output), 'The pager is not rendered.');
   }
 
diff --git a/web/core/modules/views/tests/src/Kernel/Handler/FilterCombineTest.php b/web/core/modules/views/tests/src/Kernel/Handler/FilterCombineTest.php
index ea079c488aa2077566a9c58cc8ae4c20f1473b6c..57a6d6d71d8a0eeca1f81c24dc5bd810607df8fd 100644
--- a/web/core/modules/views/tests/src/Kernel/Handler/FilterCombineTest.php
+++ b/web/core/modules/views/tests/src/Kernel/Handler/FilterCombineTest.php
@@ -98,6 +98,65 @@ public function testFilterCombineContains() {
     $this->assertIdenticalResultset($view, $resultset, $this->columnMap);
   }
 
+  /**
+   * Tests the Combine field filter with the 'regular_expression' operator.
+   */
+  public function testFilterCombineRegEx() {
+    $view = Views::getView('test_view');
+    $view->setDisplay();
+
+    $fields = $view->displayHandlers->get('default')->getOption('fields');
+    $view->displayHandlers->get('default')->overrideOption('fields', $fields + [
+      'job' => [
+        'id' => 'job',
+        'table' => 'views_test_data',
+        'field' => 'job',
+        'relationship' => 'none',
+      ],
+    ]);
+
+    // Change the filtering.
+    $view->displayHandlers->get('default')->overrideOption('filters', [
+      'age' => [
+        'id' => 'combine',
+        'table' => 'views',
+        'field' => 'combine',
+        'relationship' => 'none',
+        'operator' => 'regular_expression',
+        'fields' => [
+          'name',
+          'job',
+        ],
+        'value' => '(ing|write)',
+      ],
+    ]);
+
+    $this->executeView($view);
+    $resultset = [
+      [
+        'name' => 'John',
+        'job' => 'Singer',
+      ],
+      [
+        'name' => 'George',
+        'job' => 'Singer',
+      ],
+      [
+        'name' => 'Ringo',
+        'job' => 'Drummer',
+      ],
+      [
+        'name' => 'Paul',
+        'job' => 'Songwriter',
+      ],
+      [
+        'name' => 'Ginger',
+        'job' => NULL,
+      ],
+    ];
+    $this->assertIdenticalResultset($view, $resultset, $this->columnMap);
+  }
+
   /**
    * Tests the Combine field filter with the 'word' operator.
    */
diff --git a/web/core/modules/views/tests/src/Unit/Controller/ViewAjaxControllerTest.php b/web/core/modules/views/tests/src/Unit/Controller/ViewAjaxControllerTest.php
index 6ef1a332fef51881f405fe3a00bff6d4a2652511..aff3dc6696daa9ee5d82dded1023d2fa8518ed5b 100644
--- a/web/core/modules/views/tests/src/Unit/Controller/ViewAjaxControllerTest.php
+++ b/web/core/modules/views/tests/src/Unit/Controller/ViewAjaxControllerTest.php
@@ -336,7 +336,7 @@ public function testAjaxViewWithPager() {
       ->disableOriginalConstructor()
       ->getMock();
     $display_handler->expects($this->once())
-      ->method('setOption', '0')
+      ->method('setOption')
       ->with($this->equalTo('pager_element'));
 
     $display_collection = $this->getMockBuilder('Drupal\views\DisplayPluginCollection')
diff --git a/web/core/modules/views/tests/src/Unit/Plugin/field/FieldPluginBaseTest.php b/web/core/modules/views/tests/src/Unit/Plugin/field/FieldPluginBaseTest.php
index a7899a91431e437e57f3fb7fb3ea8adc2c6deccd..df4c653103aa82e8fc7ef1e48138d7da8a6b96b2 100644
--- a/web/core/modules/views/tests/src/Unit/Plugin/field/FieldPluginBaseTest.php
+++ b/web/core/modules/views/tests/src/Unit/Plugin/field/FieldPluginBaseTest.php
@@ -4,8 +4,8 @@
 
 namespace Drupal\Tests\views\Unit\Plugin\field;
 
-use Drupal\Core\GeneratedUrl;
 use Drupal\Core\Entity\EntityInterface;
+use Drupal\Core\GeneratedUrl;
 use Drupal\Core\Language\Language;
 use Drupal\Core\Render\Markup;
 use Drupal\Core\Url;
@@ -15,11 +15,11 @@
 use Drupal\Tests\UnitTestCase;
 use Drupal\views\Plugin\views\field\FieldPluginBase;
 use Drupal\views\ResultRow;
+use Prophecy\Prophet;
 use Symfony\Component\DependencyInjection\ContainerBuilder;
 use Symfony\Component\HttpFoundation\Request;
 use Symfony\Component\HttpFoundation\RequestStack;
 use Symfony\Component\Routing\Route;
-use Prophecy\Prophet;
 
 /**
  * @coversDefaultClass \Drupal\views\Plugin\views\field\FieldPluginBase
@@ -640,18 +640,13 @@ public function providerTestRenderAsExternalLinkWithPathAndTokens() {
   /**
    * Sets up a test field.
    *
-   * @return \Drupal\Tests\views\Unit\Plugin\field\FieldPluginBaseTestField|\PHPUnit\Framework\MockObject\MockObject
+   * @return \Drupal\Tests\views\Unit\Plugin\field\FieldPluginBaseTestField
    *   The test field.
    */
   protected function setupTestField(array $options = []) {
-    /** @var \Drupal\Tests\views\Unit\Plugin\field\FieldPluginBaseTestField $field */
-    $field = $this->getMockBuilder('Drupal\Tests\views\Unit\Plugin\field\FieldPluginBaseTestField')
-      ->addMethods(['l'])
-      ->setConstructorArgs([$this->configuration, $this->pluginId, $this->pluginDefinition])
-      ->getMock();
+    $field = new FieldPluginBaseTestField($this->configuration, $this->pluginId, $this->pluginDefinition);
     $field->init($this->executable, $this->display, $options);
     $field->setLinkGenerator($this->linkGenerator);
-
     return $field;
   }
 
diff --git a/web/core/modules/views/tests/src/Unit/Plugin/views/filter/NumericFilterTest.php b/web/core/modules/views/tests/src/Unit/Plugin/views/filter/NumericFilterTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..6752f91065804878312c93a079a36e3d25f1be81
--- /dev/null
+++ b/web/core/modules/views/tests/src/Unit/Plugin/views/filter/NumericFilterTest.php
@@ -0,0 +1,118 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\views\Unit\Plugin\views\filter;
+
+use Drupal\Tests\UnitTestCase;
+use Drupal\views\Plugin\views\display\DisplayPluginBase;
+use Drupal\views\Plugin\views\filter\NumericFilter;
+use Drupal\views\ViewExecutable;
+
+/**
+ * @coversDefaultClass \Drupal\views\Plugin\views\filter\NumericFilter
+ * @group Views
+ */
+class NumericFilterTest extends UnitTestCase {
+
+  /**
+   * Tests the acceptExposedInput method.
+   *
+   * @covers ::acceptExposedInput
+   * @dataProvider provideAcceptExposedInput
+   */
+  public function testAcceptExposedInput($options, $value, $expected): void {
+    $plugin_definition = [
+      'title' => $this->randomMachineName(),
+    ];
+
+    $plugin = new NumericFilter([], 'numeric', $plugin_definition);
+    $translation_stub = $this->getStringTranslationStub();
+    $plugin->setStringTranslation($translation_stub);
+
+    $view = $this->prophesize(ViewExecutable::class)->reveal();
+    $display = $this->prophesize(DisplayPluginBase::class)->reveal();
+    $view->display_handler = $display;
+    $plugin->init($view, $view->display_handler, $options);
+
+    $this->assertSame($expected, $plugin->acceptExposedInput($value));
+  }
+
+  /**
+   * Data provider for testAcceptExposedInput test.
+   *
+   * @return array[]
+   *   The test cases.
+   */
+  public function provideAcceptExposedInput(): array {
+    // [$options, $value, $expected]
+    return [
+      // Not exposed by default. Bypass parsing and return true.
+      'defaults' => [[], [], TRUE],
+      'exposed but not configured' => [
+        [
+          'exposed' => TRUE,
+          'expose' => [],
+          'group_info' => [],
+        ],
+        [],
+        FALSE,
+      ],
+      // Exposed but not grouped.
+      'exposed not grouped - missing value' => [
+        [
+          'exposed' => TRUE,
+          'expose' => ['identifier' => 'test_id'],
+        ],
+        [],
+        TRUE,
+      ],
+      'exposed not grouped - wrong group config' => [
+        [
+          'exposed' => TRUE,
+          'group_info' => ['identifier' => 'test_id'],
+        ],
+        ['test_id' => ['value' => 1]],
+        // Wrong identifier configured.
+        FALSE,
+      ],
+      'exposed not grouped' => [
+        [
+          'exposed' => TRUE,
+          'expose' => ['identifier' => 'test_id'],
+        ],
+        ['test_id' => ['value' => 1]],
+        TRUE,
+      ],
+      // Exposed and grouped.
+      'exposed grouped - missing value' => [
+        [
+          'exposed' => TRUE,
+          'is_grouped' => TRUE,
+          'group_info' => ['identifier' => 'test_id'],
+        ],
+        [],
+        TRUE,
+      ],
+      'exposed grouped - wrong group config' => [
+        [
+          'exposed' => TRUE,
+          'is_grouped' => TRUE,
+          'expose' => ['identifier' => 'test_id'],
+        ],
+        ['test_id' => ['value' => 1]],
+        FALSE,
+      ],
+      'exposed grouped' => [
+        [
+          'exposed' => TRUE,
+          'is_grouped' => TRUE,
+          'group_info' => ['identifier' => 'test_id'],
+        ],
+        ['test_id' => ['value' => 1]],
+        TRUE,
+      ],
+    ];
+  }
+
+}
diff --git a/web/core/modules/views_ui/css/views_ui.admin.theme.css b/web/core/modules/views_ui/css/views_ui.admin.theme.css
index 63112b3cd70b4472b1ba7dab0e4d28c4e73a97c2..2d8fe5081f9b9a296499530230fc0a4777f4a4f8 100644
--- a/web/core/modules/views_ui/css/views_ui.admin.theme.css
+++ b/web/core/modules/views_ui/css/views_ui.admin.theme.css
@@ -568,7 +568,12 @@ td.group-title {
 .views-edit-view {
   margin-bottom: 15px;
 }
-
+.views-edit-view.disabled .views-displays {
+  background-color: #fff4f4;
+}
+.views-edit-view.disabled .views-display-column {
+  background: white;
+}
 /* The contents of the popup dialog on the views edit form. */
 .views-filterable-options .form-type-checkbox {
   padding: 5px 8px;
diff --git a/web/core/modules/views_ui/js/ajax.js b/web/core/modules/views_ui/js/ajax.js
index 5cbd583e3c6300a51bb1ed12bb1267d9b149df19..f534cd6ff93921a6a8a27e9a1a1fd2e7e31a8d53 100644
--- a/web/core/modules/views_ui/js/ajax.js
+++ b/web/core/modules/views_ui/js/ajax.js
@@ -194,7 +194,7 @@
       $(once('views-ajax', '#views-tabset a')).on('click', function () {
         const href = $(this).attr('href');
         // Cut of #views-tabset.
-        const displayId = href.substr(11);
+        const displayId = href.substring(11);
         const viewsPreviewId = document.querySelector(
           '#views-live-preview #preview-display-id',
         );
diff --git a/web/core/modules/views_ui/js/views-admin.js b/web/core/modules/views_ui/js/views-admin.js
index 34edf52d533f7b8ab2d3f0c86666ce31cbcfbe56..4cadec6186b91d61f6745ba5327ee783d4101f74 100644
--- a/web/core/modules/views_ui/js/views-admin.js
+++ b/web/core/modules/views_ui/js/views-admin.js
@@ -221,7 +221,7 @@
         this.target.each(function (i) {
           // Ensure that the maxlength is not exceeded by prepopulating the field.
           const maxlength = $(this).attr('maxlength') - suffix.length;
-          this.value = transliterated.substr(0, maxlength) + suffix;
+          this.value = transliterated.substring(0, maxlength) + suffix;
         });
       },
 
diff --git a/web/core/modules/views_ui/tests/src/Functional/OverrideDisplaysTest.php b/web/core/modules/views_ui/tests/src/Functional/OverrideDisplaysTest.php
index 2dac1a7d1c2a9d405243569eac00178d71a8a475..8208210e051a6553eb6150e5788e4d01857ef576 100644
--- a/web/core/modules/views_ui/tests/src/Functional/OverrideDisplaysTest.php
+++ b/web/core/modules/views_ui/tests/src/Functional/OverrideDisplaysTest.php
@@ -6,6 +6,7 @@
  * Tests that displays can be correctly overridden via the user interface.
  *
  * @group views_ui
+ * @group #slow
  */
 class OverrideDisplaysTest extends UITestBase {
 
diff --git a/web/core/modules/workspaces/css/workspaces.off-canvas.css b/web/core/modules/workspaces/css/workspaces.off-canvas.css
index 76a9b1f7bbfea173907af37fdc3389eb9a2dfd65..152ed043f71e4b7473a18774264abdb2cb346027 100644
--- a/web/core/modules/workspaces/css/workspaces.off-canvas.css
+++ b/web/core/modules/workspaces/css/workspaces.off-canvas.css
@@ -23,6 +23,12 @@
   }
 }
 
+@media (max-width: 47.9375rem) {
+  #drupal-off-canvas-wrapper.workspaces-dialog + .ui-dialog .ui-dialog-content {
+    max-height: unset !important; /* Override the max-height added by JS. */
+  }
+}
+
 /**
    * The Workspace UI hides the titlebar, but we need to show and correctly
    * position the close button that is nested within it.
diff --git a/web/core/modules/workspaces/css/workspaces.off-canvas.pcss.css b/web/core/modules/workspaces/css/workspaces.off-canvas.pcss.css
index 053ff32989c9f3efd86cf0d65542ee4fb85f7b4f..fe43b71d6dd60bdb02178c90af9a443fc1b51b41 100644
--- a/web/core/modules/workspaces/css/workspaces.off-canvas.pcss.css
+++ b/web/core/modules/workspaces/css/workspaces.off-canvas.pcss.css
@@ -18,6 +18,12 @@
     }
   }
 
+  & + .ui-dialog .ui-dialog-content {
+    @media (--workspace-layout-small) {
+      max-height: unset !important; /* Override the max-height added by JS. */
+    }
+  }
+
   /**
    * The Workspace UI hides the titlebar, but we need to show and correctly
    * position the close button that is nested within it.
diff --git a/web/core/modules/workspaces/src/WorkspaceListBuilder.php b/web/core/modules/workspaces/src/WorkspaceListBuilder.php
index 0ed2d9f130e78df168deaaf784629d1033327657..958f6f60d7c16b1ff8abe187a463e1d8bf109ba2 100644
--- a/web/core/modules/workspaces/src/WorkspaceListBuilder.php
+++ b/web/core/modules/workspaces/src/WorkspaceListBuilder.php
@@ -10,6 +10,7 @@
 use Drupal\Core\Entity\EntityTypeInterface;
 use Drupal\Core\Render\RendererInterface;
 use Drupal\Core\Url;
+use Drupal\user\UserInterface;
 use Symfony\Component\DependencyInjection\ContainerInterface;
 
 /**
@@ -121,7 +122,9 @@ public function buildRow(EntityInterface $entity) {
           '#url' => $entity->toUrl(),
         ],
       ],
-      'owner' => $entity->getOwner()->getDisplayName(),
+      'owner' => (($owner = $entity->getOwner()) && $owner instanceof UserInterface)
+        ? $owner->getDisplayName()
+        : $this->t('N/A'),
     ];
     $row['data'] = $row['data'] + parent::buildRow($entity);
 
diff --git a/web/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php b/web/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
index 524413750b58a639c7aaa3482a556ce7bc73a4c5..72931bbccf39e615e55d3671a190ae03b6b941e1 100644
--- a/web/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
+++ b/web/core/modules/workspaces/tests/src/Functional/WorkspaceTest.php
@@ -297,6 +297,16 @@ public function testWorkspaceList() {
     // 'Live' is no longer the active workspace, so it's 'Switch to Live'
     // operation should be visible now.
     $assert_session->linkExists('Switch to Live');
+
+    // Delete any of the workspace owners and visit workspaces listing.
+    $this->drupalLogin($this->editor2);
+    user_cancel([], $this->editor1->id(), 'user_cancel_reassign');
+    $user = \Drupal::service('entity_type.manager')->getStorage('user')->load($this->editor1->id());
+    $user->delete();
+    $this->drupalGet('/admin/config/workflow/workspaces');
+    $this->assertSession()->pageTextContains('Summer event');
+    $summer_event_workspace_row = $page->find('css', 'table tbody tr:nth-of-type(3)');
+    $this->assertEquals('N/A', $summer_event_workspace_row->find('css', 'td:nth-of-type(2)')->getText());
   }
 
   /**
diff --git a/web/core/package.json b/web/core/package.json
index f8d3e0ad87f54008c0e6a95d736f4314a347c351..fd3392674702900c7a718b5ba994d817365632d2 100644
--- a/web/core/package.json
+++ b/web/core/package.json
@@ -118,5 +118,6 @@
     "last 1 ChromeAndroid version",
     "last 1 Samsung version",
     "Firefox ESR"
-  ]
+  ],
+  "packageManager": "yarn@1.22.22"
 }
diff --git a/web/core/phpcs.xml.dist b/web/core/phpcs.xml.dist
index ec7fb9dc49aef26a8a5cdd232a9d57f312e05aaa..2a03880002d7bca22dbbe23fca92bea0b58bbab3 100644
--- a/web/core/phpcs.xml.dist
+++ b/web/core/phpcs.xml.dist
@@ -8,6 +8,8 @@
   <exclude-pattern>*/node_modules/*</exclude-pattern>
   <!--Exclude third party code.-->
   <exclude-pattern>./assets/vendor/*</exclude-pattern>
+  <!--Exclude the PHPStan baseline from coding standards.-->
+  <exclude-pattern>./core/.phpstan-baseline.php</exclude-pattern>
   <!-- Exclude third-party code maintained within core that does not follow our standards. -->
   <!-- @todo This rule may be removed when https://www.drupal.org/node/1848264 is resolved. -->
   <exclude-pattern>./core/lib/Drupal/Component/Diff/</exclude-pattern>
diff --git a/web/core/phpstan-baseline.neon b/web/core/phpstan-baseline.neon
deleted file mode 100644
index 845c209c0da661d6d0887794f234d4440ad718b5..0000000000000000000000000000000000000000
--- a/web/core/phpstan-baseline.neon
+++ /dev/null
@@ -1,3623 +0,0 @@
-parameters:
-	ignoreErrors:
-		-
-			message: "#^Variable \\$data_path in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: ../composer/Plugin/Scaffold/Operations/AppendOp.php
-
-		-
-			message: "#^Variable \\$app_root might not be defined\\.$#"
-			count: 1
-			path: assets/scaffold/files/default.settings.php
-
-		-
-			message: "#^Variable \\$site_path might not be defined\\.$#"
-			count: 1
-			path: assets/scaffold/files/default.settings.php
-
-		-
-			message: "#^Variable \\$new_set_index might not be defined\\.$#"
-			count: 1
-			path: includes/form.inc
-
-		-
-			message: """
-				#^Call to deprecated method getFromDriverName\\(\\) of class Drupal\\\\Core\\\\Extension\\\\DatabaseDriverList\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				  DatabaseDriverList\\:\\:get\\(\\) instead, passing a database driver namespace\\.$#
-			"""
-			count: 1
-			path: includes/install.core.inc
-
-		-
-			message: "#^Function install_config_download_translations\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: includes/install.core.inc
-
-		-
-			message: "#^Function install_download_translation\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: includes/install.core.inc
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: includes/theme.inc
-
-		-
-			message: "#^Variable \\$custom_theme might not be defined\\.$#"
-			count: 1
-			path: includes/theme.maintenance.inc
-
-		-
-			message: """
-				#^Call to deprecated method registerLoader\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
-				This method is deprecated and will be removed in
-				            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Component/Annotation/Plugin/Discovery/AnnotatedClassDiscovery.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Component\\\\Datetime\\\\DateTimePlus\\:\\:getTimeZone\\(\\)\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Datetime/DateTimePlus.php
-
-		-
-			message: "#^Variable \\$value might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Datetime/DateTimePlus.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\Component\\\\DependencyInjection\\\\ServiceIdHashTrait in class Drupal\\\\Component\\\\DependencyInjection\\\\Container\\:
-				in drupal\\:9\\.5\\.1 and is removed from drupal\\:11\\.0\\.0\\. Use the
-				  'Drupal\\\\Component\\\\DependencyInjection\\\\ReverseContainer' service instead\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Component/DependencyInjection/Container.php
-
-		-
-			message: "#^Variable \\$x0 might not be defined\\.$#"
-			count: 4
-			path: lib/Drupal/Component/Diff/DiffFormatter.php
-
-		-
-			message: "#^Variable \\$xi in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Diff/DiffFormatter.php
-
-		-
-			message: "#^Variable \\$y0 might not be defined\\.$#"
-			count: 4
-			path: lib/Drupal/Component/Diff/DiffFormatter.php
-
-		-
-			message: "#^Variable \\$yi in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Diff/DiffFormatter.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$in_seq\\.$#"
-			count: 3
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$lcs\\.$#"
-			count: 4
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$seq\\.$#"
-			count: 7
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xchanged\\.$#"
-			count: 6
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xind\\.$#"
-			count: 2
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$xv\\.$#"
-			count: 5
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$ychanged\\.$#"
-			count: 5
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$yind\\.$#"
-			count: 2
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Component\\\\Diff\\\\Engine\\\\DiffEngine\\:\\:\\$yv\\.$#"
-			count: 5
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Variable \\$k might not be defined\\.$#"
-			count: 4
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Variable \\$seps might not be defined\\.$#"
-			count: 3
-			path: lib/Drupal/Component/Diff/Engine/DiffEngine.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$cache_backend_class\\.$#"
-			count: 1
-			path: lib/Drupal/Component/FileCache/NullFileCache.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$cache_backend_configuration\\.$#"
-			count: 1
-			path: lib/Drupal/Component/FileCache/NullFileCache.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$collection\\.$#"
-			count: 1
-			path: lib/Drupal/Component/FileCache/NullFileCache.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Component\\\\FileCache\\\\NullFileCache has an unused parameter \\$prefix\\.$#"
-			count: 1
-			path: lib/Drupal/Component/FileCache/NullFileCache.php
-
-		-
-			message: "#^Method Drupal\\\\Component\\\\Gettext\\\\PoMemoryWriter\\:\\:getHeader\\(\\) should return Drupal\\\\Component\\\\Gettext\\\\PoHeader but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Gettext/PoMemoryWriter.php
-
-		-
-			message: "#^Method Drupal\\\\Component\\\\Gettext\\\\PoMemoryWriter\\:\\:getLangcode\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Gettext/PoMemoryWriter.php
-
-		-
-			message: "#^Variable \\$log_vars might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Component/Gettext/PoStreamReader.php
-
-		-
-			message: "#^Variable \\$permission might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Access/AccessResult.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Access\\\\CheckProvider implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Access/CheckProvider.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Access\\\\CheckProvider\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Access/CheckProvider.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Access\\\\CsrfRequestHeaderAccessCheck\\:\\:applies\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Access/CsrfRequestHeaderAccessCheck.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Executable\\\\ExecutableInterface\\:\\:execute\\(\\) invoked with 1 parameter, 0 required\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Action/ActionBase.php
-
-		-
-			message: "#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Action/ActionManager.php
-
-		-
-			message: "#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Action/ActionManager.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Archiver\\\\ArchiverManager\\:\\:getInstance\\(\\) should return object\\|false but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Archiver/ArchiverManager.php
-
-		-
-			message: "#^Variable \\$group_keys might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Asset/CssCollectionGrouper.php
-
-		-
-			message: "#^Variable \\$group_keys might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Asset/JsCollectionGrouper.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Asset/JsCollectionRenderer.php
-
-		-
-			message: "#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Block/BlockManager.php
-
-		-
-			message: "#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Block/BlockManager.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: lib/Drupal/Core/Cache/ApcuBackend.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Cache\\\\CacheFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Cache/CacheFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\CacheFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Cache/CacheFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\CacheTagsInvalidator\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Cache/CacheTagsInvalidator.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Cache\\\\ChainedFastBackendFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Cache/ChainedFastBackendFactory.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: lib/Drupal/Core/Cache/DatabaseBackend.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Cache/MemoryBackend.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Core\\\\Cache\\\\NullBackend has an unused parameter \\$bin\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Cache/NullBackend.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: lib/Drupal/Core/Cache/PhpBackend.php
-
-		-
-			message: "#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Condition/ConditionManager.php
-
-		-
-			message: "#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Condition/ConditionManager.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 4
-			path: lib/Drupal/Core/Config/DatabaseStorage.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Config/Entity/Query/Condition.php
-
-		-
-			message: "#^Variable \\$theme_list might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Config/ExtensionInstallStorage.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Config\\\\TypedConfigManager\\:\\:replaceVariable\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Config/TypedConfigManager.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Connection.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Connection.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_NULL of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Connection.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_STATEMENT of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 2
-			path: lib/Drupal/Core/Database/Connection.php
-
-		-
-			message: "#^Variable \\$statement might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Database/Connection.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Delete.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Database\\\\Query\\\\Delete\\:\\:execute\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Delete.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Insert.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Merge.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Database\\\\Query\\\\Merge\\:\\:__toString\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Merge.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_STATEMENT of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Select.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Truncate.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Update.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_AFFECTED of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Upsert.php
-
-		-
-			message: "#^Variable \\$affected_rows might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Database/Query/Upsert.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: lib/Drupal/Core/Datetime/DateHelper.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\DependencyInjection\\\\ClassResolver implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/DependencyInjection/ClassResolver.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\DependencyInjection\\\\ClassResolver\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/DependencyInjection/ClassResolver.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\Component\\\\DependencyInjection\\\\ServiceIdHashTrait in class Drupal\\\\Core\\\\DependencyInjection\\\\ContainerBuilder\\:
-				in drupal\\:9\\.5\\.1 and is removed from drupal\\:11\\.0\\.0\\. Use the
-				  'Drupal\\\\Component\\\\DependencyInjection\\\\ReverseContainer' service instead\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/DependencyInjection/ContainerBuilder.php
-
-		-
-			message: """
-				#^Call to deprecated method closing\\(\\) of class Drupal\\\\Component\\\\Diff\\\\WordLevelDiff\\:
-				in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Diff/DiffFormatter.php
-
-		-
-			message: """
-				#^Call to deprecated method orig\\(\\) of class Drupal\\\\Component\\\\Diff\\\\WordLevelDiff\\:
-				in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Diff/DiffFormatter.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\DrupalKernel\\:\\:discoverServiceProviders\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/DrupalKernel.php
-
-		-
-			message: "#^Variable \\$container might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/DrupalKernel.php
-
-		-
-			message: "#^Variable \\$container_definition might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/DrupalKernel.php
-
-		-
-			message: """
-				#^Interface Drupal\\\\Core\\\\DrupalKernelInterface extends deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/DrupalKernelInterface.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityConfirmFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/ContentEntityConfirmFormBase.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:doLoadMultiple\\(\\) should return array\\<Drupal\\\\Core\\\\Entity\\\\EntityInterface\\> but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/ContentEntityNullStorage.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:doSave\\(\\) should return bool\\|int but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/ContentEntityNullStorage.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\ContentEntityNullStorage\\:\\:has\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/ContentEntityNullStorage.php
-
-		-
-			message: "#^Variable \\$current_affected in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/ContentEntityStorageBase.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\Controller\\\\EntityController\\:\\:deleteTitle\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Controller/EntityController.php
-
-		-
-			message: "#^Variable \\$candidate_ids might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Entity/Entity/EntityFormDisplay.php
-
-		-
-			message: "#^Variable \\$string in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/EntityAutocompleteMatcher.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\Entity\\\\EntityBase\\:\\:\\$id\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/EntityBase.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\EntityConfirmFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/EntityConfirmFormBase.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\Entity\\\\EntityDisplayBase\\:\\:\\$_serializedKeys\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Entity/EntityDisplayBase.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Entity\\\\EntityTypeManager implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Entity/EntityTypeManager.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Entity\\\\EntityTypeManager\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Entity/EntityTypeManager.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\KeyValueStore\\\\KeyValueContentEntityStorage\\:\\:createTranslation\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/KeyValueStore/KeyValueContentEntityStorage.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\KeyValueStore\\\\KeyValueContentEntityStorage\\:\\:createWithSampleValues\\(\\) should return Drupal\\\\Core\\\\Entity\\\\FieldableEntityInterface but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/KeyValueStore/KeyValueContentEntityStorage.php
-
-		-
-			message: "#^Variable \\$selected_bundles might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Entity/Plugin/EntityReferenceSelection/DefaultSelection.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Plugin/Validation/Constraint/ReferenceAccessConstraintValidator.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Plugin/Validation/Constraint/ValidReferenceConstraintValidator.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Entity\\\\Query\\\\QueryBase\\:\\:getClass\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Query/QueryBase.php
-
-		-
-			message: "#^Variable \\$next_index_prefix might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Query/Sql/Tables.php
-
-		-
-			message: "#^Variable \\$relationship_specifier might not be defined\\.$#"
-			count: 5
-			path: lib/Drupal/Core/Entity/Query/Sql/Tables.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 2
-			path: lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php
-
-		-
-			message: "#^Variable \\$revision_query might not be defined\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php
-
-		-
-			message: "#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 2
-			path: lib/Drupal/Core/Entity/Sql/SqlContentEntityStorage.php
-
-		-
-			message: "#^Variable \\$initial_storage_value in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Entity/Sql/SqlContentEntityStorageSchema.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: lib/Drupal/Core/EventSubscriber/FinishResponseSubscriber.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\EventSubscriber\\\\KernelDestructionSubscriber implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/EventSubscriber/KernelDestructionSubscriber.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\EventSubscriber\\\\KernelDestructionSubscriber\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/EventSubscriber/KernelDestructionSubscriber.php
-
-		-
-			message: """
-				#^Call to deprecated method getFromDriverName\\(\\) of class Drupal\\\\Core\\\\Extension\\\\DatabaseDriverList\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				  DatabaseDriverList\\:\\:get\\(\\) instead, passing a database driver namespace\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Extension/DatabaseDriverList.php
-
-		-
-			message: "#^Variable \\$minor_version might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Extension/ExtensionVersion.php
-
-		-
-			message: "#^Variable \\$callback in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldDefinition.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Field\\\\FieldItemBase\\:\\:generateSampleValue\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldItemBase.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Field\\\\FieldItemBase\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldItemBase.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Field\\\\FieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldItemList.php
-
-		-
-			message: "#^Variable \\$values might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldItemList.php
-
-		-
-			message: "#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldTypePluginManager.php
-
-		-
-			message: "#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/FieldTypePluginManager.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Field/Plugin/Field/FieldFormatter/TimestampFormatter.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: lib/Drupal/Core/Field/Plugin/Field/FieldType/ChangedItem.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Field/Plugin/Field/FieldType/CreatedItem.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Field\\\\Plugin\\\\Field\\\\FieldType\\\\EntityReferenceItem\\:\\:generateSampleValue\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/Plugin/Field/FieldType/EntityReferenceItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\Field\\\\Plugin\\\\Field\\\\FieldType\\\\NumericItemBase\\:\\:\\$value\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Field/Plugin/Field/FieldType/NumericItemBase.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\FTPExtension\\:\\:\\$connection\\.$#"
-			count: 19
-			path: lib/Drupal/Core/FileTransfer/FTPExtension.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\FileTransfer\\:\\:\\$chroot\\.$#"
-			count: 3
-			path: lib/Drupal/Core/FileTransfer/FileTransfer.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\FileTransfer\\\\FileTransfer\\:\\:__get\\(\\) should return bool\\|string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/FileTransfer/FileTransfer.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\FileTransfer\\\\SSH\\:\\:\\$connection\\.$#"
-			count: 9
-			path: lib/Drupal/Core/FileTransfer/SSH.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: lib/Drupal/Core/Flood/DatabaseBackend.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Form\\\\FormBuilder\\:\\:setInvalidTokenError\\(\\) should return \\$this\\(Drupal\\\\Core\\\\Form\\\\FormBuilder\\) but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormBuilder.php
-
-		-
-			message: "#^Variable \\$form_id in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormBuilder.php
-
-		-
-			message: "#^Variable \\$form in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormCache.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Form\\\\FormValidator\\:\\:setInvalidTokenError\\(\\) should return \\$this\\(Drupal\\\\Core\\\\Form\\\\FormValidator\\) but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormValidator.php
-
-		-
-			message: "#^Variable \\$is_empty_multiple might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormValidator.php
-
-		-
-			message: "#^Variable \\$is_empty_null might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormValidator.php
-
-		-
-			message: "#^Variable \\$is_empty_string might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Form/FormValidator.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/KeyValueStore/KeyValueDatabaseExpirableFactory.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\KeyValueStore\\\\NullStorageExpirable\\:\\:setIfNotExists\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/KeyValueStore/NullStorageExpirable.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\KeyValueStore\\\\NullStorageExpirable\\:\\:setWithExpireIfNotExists\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/KeyValueStore/NullStorageExpirable.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Lock\\\\NullLockBackend\\:\\:wait\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Lock/NullLockBackend.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Logger\\\\LoggerChannelFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Logger/LoggerChannelFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Logger\\\\LoggerChannelFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Logger/LoggerChannelFactory.php
-
-		-
-			message: "#^Variable \\$parent in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Menu/Form/MenuLinkDefaultForm.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Menu\\\\MenuLinkManager\\:\\:getInstance\\(\\) should return object\\|false but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Menu/MenuLinkManager.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Menu\\\\MenuLinkManager\\:\\:menuNameInUse\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Menu/MenuLinkManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Menu/MenuLinkManager.php
-
-		-
-			message: """
-				#^Fetching deprecated class constant RETURN_INSERT_ID of class Drupal\\\\Core\\\\Database\\\\Database\\:
-				in drupal\\:9\\.4\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is no
-				  replacement\\.$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Menu/MenuTreeStorage.php
-
-		-
-			message: "#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Menu/MenuTreeStorage.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Plugin/DefaultPluginManager.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Core\\\\Queue\\\\Memory has an unused parameter \\$name\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Queue/Memory.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Queue\\\\QueueFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Queue/QueueFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Queue\\\\QueueFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Queue/QueueFactory.php
-
-		-
-			message: "#^Variable \\$sort in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Render/Element/RenderElement.php
-
-		-
-			message: "#^Variable \\$output in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Render/MainContent/AjaxRenderer.php
-
-		-
-			message: "#^Variable \\$page_bottom in empty\\(\\) always exists and is always falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Render/MainContent/HtmlRenderer.php
-
-		-
-			message: "#^Variable \\$page_top in empty\\(\\) always exists and is always falsy\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Render/MainContent/HtmlRenderer.php
-
-		-
-			message: "#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Routing/MatcherDumper.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: lib/Drupal/Core/Session/SessionHandler.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Session/SessionManager.php
-
-		-
-			message: "#^Variable \\$current might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Site/SettingsEditor.php
-
-		-
-			message: "#^Variable \\$index might not be defined\\.$#"
-			count: 3
-			path: lib/Drupal/Core/Site/SettingsEditor.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\StackMiddleware\\\\Session\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/StackMiddleware/Session.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\StreamWrapper\\\\StreamWrapperManager implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/StreamWrapper/StreamWrapperManager.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\StreamWrapper\\\\StreamWrapperManager\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/StreamWrapper/StreamWrapperManager.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Template\\\\AttributeValueBase\\:\\:render\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Template/AttributeValueBase.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Core\\\\Template\\\\TwigEnvironment has an unused parameter \\$root\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Template/TwigEnvironment.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: lib/Drupal/Core/Template/TwigPhpStorageCache.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Core\\\\Test\\\\TestRunnerKernel has an unused parameter \\$allow_dumping\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Test/TestRunnerKernel.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Theme\\\\ThemeInitialization\\:\\:resolveStyleSheetPlaceholders\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Theme/ThemeInitialization.php
-
-		-
-			message: "#^Variable \\$candidate might not be defined\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Theme/ThemeManager.php
-
-		-
-			message: "#^Variable \\$theme_engine in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Theme/ThemeManager.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\TypedData\\\\ListDataDefinition\\:\\:setDataType\\(\\) should return static\\(Drupal\\\\Core\\\\TypedData\\\\ListDataDefinition\\) but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/TypedData/ListDataDefinition.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Core\\\\TypedData\\\\TypedData\\:\\:\\$value\\.$#"
-			count: 2
-			path: lib/Drupal/Core/TypedData/TypedData.php
-
-		-
-			message: "#^Variable \\$cache_key in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: lib/Drupal/Core/TypedData/Validation/RecursiveContextualValidator.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Update\\\\UpdateHookRegistryFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Update/UpdateHookRegistryFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Update\\\\UpdateHookRegistryFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Update/UpdateHookRegistryFactory.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Update\\\\UpdateKernel\\:\\:discoverServiceProviders\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Update/UpdateKernel.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Core\\\\Update\\\\UpdateRegistryFactory implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Update/UpdateRegistryFactory.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Core\\\\Update\\\\UpdateRegistryFactory\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: lib/Drupal/Core/Update/UpdateRegistryFactory.php
-
-		-
-			message: "#^Method Drupal\\\\Core\\\\Updater\\\\Module\\:\\:postUpdateTasks\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: lib/Drupal/Core/Updater/Module.php
-
-		-
-			message: "#^Method Drupal\\\\action\\\\Form\\\\ActionFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/action/src/Form/ActionFormBase.php
-
-		-
-			message: "#^Variable \\$position might not be defined\\.$#"
-			count: 4
-			path: modules/block/tests/src/Functional/BlockRenderOrderTest.php
-
-		-
-			message: "#^Variable \\$edit might not be defined\\.$#"
-			count: 1
-			path: modules/block/tests/src/Functional/BlockUiTest.php
-
-		-
-			message: "#^Variable \\$dependency in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/block_content/src/BlockContentAccessControlHandler.php
-
-		-
-			message: "#^Method Drupal\\\\block_content\\\\BlockContentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/block_content/src/BlockContentForm.php
-
-		-
-			message: "#^Method Drupal\\\\block_content\\\\BlockContentTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/block_content/src/BlockContentTypeForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/block_content/tests/src/Functional/BlockContentRevisionsTest.php
-
-		-
-			message: "#^Variable \\$loaded might not be defined\\.$#"
-			count: 9
-			path: modules/block_content/tests/src/Functional/BlockContentRevisionsTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/block_content/tests/src/Functional/BlockContentSaveTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/block_content/tests/src/Kernel/Migrate/d6/MigrateBlockContentTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/block_content/tests/src/Kernel/Migrate/d6/MigrateCustomBlockContentTranslationTest.php
-
-		-
-			message: "#^Variable \\$callable in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/book/src/BookExport.php
-
-		-
-			message: "#^Method Drupal\\\\book\\\\BookOutline\\:\\:nextLink\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/book/src/BookOutline.php
-
-		-
-			message: "#^Method Drupal\\\\book\\\\BookOutline\\:\\:prevLink\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/book/src/BookOutline.php
-
-		-
-			message: "#^Method Drupal\\\\book\\\\Form\\\\BookOutlineForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/book/src/Form/BookOutlineForm.php
-
-		-
-			message: "#^Variable \\$ghs_config_classes in empty\\(\\) always exists and is always falsy\\.$#"
-			count: 1
-			path: modules/ckeditor5/src/Plugin/Validation/Constraint/StyleSensibleElementConstraintValidator.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/comment/src/CommentForm.php
-
-		-
-			message: "#^Method Drupal\\\\comment\\\\CommentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/comment/src/CommentForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/comment/src/CommentStatistics.php
-
-		-
-			message: "#^Method Drupal\\\\comment\\\\CommentTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/comment/src/CommentTypeForm.php
-
-		-
-			message: "#^Variable \\$state might not be defined\\.$#"
-			count: 1
-			path: modules/comment/src/Plugin/migrate/destination/EntityComment.php
-
-		-
-			message: "#^Method Drupal\\\\comment\\\\Plugin\\\\views\\\\field\\\\NodeNewComments\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#"
-			count: 1
-			path: modules/comment/src/Plugin/views/field/NodeNewComments.php
-
-		-
-			message: "#^Variable \\$comment in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/comment/src/Plugin/views/row/Rss.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/comment/tests/src/Functional/CommentBlockTest.php
-
-		-
-			message: "#^Variable \\$position might not be defined\\.$#"
-			count: 1
-			path: modules/comment/tests/src/Functional/CommentBlockTest.php
-
-		-
-			message: "#^Variable \\$comment_values might not be defined\\.$#"
-			count: 1
-			path: modules/comment/tests/src/Functional/CommentLanguageTest.php
-
-		-
-			message: "#^Variable \\$mode_text might not be defined\\.$#"
-			count: 1
-			path: modules/comment/tests/src/Functional/CommentTestBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/comment/tests/src/Functional/CommentTranslationUITest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/comment/tests/src/Functional/Views/DefaultViewRecentCommentsTest.php
-
-		-
-			message: "#^Variable \\$data might not be defined\\.$#"
-			count: 2
-			path: modules/config/src/Form/ConfigSingleImportForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/config_translation/src/FormElement/DateFormat.php
-
-		-
-			message: "#^Method Drupal\\\\contact\\\\ContactFormEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/contact/src/ContactFormEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\contact\\\\Entity\\\\Message\\:\\:getPersonalRecipient\\(\\) should return Drupal\\\\user\\\\UserInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/contact/src/Entity/Message.php
-
-		-
-			message: "#^Method Drupal\\\\contact\\\\MessageForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/contact/src/MessageForm.php
-
-		-
-			message: "#^Variable \\$state in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 3
-			path: modules/content_moderation/src/Form/ContentModerationStateForm.php
-
-		-
-			message: "#^Method Drupal\\\\content_moderation\\\\ModerationInformation\\:\\:getAffectedRevisionTranslation\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/content_moderation/src/ModerationInformation.php
-
-		-
-			message: "#^Method Drupal\\\\content_moderation\\\\ModerationInformation\\:\\:getDefaultRevisionId\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/content_moderation/src/ModerationInformation.php
-
-		-
-			message: "#^Variable \\$checkbox_id might not be defined\\.$#"
-			count: 1
-			path: modules/content_translation/content_translation.admin.inc
-
-		-
-			message: "#^Variable \\$locked_languages might not be defined\\.$#"
-			count: 1
-			path: modules/content_translation/content_translation.admin.inc
-
-		-
-			message: "#^Variable \\$locked_languages might not be defined\\.$#"
-			count: 1
-			path: modules/content_translation/content_translation.module
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/content_translation/src/ContentTranslationHandler.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/content_translation/src/Controller/ContentTranslationController.php
-
-		-
-			message: "#^Variable \\$source_name might not be defined\\.$#"
-			count: 1
-			path: modules/content_translation/src/Controller/ContentTranslationController.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/content_translation/tests/src/Functional/ContentTranslationUITestBase.php
-
-		-
-			message: "#^Variable \\$unrestricted_tab_count might not be defined\\.$#"
-			count: 1
-			path: modules/contextual/tests/src/FunctionalJavascript/EditModeTest.php
-
-		-
-			message: "#^Method Drupal\\\\datetime\\\\Plugin\\\\Field\\\\FieldType\\\\DateTimeFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/datetime/src/Plugin/Field/FieldType/DateTimeFieldItemList.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\datetime\\\\Plugin\\\\Field\\\\FieldType\\\\DateTimeItem\\:\\:\\$date\\.$#"
-			count: 1
-			path: modules/datetime/src/Plugin/Field/FieldType/DateTimeItem.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/datetime/src/Plugin/Field/FieldType/DateTimeItem.php
-
-		-
-			message: "#^Variable \\$date_part_order might not be defined\\.$#"
-			count: 3
-			path: modules/datetime/src/Plugin/Field/FieldWidget/DateTimeDatelistWidget.php
-
-		-
-			message: "#^Variable \\$item in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/datetime/src/Plugin/Validation/Constraint/DateTimeFormatConstraintValidator.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: modules/datetime/tests/src/Functional/DateTimeFieldTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/datetime/tests/src/Kernel/Views/FilterDateTimeTest.php
-
-		-
-			message: "#^Method Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/datetime_range/src/Plugin/Field/FieldType/DateRangeFieldItemList.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeItem\\:\\:\\$end_date\\.$#"
-			count: 1
-			path: modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\datetime_range\\\\Plugin\\\\Field\\\\FieldType\\\\DateRangeItem\\:\\:\\$start_date\\.$#"
-			count: 1
-			path: modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/datetime_range/src/Plugin/Field/FieldType/DateRangeItem.php
-
-		-
-			message: "#^Variable \\$view in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/dblog/dblog.module
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/dblog/tests/src/Functional/DbLogTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/dblog/tests/src/Kernel/DbLogTest.php
-
-		-
-			message: "#^Variable \\$items in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/field/tests/modules/field_test/src/Plugin/Field/FieldFormatter/TestFieldEmptySettingFormatter.php
-
-		-
-			message: "#^Variable \\$items in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/field/tests/modules/field_test/src/Plugin/Field/FieldFormatter/TestFieldMultipleFormatter.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/field/tests/src/Functional/NestedFormTest.php
-
-		-
-			message: "#^Variable \\$values might not be defined\\.$#"
-			count: 1
-			path: modules/field/tests/src/Kernel/FieldAttachStorageTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/field/tests/src/Kernel/Timestamp/TimestampFormatterTest.php
-
-		-
-			message: "#^Variable \\$entity_display might not be defined\\.$#"
-			count: 1
-			path: modules/field_ui/src/Access/FormModeAccessCheck.php
-
-		-
-			message: "#^Variable \\$entity_display might not be defined\\.$#"
-			count: 1
-			path: modules/field_ui/src/Access/ViewModeAccessCheck.php
-
-		-
-			message: "#^Method Drupal\\\\field_ui\\\\FieldUI\\:\\:getOverviewRouteInfo\\(\\) should return Drupal\\\\Core\\\\Url but return statement is missing\\.$#"
-			count: 1
-			path: modules/field_ui/src/FieldUI.php
-
-		-
-			message: "#^Variable \\$updated_columns might not be defined\\.$#"
-			count: 1
-			path: modules/field_ui/src/Form/EntityDisplayFormBase.php
-
-		-
-			message: "#^Variable \\$updated_rows might not be defined\\.$#"
-			count: 2
-			path: modules/field_ui/src/Form/EntityDisplayFormBase.php
-
-		-
-			message: "#^Method Drupal\\\\field_ui\\\\Form\\\\EntityDisplayModeFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/field_ui/src/Form/EntityDisplayModeFormBase.php
-
-		-
-			message: "#^Method Drupal\\\\field_ui\\\\Form\\\\FieldConfigEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/field_ui/src/Form/FieldConfigEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\field_ui\\\\Form\\\\FieldStorageConfigEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/field_ui/src/Form/FieldStorageConfigEditForm.php
-
-		-
-			message: "#^Variable \\$value might not be defined\\.$#"
-			count: 1
-			path: modules/file/file.install
-
-		-
-			message: "#^Variable \\$file_upload in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/file/file.module
-
-		-
-			message: "#^Variable \\$message might not be defined\\.$#"
-			count: 1
-			path: modules/file/file.module
-
-		-
-			message: "#^Variable \\$rows in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/file/src/Plugin/Field/FieldFormatter/TableFormatter.php
-
-		-
-			message: "#^Method Drupal\\\\file\\\\Plugin\\\\Field\\\\FieldType\\\\FileFieldItemList\\:\\:defaultValuesForm\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/file/src/Plugin/Field/FieldType/FileFieldItemList.php
-
-		-
-			message: "#^Method Drupal\\\\file\\\\Plugin\\\\Field\\\\FieldType\\\\FileFieldItemList\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/file/src/Plugin/Field/FieldType/FileFieldItemList.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/file/tests/src/Functional/FileFieldPathTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/file/tests/src/Functional/FileFieldRevisionTest.php
-
-		-
-			message: "#^Variable \\$unexpected in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/file/tests/src/Functional/FileManagedTestBase.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\file\\\\Functional\\\\FileUploadJsonBasicAuthTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#"
-			count: 1
-			path: modules/file/tests/src/Functional/FileUploadJsonBasicAuthTest.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\file\\\\Functional\\\\FileUploadJsonCookieTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#"
-			count: 1
-			path: modules/file/tests/src/Functional/FileUploadJsonCookieTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/file/tests/src/Kernel/DeleteTest.php
-
-		-
-			message: "#^Variable \\$unexpected in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/file/tests/src/Kernel/FileManagedUnitTestBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/file/tests/src/Kernel/UsageTest.php
-
-		-
-			message: "#^Variable \\$rows might not be defined\\.$#"
-			count: 1
-			path: modules/filter/src/Plugin/Filter/FilterHtml.php
-
-		-
-			message: "#^Method Drupal\\\\forum\\\\ForumManager\\:\\:getTopicOrder\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/forum/src/ForumManager.php
-
-		-
-			message: "#^Variable \\$vocabulary in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/forum/src/ForumUninstallValidator.php
-
-		-
-			message: "#^Method Drupal\\\\history\\\\Plugin\\\\views\\\\field\\\\HistoryUserTimestamp\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#"
-			count: 1
-			path: modules/history/src/Plugin/views/field/HistoryUserTimestamp.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/history/src/Plugin/views/filter/HistoryUserTimestamp.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/history/tests/src/Kernel/Views/HistoryTimestampTest.php
-
-		-
-			message: "#^Variable \\$image_style in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/image/src/Controller/ImageStyleDownloadController.php
-
-		-
-			message: "#^Variable \\$lock_name might not be defined\\.$#"
-			count: 1
-			path: modules/image/src/Controller/ImageStyleDownloadController.php
-
-		-
-			message: "#^Method Drupal\\\\image\\\\Form\\\\ImageStyleEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/image/src/Form/ImageStyleEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\image\\\\Form\\\\ImageStyleFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/image/src/Form/ImageStyleFormBase.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\image\\\\Plugin\\\\Field\\\\FieldType\\\\ImageItem\\:\\:\\$height\\.$#"
-			count: 2
-			path: modules/image/src/Plugin/Field/FieldType/ImageItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\image\\\\Plugin\\\\Field\\\\FieldType\\\\ImageItem\\:\\:\\$width\\.$#"
-			count: 2
-			path: modules/image/src/Plugin/Field/FieldType/ImageItem.php
-
-		-
-			message: "#^Variable \\$image_that_is_too_small_file might not be defined\\.$#"
-			count: 2
-			path: modules/image/tests/src/Functional/ImageFieldValidateTest.php
-
-		-
-			message: "#^Variable \\$edit in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/image/tests/src/Functional/ImageStyleFlushTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 2
-			path: modules/inline_form_errors/tests/src/Unit/FormErrorHandlerTest.php
-
-		-
-			message: "#^Variable \\$reason in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/jsonapi/src/Context/FieldResolver.php
-
-		-
-			message: "#^Method Drupal\\\\jsonapi\\\\JsonApiResource\\\\ResourceIdentifier\\:\\:getDataReferencePropertyName\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/jsonapi/src/JsonApiResource/ResourceIdentifier.php
-
-		-
-			message: "#^Variable \\$entity in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/jsonapi/src/Normalizer/EntityAccessDeniedHttpExceptionNormalizer.php
-
-		-
-			message: "#^Variable \\$group might not be defined\\.$#"
-			count: 5
-			path: modules/jsonapi/src/Query/Filter.php
-
-		-
-			message: "#^Method Drupal\\\\jsonapi\\\\Revisions\\\\VersionNegotiator\\:\\:getRevision\\(\\) should return Drupal\\\\Core\\\\Entity\\\\EntityInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/jsonapi/src/Revisions/VersionNegotiator.php
-
-		-
-			message: "#^Variable \\$created_entity might not be defined\\.$#"
-			count: 1
-			path: modules/jsonapi/tests/src/Functional/ResourceTestBase.php
-
-		-
-			message: "#^Variable \\$dynamic_cache might not be defined\\.$#"
-			count: 1
-			path: modules/jsonapi/tests/src/Functional/ResourceTestBase.php
-
-		-
-			message: "#^Variable \\$parseable_invalid_request_body might not be defined\\.$#"
-			count: 2
-			path: modules/jsonapi/tests/src/Functional/ResourceTestBase.php
-
-		-
-			message: "#^Variable \\$reason in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 2
-			path: modules/jsonapi/tests/src/Functional/ResourceTestBase.php
-
-		-
-			message: "#^Variable \\$id in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 2
-			path: modules/jsonapi/tests/src/Unit/Normalizer/JsonApiDocumentTopLevelNormalizerTest.php
-
-		-
-			message: "#^Method Drupal\\\\language\\\\Form\\\\LanguageAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/language/src/Form/LanguageAddForm.php
-
-		-
-			message: "#^Method Drupal\\\\language\\\\Form\\\\LanguageEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/language/src/Form/LanguageEditForm.php
-
-		-
-			message: "#^Variable \\$key might not be defined\\.$#"
-			count: 2
-			path: modules/language/src/Form/NegotiationBrowserForm.php
-
-		-
-			message: "#^Variable \\$method_id might not be defined\\.$#"
-			count: 1
-			path: modules/language/src/LanguageNegotiator.php
-
-		-
-			message: "#^Variable \\$langcode might not be defined\\.$#"
-			count: 1
-			path: modules/language/src/Plugin/LanguageNegotiation/LanguageNegotiationContentEntity.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\link\\\\Plugin\\\\migrate\\\\process\\\\FieldLink has an unused parameter \\$migration\\.$#"
-			count: 1
-			path: modules/link/src/Plugin/migrate/process/FieldLink.php
-
-		-
-			message: "#^Function locale_config_batch_update_components\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/locale.bulk.inc
-
-		-
-			message: "#^Variable \\$item in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/locale/src/Form/ExportForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/locale/src/Form/TranslationStatusForm.php
-
-		-
-			message: "#^Method Drupal\\\\locale\\\\LocaleDefaultConfigStorage\\:\\:read\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/src/LocaleDefaultConfigStorage.php
-
-		-
-			message: "#^Method Drupal\\\\locale\\\\LocaleProjectStorage\\:\\:deleteAll\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/src/LocaleProjectStorage.php
-
-		-
-			message: "#^Method Drupal\\\\locale\\\\PoDatabaseReader\\:\\:readItem\\(\\) should return Drupal\\\\Component\\\\Gettext\\\\PoItem but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/src/PoDatabaseReader.php
-
-		-
-			message: "#^Method Drupal\\\\locale\\\\PoDatabaseWriter\\:\\:importString\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/src/PoDatabaseWriter.php
-
-		-
-			message: "#^Variable \\$plural in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/locale/src/PoDatabaseWriter.php
-
-		-
-			message: "#^Method Drupal\\\\locale\\\\StringDatabaseStorage\\:\\:dbStringTable\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/locale/src/StringDatabaseStorage.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 5
-			path: modules/locale/tests/src/Functional/LocaleUpdateBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/locale/tests/src/Functional/LocaleUpdateCronTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/locale/tests/src/Functional/LocaleUpdateInterfaceTest.php
-
-		-
-			message: "#^Variable \\$error in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/media/media.install
-
-		-
-			message: "#^Method Drupal\\\\media\\\\MediaTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/media/src/MediaTypeForm.php
-
-		-
-			message: "#^Variable \\$source in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/media/src/MediaTypeForm.php
-
-		-
-			message: "#^Variable \\$resource_url on left side of \\?\\? always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/media/src/OEmbed/UrlResolver.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\media_library\\\\OpenerResolver\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: modules/media_library/src/OpenerResolver.php
-
-		-
-			message: "#^Variable \\$jpg_image might not be defined\\.$#"
-			count: 1
-			path: modules/media_library/tests/src/FunctionalJavascript/EmbeddedFormWidgetTest.php
-
-		-
-			message: "#^Method Drupal\\\\menu_link_content\\\\Form\\\\MenuLinkContentForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/menu_link_content/src/Form/MenuLinkContentForm.php
-
-		-
-			message: "#^Variable \\$uuid might not be defined\\.$#"
-			count: 1
-			path: modules/menu_link_content/src/Plugin/Menu/MenuLinkContent.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php
-
-		-
-			message: "#^Method Drupal\\\\menu_ui\\\\MenuForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/menu_ui/src/MenuForm.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\migrate\\\\MigrateException has an unused parameter \\$code\\.$#"
-			count: 1
-			path: modules/migrate/src/MigrateException.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\migrate\\\\MigrateException has an unused parameter \\$previous\\.$#"
-			count: 1
-			path: modules/migrate/src/MigrateException.php
-
-		-
-			message: """
-				#^Call to deprecated method registerLoader\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
-				This method is deprecated and will be removed in
-				            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#
-			"""
-			count: 1
-			path: modules/migrate/src/Plugin/Discovery/AnnotatedClassDiscoveryAutomatedProviders.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/MigrateDestinationPluginManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/MigrateSourcePluginManager.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\migrate\\\\Plugin\\\\MigrationPluginManager has an unused parameter \\$language_manager\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/MigrationPluginManager.php
-
-		-
-			message: "#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\ComponentEntityDisplayBase\\:\\:fields\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/migrate/destination/ComponentEntityDisplayBase.php
-
-		-
-			message: "#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\Config\\:\\:fields\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/migrate/destination/Config.php
-
-		-
-			message: "#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\Entity\\:\\:fields\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/migrate/destination/Entity.php
-
-		-
-			message: "#^Variable \\$config might not be defined\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/migrate/destination/EntityConfigBase.php
-
-		-
-			message: "#^Method Drupal\\\\migrate\\\\Plugin\\\\migrate\\\\destination\\\\NullDestination\\:\\:import\\(\\) should return array\\|bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/migrate/src/Plugin/migrate/destination/NullDestination.php
-
-		-
-			message: "#^Call to an undefined static method static\\(Drupal\\\\Tests\\\\migrate\\\\Kernel\\\\MigrateTestBase\\)\\:\\:migrateDumpAlter\\(\\)\\.$#"
-			count: 1
-			path: modules/migrate/tests/src/Kernel/MigrateTestBase.php
-
-		-
-			message: "#^Variable \\$sub_process_plugins might not be defined\\.$#"
-			count: 2
-			path: modules/migrate/tests/src/Unit/process/SubProcessTest.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/migrate_drupal/src/MigrationPluginManager.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/src/NodeMigrateType.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\migrate_drupal\\\\Plugin\\\\migrate\\\\EntityReferenceTranslationDeriver has an unused parameter \\$base_plugin_id\\.$#"
-			count: 1
-			path: modules/migrate_drupal/src/Plugin/migrate/EntityReferenceTranslationDeriver.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\migrate_drupal\\\\Plugin\\\\migrate\\\\source\\\\ContentEntityDeriver has an unused parameter \\$base_plugin_id\\.$#"
-			count: 1
-			path: modules/migrate_drupal/src/Plugin/migrate/source/ContentEntityDeriver.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Kernel/StateFileExistsTest.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Kernel/d6/ValidateMigrationStateTest.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Kernel/d7/ValidateMigrationStateTest.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Unit/MigrateFieldPluginManagerTest.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php
-
-		-
-			message: "#^Variable \\$statement might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/migrate_drupal_ui/src/Batch/MigrateUpgradeImportBatch.php
-
-		-
-			message: "#^Variable \\$connection might not be defined\\.$#"
-			count: 2
-			path: modules/migrate_drupal_ui/src/Form/CredentialForm.php
-
-		-
-			message: "#^Variable \\$version might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal_ui/src/Form/CredentialForm.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal_ui/src/Form/MigrateUpgradeFormBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/migrate_drupal_ui/src/Form/ReviewForm.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\CredentialFormTest\\:\\:installEntitySchema\\(\\)\\.$#"
-			count: 8
-			path: modules/migrate_drupal_ui/tests/src/Functional/CredentialFormTest.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeExecuteTestBase\\:\\:installEntitySchema\\(\\)\\.$#"
-			count: 8
-			path: modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeExecuteTestBase.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeFormStepsTest\\:\\:installEntitySchema\\(\\)\\.$#"
-			count: 8
-			path: modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeFormStepsTest.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeFormStepsTest.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MigrateUpgradeTestBase\\:\\:getManagedFiles\\(\\)\\.$#"
-			count: 1
-			path: modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeTestBase.php
-
-		-
-			message: "#^Variable \\$patterns might not be defined\\.$#"
-			count: 1
-			path: modules/migrate_drupal_ui/tests/src/Functional/MigrateUpgradeTestBase.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\migrate_drupal_ui\\\\Functional\\\\MultilingualReviewPageTestBase\\:\\:installEntitySchema\\(\\)\\.$#"
-			count: 8
-			path: modules/migrate_drupal_ui/tests/src/Functional/MultilingualReviewPageTestBase.php
-
-		-
-			message: """
-				#^Access to deprecated property \\$needsCleanup of class Drupal\\\\mysql\\\\Driver\\\\Database\\\\mysql\\\\Connection\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There's no
-				   replacement\\.$#
-			"""
-			count: 1
-			path: modules/mysql/src/Driver/Database/mysql/Connection.php
-
-		-
-			message: "#^Variable \\$last_insert_id might not be defined\\.$#"
-			count: 1
-			path: modules/mysql/src/Driver/Database/mysql/Insert.php
-
-		-
-			message: "#^Variable \\$string_ascii_check might not be defined\\.$#"
-			count: 1
-			path: modules/mysql/tests/src/Kernel/mysql/SchemaTest.php
-
-		-
-			message: "#^Variable \\$string_check might not be defined\\.$#"
-			count: 1
-			path: modules/mysql/tests/src/Kernel/mysql/SchemaTest.php
-
-		-
-			message: "#^Method Drupal\\\\node\\\\ConfigTranslation\\\\NodeTypeMapper\\:\\:setEntity\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/node/src/ConfigTranslation/NodeTypeMapper.php
-
-		-
-			message: "#^Method Drupal\\\\node\\\\NodeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/node/src/NodeForm.php
-
-		-
-			message: "#^Method Drupal\\\\node\\\\NodeGrantDatabaseStorage\\:\\:alterQuery\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/node/src/NodeGrantDatabaseStorage.php
-
-		-
-			message: "#^Method Drupal\\\\node\\\\NodeTypeForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/node/src/NodeTypeForm.php
-
-		-
-			message: "#^Variable \\$node in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/node/src/Plugin/views/row/Rss.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/node/tests/src/Functional/NodeAdminTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/node/tests/src/Functional/NodeRevisionsAllTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/node/tests/src/Functional/NodeRevisionsTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/node/tests/src/Functional/NodeSaveTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/node/tests/src/Functional/NodeTranslationUITest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/node/tests/src/Functional/Views/FrontPageTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/node/tests/src/Functional/Views/NodeIntegrationTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 5
-			path: modules/node/tests/src/Functional/Views/Wizard/NodeRevisionWizardTest.php
-
-		-
-			message: "#^Variable \\$changed in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/node/tests/src/Kernel/Migrate/d7/MigrateNodeTest.php
-
-		-
-			message: "#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListFloatItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/options/src/Plugin/Field/FieldType/ListFloatItem.php
-
-		-
-			message: "#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListIntegerItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/options/src/Plugin/Field/FieldType/ListIntegerItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListItemBase\\:\\:\\$value\\.$#"
-			count: 1
-			path: modules/options/src/Plugin/Field/FieldType/ListItemBase.php
-
-		-
-			message: "#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListItemBase\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/options/src/Plugin/Field/FieldType/ListItemBase.php
-
-		-
-			message: "#^Method Drupal\\\\options\\\\Plugin\\\\Field\\\\FieldType\\\\ListStringItem\\:\\:validateAllowedValue\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/options/src/Plugin/Field/FieldType/ListStringItem.php
-
-		-
-			message: "#^Method Drupal\\\\path\\\\PathAliasForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/path/src/PathAliasForm.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$alias\\.$#"
-			count: 3
-			path: modules/path/src/Plugin/Field/FieldType/PathItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$langcode\\.$#"
-			count: 2
-			path: modules/path/src/Plugin/Field/FieldType/PathItem.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:\\$pid\\.$#"
-			count: 5
-			path: modules/path/src/Plugin/Field/FieldType/PathItem.php
-
-		-
-			message: "#^Method Drupal\\\\path\\\\Plugin\\\\Field\\\\FieldType\\\\PathItem\\:\\:postSave\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/path/src/Plugin/Field/FieldType/PathItem.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/path_alias/src/AliasManager.php
-
-		-
-			message: """
-				#^Call to deprecated method makeSequenceName\\(\\) of class Drupal\\\\Core\\\\Database\\\\Connection\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is
-				  no replacement\\.$#
-			"""
-			count: 1
-			path: modules/pgsql/src/Driver/Database/pgsql/Schema.php
-
-		-
-			message: "#^Variable \\$table_field might not be defined\\.$#"
-			count: 1
-			path: modules/pgsql/src/Driver/Database/pgsql/Select.php
-
-		-
-			message: "#^Method Drupal\\\\pgsql\\\\Driver\\\\Database\\\\pgsql\\\\Upsert\\:\\:execute\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/pgsql/src/Driver/Database/pgsql/Upsert.php
-
-		-
-			message: """
-				#^Call to deprecated method makeSequenceName\\(\\) of class Drupal\\\\Core\\\\Database\\\\Connection\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. There is
-				  no replacement\\.$#
-			"""
-			count: 1
-			path: modules/pgsql/src/Update10101.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: modules/pgsql/tests/src/Unit/SchemaTest.php
-
-		-
-			message: "#^Variable \\$responsive_image_styles in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/responsive_image/src/Plugin/Field/FieldFormatter/ResponsiveImageFormatter.php
-
-		-
-			message: "#^Method Drupal\\\\responsive_image\\\\ResponsiveImageStyleForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/responsive_image/src/ResponsiveImageStyleForm.php
-
-		-
-			message: "#^Variable \\$created_entity might not be defined\\.$#"
-			count: 4
-			path: modules/rest/tests/src/Functional/EntityResource/EntityResourceTestBase.php
-
-		-
-			message: "#^Variable \\$working_to might not be defined\\.$#"
-			count: 1
-			path: modules/search/search.module
-
-		-
-			message: "#^Method Drupal\\\\search\\\\Form\\\\SearchPageAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/search/src/Form/SearchPageAddForm.php
-
-		-
-			message: "#^Method Drupal\\\\search\\\\Form\\\\SearchPageEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/search/src/Form/SearchPageEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\search\\\\Form\\\\SearchPageFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/search/src/Form/SearchPageFormBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/search/src/SearchIndex.php
-
-		-
-			message: "#^Method Drupal\\\\search\\\\SearchPageRepository\\:\\:setDefaultSearchPage\\(\\) should return static\\(Drupal\\\\search\\\\SearchPageRepository\\) but return statement is missing\\.$#"
-			count: 1
-			path: modules/search/src/SearchPageRepository.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/search/tests/src/Functional/SearchMultilingualEntityTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/search/tests/src/Functional/SearchRankingTest.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\serialization\\\\Normalizer\\\\EntityNormalizer\\:\\:getCustomSerializedPropertyNames\\(\\)\\.$#"
-			count: 1
-			path: modules/serialization/src/Normalizer/EntityNormalizer.php
-
-		-
-			message: "#^Method Drupal\\\\shortcut\\\\Form\\\\SetCustomize\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/shortcut/src/Form/SetCustomize.php
-
-		-
-			message: "#^Method Drupal\\\\shortcut\\\\ShortcutForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/shortcut/src/ShortcutForm.php
-
-		-
-			message: "#^Method Drupal\\\\shortcut\\\\ShortcutSetForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/shortcut/src/ShortcutSetForm.php
-
-		-
-			message: "#^Variable \\$args might not be defined\\.$#"
-			count: 1
-			path: modules/sqlite/src/Driver/Database/sqlite/Connection.php
-
-		-
-			message: "#^Variable \\$statement might not be defined\\.$#"
-			count: 1
-			path: modules/sqlite/src/Driver/Database/sqlite/Connection.php
-
-		-
-			message: "#^Method Drupal\\\\system\\\\Controller\\\\BatchController\\:\\:batchPage\\(\\) should return array\\|Symfony\\\\Component\\\\HttpFoundation\\\\Response but return statement is missing\\.$#"
-			count: 1
-			path: modules/system/src/Controller/BatchController.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/system/src/DateFormatListBuilder.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/system/src/Form/DateFormatDeleteForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/system/src/Form/DateFormatEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\system\\\\Form\\\\DateFormatFormBase\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/system/src/Form/DateFormatFormBase.php
-
-		-
-			message: "#^Method Drupal\\\\system\\\\Form\\\\ModulesListNonStableConfirmForm\\:\\:getQuestion\\(\\) should return Drupal\\\\Core\\\\StringTranslation\\\\TranslatableMarkup but return statement is missing\\.$#"
-			count: 1
-			path: modules/system/src/Form/ModulesListNonStableConfirmForm.php
-
-		-
-			message: "#^Variable \\$default_theme in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/system/src/Form/ThemeSettingsForm.php
-
-		-
-			message: "#^Variable \\$theme_settings in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/system/src/Plugin/migrate/destination/d7/ThemeSettings.php
-
-		-
-			message: "#^Variable \\$violation_messages might not be defined\\.$#"
-			count: 1
-			path: modules/system/src/SecurityAdvisories/SecurityAdvisory.php
-
-		-
-			message: "#^Variable \\$directories might not be defined\\.$#"
-			count: 1
-			path: modules/system/system.install
-
-		-
-			message: "#^Variable \\$pdo_message might not be defined\\.$#"
-			count: 1
-			path: modules/system/system.install
-
-		-
-			message: "#^Variable \\$site_path might not be defined\\.$#"
-			count: 1
-			path: modules/system/system.install
-
-		-
-			message: "#^Variable \\$messages might not be defined\\.$#"
-			count: 1
-			path: modules/system/tests/modules/batch_test/batch_test.callbacks.inc
-
-		-
-			message: """
-				#^Call to deprecated function deprecation_test_function\\(\\)\\:
-				in drupal\\:8\\.4\\.0 and is removed from drupal\\:9\\.0\\.0\\. This is
-				  the deprecation message for deprecated_test_function\\(\\)\\.$#
-			"""
-			count: 1
-			path: modules/system/tests/modules/deprecation_test/src/DeprecatedController.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/system/tests/modules/entity_test/src/Plugin/Field/FieldType/ChangedTestItem.php
-
-		-
-			message: "#^Variable \\$options might not be defined\\.$#"
-			count: 1
-			path: modules/system/tests/modules/form_test/src/Form/FormTestTableSelectJsSelectForm.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\lazy_route_provider_install_test\\\\PluginManager has an unused parameter \\$cache_backend\\.$#"
-			count: 1
-			path: modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\lazy_route_provider_install_test\\\\PluginManager has an unused parameter \\$url_generator\\.$#"
-			count: 1
-			path: modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php
-
-		-
-			message: """
-				#^Class Drupal\\\\service_provider_test\\\\TestClass implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: modules/system/tests/modules/service_provider_test/src/TestClass.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/system/tests/modules/lazy_route_provider_install_test/src/PluginManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/system/tests/modules/module_test/src/PluginManagerCacheClearer.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/system/tests/modules/plugin_test/src/Plugin/DefaultsTestPluginManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/system/tests/modules/plugin_test/src/Plugin/MockBlockManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: modules/system/tests/modules/plugin_test/src/Plugin/TestPluginManager.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\service_provider_test\\\\TestClass\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: modules/system/tests/modules/service_provider_test/src/TestClass.php
-
-		-
-			message: "#^Access to an undefined property Drupal\\\\Tests\\\\system\\\\Functional\\\\FileTransfer\\\\TestFileTransfer\\:\\:\\$connection\\.$#"
-			count: 5
-			path: modules/system/tests/src/Functional/FileTransfer/TestFileTransfer.php
-
-		-
-			message: "#^Variable \\$form_output in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 2
-			path: modules/system/tests/src/Functional/Form/FormTest.php
-
-		-
-			message: "#^Variable \\$parent might not be defined\\.$#"
-			count: 3
-			path: modules/system/tests/src/Functional/Menu/BreadcrumbTest.php
-
-		-
-			message: "#^Variable \\$expected_required_list_items might not be defined\\.$#"
-			count: 2
-			path: modules/system/tests/src/Functional/Theme/ThemeUiTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 2
-			path: modules/system/tests/src/Kernel/System/CronQueueTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/system/tests/src/Kernel/Token/TokenReplaceKernelTest.php
-
-		-
-			message: "#^Variable \\$help_message might not be defined\\.$#"
-			count: 1
-			path: modules/taxonomy/src/Form/OverviewTerms.php
-
-		-
-			message: "#^Method Drupal\\\\taxonomy\\\\Plugin\\\\migrate\\\\source\\\\d7\\\\TermTranslation\\:\\:prepareRow\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/taxonomy/src/Plugin/migrate/source/d7/TermTranslation.php
-
-		-
-			message: "#^Variable \\$inner_count might not be defined\\.$#"
-			count: 1
-			path: modules/taxonomy/src/Plugin/views/argument/IndexTidDepth.php
-
-		-
-			message: "#^Variable \\$inner_count might not be defined\\.$#"
-			count: 1
-			path: modules/taxonomy/src/Plugin/views/filter/TaxonomyIndexTidDepth.php
-
-		-
-			message: "#^Method Drupal\\\\taxonomy\\\\TermForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/taxonomy/src/TermForm.php
-
-		-
-			message: "#^Method Drupal\\\\taxonomy\\\\TermForm\\:\\:validateForm\\(\\) should return Drupal\\\\Core\\\\Entity\\\\ContentEntityInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/taxonomy/src/TermForm.php
-
-		-
-			message: "#^Method Drupal\\\\taxonomy\\\\VocabularyForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/taxonomy/src/VocabularyForm.php
-
-		-
-			message: "#^Variable \\$depth_count might not be defined\\.$#"
-			count: 4
-			path: modules/taxonomy/tests/src/Kernel/TermKernelTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/toolbar/src/Controller/ToolbarController.php
-
-		-
-			message: "#^Method Drupal\\\\tour\\\\TipPluginBase\\:\\:get\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/tour/src/TipPluginBase.php
-
-		-
-			message: "#^Variable \\$location on left side of \\?\\? always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/tour/src/TipPluginBase.php
-
-		-
-			message: "#^Variable \\$violation_messages might not be defined\\.$#"
-			count: 1
-			path: modules/update/src/ProjectRelease.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: modules/update/src/UpdateProcessor.php
-
-		-
-			message: "#^Variable \\$users might not be defined\\.$#"
-			count: 1
-			path: modules/user/src/Controller/UserAuthenticationController.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/user/src/Controller/UserController.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/user/src/EventSubscriber/UserRequestSubscriber.php
-
-		-
-			message: "#^Variable \\$route_object might not be defined\\.$#"
-			count: 1
-			path: modules/user/src/Plugin/LanguageNegotiation/LanguageNegotiationUserAdmin.php
-
-		-
-			message: "#^Variable \\$account in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/src/Plugin/Validation/Constraint/ProtectedUserFieldConstraintValidator.php
-
-		-
-			message: "#^Variable \\$account in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/src/Plugin/Validation/Constraint/UserMailRequiredValidator.php
-
-		-
-			message: "#^Variable \\$items in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/src/Plugin/Validation/Constraint/UserMailRequiredValidator.php
-
-		-
-			message: "#^Method Drupal\\\\user\\\\Plugin\\\\views\\\\field\\\\UserData\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#"
-			count: 1
-			path: modules/user/src/Plugin/views/field/UserData.php
-
-		-
-			message: "#^Method Drupal\\\\user\\\\ProfileForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/user/src/ProfileForm.php
-
-		-
-			message: "#^Method Drupal\\\\user\\\\RegisterForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/user/src/RegisterForm.php
-
-		-
-			message: "#^Method Drupal\\\\user\\\\RoleForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/user/src/RoleForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/user/tests/src/Functional/UserCreateTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserEditTest.php
-
-		-
-			message: "#^Variable \\$name in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserLoginHttpTest.php
-
-		-
-			message: "#^Variable \\$pass in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserLoginHttpTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 5
-			path: modules/user/tests/src/Functional/UserPasswordResetTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserPictureTest.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\Tests\\\\user\\\\Functional\\\\UserRegistrationRestTest\\:\\:getExpectedUnauthorizedEntityAccessCacheability\\(\\)\\.$#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserRegistrationRestTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/user/tests/src/Functional/UserRegistrationTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/user/tests/src/Functional/Views/UserChangedTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: modules/user/tests/src/Kernel/Views/HandlerFilterRolesTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: modules/user/tests/src/Kernel/Views/HandlerFilterRolesTest.php
-
-		-
-			message: "#^Variable \\$result in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/user/tests/src/Unit/UserAccessControlHandlerTest.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Form\\\\ViewsFormMainForm\\:\\:getFormId\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Form/ViewsFormMainForm.php
-
-		-
-			message: "#^Variable \\$display in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/Derivative/ViewsBlock.php
-
-		-
-			message: "#^Call to an undefined method \\$this\\(Drupal\\\\views\\\\Plugin\\\\views\\\\HandlerBase\\)\\:\\:getFormula\\(\\)\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/HandlerBase.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\HandlerBase\\:\\:getTableJoin\\(\\) should return Drupal\\\\views\\\\Plugin\\\\views\\\\join\\\\JoinPluginBase but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/HandlerBase.php
-
-		-
-			message: "#^Variable \\$group_types might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/HandlerBase.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/area/Broken.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\area\\\\HTTPStatusCode\\:\\:render\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/area/HTTPStatusCode.php
-
-		-
-			message: "#^Variable \\$options_name might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/argument/ArgumentPluginBase.php
-
-		-
-			message: "#^Variable \\$plugin_name might not be defined\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/argument/ArgumentPluginBase.php
-
-		-
-			message: "#^Variable \\$validate_types might not be defined\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/argument/ArgumentPluginBase.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/argument/Broken.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/src/Plugin/views/argument/Date.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\cache\\\\CachePluginBase\\:\\:cacheGet\\(\\) should return bool but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/cache/CachePluginBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/src/Plugin/views/cache/Time.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\views\\\\Plugin\\\\views\\\\display\\\\DisplayPluginBase has an unused parameter \\$configuration\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/display/DisplayPluginBase.php
-
-		-
-			message: "#^Variable \\$pager in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/display/DisplayPluginBase.php
-
-		-
-			message: "#^Variable \\$style in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/display/DisplayPluginBase.php
-
-		-
-			message: "#^Variable \\$access_plugin in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/display/PathPluginBase.php
-
-		-
-			message: "#^Variable \\$options might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/Boolean.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/Broken.php
-
-		-
-			message: "#^Variable \\$entity in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/BulkForm.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/views/src/Plugin/views/field/Date.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\Date\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/Date.php
-
-		-
-			message: "#^Variable \\$custom_format might not be defined\\.$#"
-			count: 9
-			path: modules/views/src/Plugin/views/field/Date.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\EntityField\\:\\:getFieldStorageDefinition\\(\\) should return Drupal\\\\Core\\\\Field\\\\FieldStorageDefinitionInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/EntityField.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\EntityField\\:\\:renderItems\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/EntityField.php
-
-		-
-			message: "#^Variable \\$field_item_list in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/EntityField.php
-
-		-
-			message: "#^Variable \\$options in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/FieldPluginBase.php
-
-		-
-			message: "#^Variable \\$raw_items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/FieldPluginBase.php
-
-		-
-			message: "#^Variable \\$style in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/FieldPluginBase.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\Markup\\:\\:render\\(\\) should return Drupal\\\\Component\\\\Render\\\\MarkupInterface\\|string but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/Markup.php
-
-		-
-			message: "#^Method Drupal\\\\views\\\\Plugin\\\\views\\\\field\\\\PrerenderList\\:\\:renderItems\\(\\) should return string but return statement is missing\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/field/PrerenderList.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/filter/Broken.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\views\\\\Plugin\\\\views\\\\filter\\\\FilterPluginBase\\:\\:operators\\(\\)\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/filter/FilterPluginBase.php
-
-		-
-			message: "#^Variable \\$groups might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/filter/FilterPluginBase.php
-
-		-
-			message: "#^Variable \\$source might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/filter/InOperator.php
-
-		-
-			message: "#^Variable \\$source might not be defined\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/filter/NumericFilter.php
-
-		-
-			message: "#^Variable \\$value might not be defined\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/filter/NumericFilter.php
-
-		-
-			message: "#^Variable \\$source might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/filter/StringFilter.php
-
-		-
-			message: "#^Variable \\$left in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/join/JoinPluginBase.php
-
-		-
-			message: "#^Variable \\$join in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 2
-			path: modules/views/src/Plugin/views/query/Sql.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/relationship/Broken.php
-
-		-
-			message: "#^Variable \\$sort_field might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/relationship/GroupwiseMax.php
-
-		-
-			message: "#^Variable \\$sort_table might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/relationship/GroupwiseMax.php
-
-		-
-			message: "#^Variable \\$items might not be defined\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/sort/Broken.php
-
-		-
-			message: "#^Variable \\$plugin in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/style/StylePluginBase.php
-
-		-
-			message: "#^Variable \\$created_column in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/wizard/WizardPluginBase.php
-
-		-
-			message: "#^Variable \\$default_field might not be defined\\.$#"
-			count: 6
-			path: modules/views/src/Plugin/views/wizard/WizardPluginBase.php
-
-		-
-			message: "#^Variable \\$sorts in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/wizard/WizardPluginBase.php
-
-		-
-			message: "#^Variable \\$style_plugin in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/wizard/WizardPluginBase.php
-
-		-
-			message: "#^Variable \\$view in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views/src/Plugin/views/wizard/WizardPluginBase.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/src/ViewExecutable.php
-
-		-
-			message: "#^Variable \\$view in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 2
-			path: modules/views/tests/modules/views_test_data/views_test_data.views_execution.inc
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/tests/src/Functional/BulkFormTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/views/tests/src/Functional/DefaultViewsTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/views/tests/src/Functional/GlossaryTest.php
-
-		-
-			message: "#^Variable \\$link might not be defined\\.$#"
-			count: 1
-			path: modules/views/tests/src/Functional/TaxonomyGlossaryTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 6
-			path: modules/views/tests/src/Functional/Wizard/ItemsPerPageTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/tests/src/Functional/Wizard/PagerTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/views/tests/src/Functional/Wizard/SortingTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/views/tests/src/FunctionalJavascript/ClickSortingAJAXTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 3
-			path: modules/views/tests/src/Kernel/Handler/FieldDropbuttonTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: modules/views/tests/src/Kernel/Handler/FieldFieldTest.php
-
-		-
-			message: "#^Variable \\$rand1 might not be defined\\.$#"
-			count: 2
-			path: modules/views/tests/src/Kernel/Plugin/StyleTest.php
-
-		-
-			message: "#^Variable \\$rand2 might not be defined\\.$#"
-			count: 2
-			path: modules/views/tests/src/Kernel/Plugin/StyleTest.php
-
-		-
-			message: "#^Variable \\$rand3 might not be defined\\.$#"
-			count: 2
-			path: modules/views/tests/src/Kernel/Plugin/StyleTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 2
-			path: modules/views/tests/src/Kernel/RenderCacheIntegrationTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 10
-			path: modules/views/tests/src/Unit/ViewsDataTest.php
-
-		-
-			message: "#^Variable \\$relationship_handler in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views_ui/src/Form/Ajax/ConfigHandler.php
-
-		-
-			message: "#^Cannot unset offset '\\#title' on array\\{\\#theme_wrappers\\: array\\{'container'\\}, \\#attributes\\: array\\{class\\: array\\{'scroll'\\}, data\\-drupal\\-views\\-scroll\\: true\\}\\}\\.$#"
-			count: 1
-			path: modules/views_ui/src/Form/Ajax/Display.php
-
-		-
-			message: "#^Method Drupal\\\\views_ui\\\\ViewEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/views_ui/src/ViewEditForm.php
-
-		-
-			message: "#^Variable \\$group_info might not be defined\\.$#"
-			count: 2
-			path: modules/views_ui/src/ViewEditForm.php
-
-		-
-			message: "#^Variable \\$display_plugin in empty\\(\\) always exists and is not falsy\\.$#"
-			count: 1
-			path: modules/views_ui/src/ViewFormBase.php
-
-		-
-			message: "#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:getTypedData\\(\\) should return Drupal\\\\Core\\\\TypedData\\\\ComplexDataInterface but return statement is missing\\.$#"
-			count: 1
-			path: modules/views_ui/src/ViewUI.php
-
-		-
-			message: "#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:set\\(\\) should return \\$this\\(Drupal\\\\views_ui\\\\ViewUI\\) but return statement is missing\\.$#"
-			count: 1
-			path: modules/views_ui/src/ViewUI.php
-
-		-
-			message: "#^Method Drupal\\\\views_ui\\\\ViewUI\\:\\:setSyncing\\(\\) should return \\$this\\(Drupal\\\\views_ui\\\\ViewUI\\) but return statement is missing\\.$#"
-			count: 1
-			path: modules/views_ui/src/ViewUI.php
-
-		-
-			message: "#^Variable \\$message in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/views_ui/tests/src/FunctionalJavascript/PreviewTest.php
-
-		-
-			message: "#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workflows/src/Form/WorkflowEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowStateAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workflows/src/Form/WorkflowStateAddForm.php
-
-		-
-			message: "#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowStateEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workflows/src/Form/WorkflowStateEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowTransitionAddForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workflows/src/Form/WorkflowTransitionAddForm.php
-
-		-
-			message: "#^Method Drupal\\\\workflows\\\\Form\\\\WorkflowTransitionEditForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workflows/src/Form/WorkflowTransitionEditForm.php
-
-		-
-			message: "#^Method Drupal\\\\workspaces\\\\EntityTypeInfo\\:\\:entityBaseFieldInfo\\(\\) should return array\\<Drupal\\\\Core\\\\Field\\\\FieldDefinitionInterface\\> but return statement is missing\\.$#"
-			count: 1
-			path: modules/workspaces/src/EntityTypeInfo.php
-
-		-
-			message: "#^Method Drupal\\\\workspaces\\\\Form\\\\WorkspaceForm\\:\\:save\\(\\) should return int but return statement is missing\\.$#"
-			count: 1
-			path: modules/workspaces/src/Form/WorkspaceForm.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/workspaces/src/Plugin/Validation/Constraint/DeletedWorkspaceConstraintValidator.php
-
-		-
-			message: "#^Variable \\$entity in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/workspaces/src/Plugin/Validation/Constraint/EntityWorkspaceConflictConstraintValidator.php
-
-		-
-			message: "#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/workspaces/src/WorkspaceAssociation.php
-
-		-
-			message: "#^Method Drupal\\\\workspaces\\\\WorkspaceMerger\\:\\:checkConflictsOnTarget\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/workspaces/src/WorkspaceMerger.php
-
-		-
-			message: "#^Variable \\$transaction in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: modules/workspaces/src/WorkspaceMerger.php
-
-		-
-			message: "#^Method Drupal\\\\workspaces\\\\WorkspacePublisher\\:\\:checkConflictsOnTarget\\(\\) should return array but return statement is missing\\.$#"
-			count: 1
-			path: modules/workspaces/src/WorkspacePublisher.php
-
-		-
-			message: "#^Variable \\$keyed_content might not be defined\\.$#"
-			count: 1
-			path: profiles/demo_umami/modules/demo_umami_content/src/InstallHelper.php
-
-		-
-			message: "#^Variable \\$structured_content might not be defined\\.$#"
-			count: 1
-			path: profiles/demo_umami/modules/demo_umami_content/src/InstallHelper.php
-
-		-
-			message: "#^Variable \\$project_stabilities might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/BuildTests/Composer/Template/ComposerProjectTemplatesTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\ClassRequiresAvailable\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\ClassRequiresUnavailable\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\MethodRequires\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Drupal\\\\BuildTests\\\\Framework\\\\ExternalCommandRequirementsTrait in class Drupal\\\\BuildTests\\\\Framework\\\\Tests\\\\UsesCommandRequirements\\:
-				in drupal\\:10\\.2\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				Drupal\\\\\\\\TestTools\\\\\\\\Extension\\\\\\\\RequiresComposerTrait instead\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/BuildTests/Framework/Tests/ExternalCommandRequirementTest.php
-
-		-
-			message: "#^Variable \\$found might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Cache/ApcuBackendTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 12
-			path: tests/Drupal/KernelTests/Core/Cache/GenericCacheBackendUnitTestBase.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Config/ConfigInstallTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Config/ConfigInstallTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 2
-			path: tests/Drupal/KernelTests/Core/Database/ConnectionTest.php
-
-		-
-			message: "#^Variable \\$expected_driver might not be defined\\.$#"
-			count: 2
-			path: tests/Drupal/KernelTests/Core/Database/DriverSpecificKernelTestBase.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 3
-			path: tests/Drupal/KernelTests/Core/Database/StatementTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 3
-			path: tests/Drupal/KernelTests/Core/Database/StatementTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 4
-			path: tests/Drupal/KernelTests/Core/Entity/ContentEntityChangedTest.php
-
-		-
-			message: "#^Variable \\$title might not be defined\\.$#"
-			count: 2
-			path: tests/Drupal/KernelTests/Core/Entity/CreateSampleEntityTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 9
-			path: tests/Drupal/KernelTests/Core/Entity/EntityCrudHookTest.php
-
-		-
-			message: "#^Variable \\$previous_untranslatable_field_value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 2
-			path: tests/Drupal/KernelTests/Core/Entity/EntityDecoupledTranslationRevisionsTest.php
-
-		-
-			message: "#^Variable \\$field might not be defined\\.$#"
-			count: 9
-			path: tests/Drupal/KernelTests/Core/Entity/EntitySchemaTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Entity/EntityTypeConstraintsTest.php
-
-		-
-			message: "#^Variable \\$e might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php
-
-		-
-			message: "#^Variable \\$entity might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php
-
-		-
-			message: "#^Variable \\$new_field_schema_data might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Entity/FieldableEntityDefinitionUpdateTest.php
-
-		-
-			message: "#^Variable \\$x might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Image/ToolkitGdTest.php
-
-		-
-			message: "#^Variable \\$y might not be defined\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Image/ToolkitGdTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/KeyValueStore/GarbageCollectionTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/KernelTests/Core/Render/Element/MachineNameTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: tests/Drupal/KernelTests/Core/TempStore/TempStoreDatabaseTest.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 5
-			path: tests/Drupal/KernelTests/Core/TypedData/TypedDataTest.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: tests/Drupal/KernelTests/KernelTestBase.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\TestSite\\\\Commands\\\\TestSiteInstallCommand\\:\\:assertTrue\\(\\)\\.$#"
-			count: 1
-			path: tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php
-
-		-
-			message: "#^Call to an undefined method Drupal\\\\TestSite\\\\Commands\\\\TestSiteInstallCommand\\:\\:fail\\(\\)\\.$#"
-			count: 1
-			path: tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: tests/Drupal/TestSite/Commands/TestSiteInstallCommand.php
-
-		-
-			message: "#^Call to deprecated constant REQUEST_TIME\\: Deprecated in drupal\\:8\\.3\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use \\\\Drupal\\:\\:time\\(\\)\\-\\>getRequestTime\\(\\); $#"
-			count: 1
-			path: tests/Drupal/Tests/BrowserTestBase.php
-
-		-
-			message: """
-				#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\Client\\:
-				Client\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/BrowserTestBase.php
-
-		-
-			message: """
-				#^Call to deprecated method registerAutoloadNamespace\\(\\) of class Doctrine\\\\Common\\\\Annotations\\\\AnnotationRegistry\\:
-				This method is deprecated and will be removed in
-				            doctrine/annotations 2\\.0\\. Annotations will be autoloaded in 2\\.0\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Component/Annotation/Doctrine/DocParserTest.php
-
-		-
-			message: "#^Constructor of class Symfony\\\\Component\\\\ExpressionLanguage\\\\Expression has an unused parameter \\$expression\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/DependencyInjection/Dumper/OptimizedPhpArrayDumperTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Component/PhpStorage/FileStorageTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Component/PhpStorage/FileStorageTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$charismatic\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$delightful\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$demure\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsAllNull has an unused parameter \\$electrostatic\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsConfigArrayKey has an unused parameter \\$config_name\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$configuration\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$foo\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$plugin_definition\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$plugin_id\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsMany has an unused parameter \\$what_am_i_doing_here\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Component\\\\Plugin\\\\Factory\\\\ArgumentsPluginId has an unused parameter \\$plugin_id\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/Factory/ReflectionFactoryTest.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Component/Plugin/StubPluginManagerBaseWithMapper.php
-
-		-
-			message: "#^Result of static method Drupal\\\\Composer\\\\Composer\\:\\:ensureComposerVersion\\(\\) \\(void\\) is used\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Composer/ComposerTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Config/ConfigTest.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Tests\\\\Core\\\\Controller\\\\MockContainerAware implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Controller/ControllerResolverTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Tests\\\\Core\\\\Controller\\\\MockContainerAware\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Controller/ControllerResolverTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Database/ConditionTest.php
-
-		-
-			message: """
-				#^Call to deprecated method findCaller\\(\\) of class Drupal\\\\Core\\\\Database\\\\Log\\:
-				in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				  Connection\\:\\:findCallerFromDebugBacktrace\\(\\)\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Database/Stub/StubConnection.php
-
-		-
-			message: """
-				#^Fetching class constant class of deprecated class Drupal\\\\Core\\\\Database\\\\StatementWrapper\\:
-				in drupal\\:10\\.1\\.0 and is removed from drupal\\:11\\.0\\.0\\. Use
-				  \\\\Drupal\\\\Core\\\\Database\\\\StatementWrapperIterator instead\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Database/Stub/StubConnection.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Tests\\\\Core\\\\DependencyInjection\\\\DependencySerializationTestDummy implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/DependencyInjection/DependencySerializationTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 2
-			path: tests/Drupal/Tests/Core/Entity/EntityUnitTest.php
-
-		-
-			message: "#^Trying to mock an undefined method getRevisionId\\(\\) on class Drupal\\\\Tests\\\\Core\\\\Entity\\\\UrlTestEntity\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Entity/EntityUrlTest.php
-
-		-
-			message: "#^Trying to mock an undefined method isDefaultRevision\\(\\) on class Drupal\\\\Tests\\\\Core\\\\Entity\\\\UrlTestEntity\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Entity/EntityUrlTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 2
-			path: tests/Drupal/Tests/Core/EventSubscriber/RedirectResponseSubscriberTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/EventSubscriber/SpecialAttributesRouteSubscriberTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/EventSubscriber/SpecialAttributesRouteSubscriberTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Extension/ModuleHandlerTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Form/FormCacheTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Form/FormErrorHandlerTest.php
-
-		-
-			message: """
-				#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\Client\\:
-				Client\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Http/ClientFactoryTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Menu/ContextualLinkManagerTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Menu/DefaultMenuLinkTreeManipulatorsTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 2
-			path: tests/Drupal/Tests/Core/Menu/LocalTaskManagerTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Menu/StaticMenuLinkOverridesTest.php
-
-		-
-			message: "#^Call to method getDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php
-
-		-
-			message: "#^Call to method getSortedDefinitions\\(\\) on an unknown class Drupal\\\\Core\\\\Plugin\\\\CategorizingPluginManagerTrait\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/CategorizingPluginManagerTraitTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/Discovery/DerivativeDiscoveryDecoratorTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Core\\\\Plugin\\\\Discovery\\\\TestContainerDerivativeDiscovery has an unused parameter \\$example_service\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/Discovery/TestContainerDerivativeDiscovery.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/FilteredPluginManagerTraitTest.php
-
-		-
-			message: "#^Constructor of class Drupal\\\\Tests\\\\Core\\\\Plugin\\\\TestPluginManager has an unused parameter \\$namespaces\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/TestPluginManager.php
-
-		-
-			message: "#^Missing cache backend declaration for performance\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Plugin/TestPluginManager.php
-
-		-
-			message: """
-				#^Call to deprecated method expectError\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Render/ElementTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectErrorMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Render/ElementTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 3
-			path: tests/Drupal/Tests/Core/Routing/RouteBuilderTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarning\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Security/DoTrustedCallbackTraitTest.php
-
-		-
-			message: """
-				#^Call to deprecated method expectWarningMessage\\(\\) of class PHPUnit\\\\Framework\\\\TestCase\\:
-				https\\://github\\.com/sebastianbergmann/phpunit/issues/5062$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Security/DoTrustedCallbackTraitTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 2
-			path: tests/Drupal/Tests/Core/TempStore/PrivateTempStoreTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 3
-			path: tests/Drupal/Tests/Core/TempStore/SharedTempStoreTest.php
-
-		-
-			message: "#^Variable \\$value in isset\\(\\) always exists and is not nullable\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/Test/AssertContentTraitTest.php
-
-		-
-			message: "#^Call to deprecated method withConsecutive\\(\\) of class PHPUnit\\\\Framework\\\\MockObject\\\\Builder\\\\InvocationMocker\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Core/UrlTest.php
-
-		-
-			message: """
-				#^Class Drupal\\\\Tests\\\\Core\\\\Utility\\\\MockContainerAware implements deprecated interface Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareInterface\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Utility/CallableResolverTest.php
-
-		-
-			message: """
-				#^Usage of deprecated trait Symfony\\\\Component\\\\DependencyInjection\\\\ContainerAwareTrait in class Drupal\\\\Tests\\\\Core\\\\Utility\\\\MockContainerAware\\:
-				since Symfony 6\\.4, use dependency injection instead$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Core/Utility/CallableResolverTest.php
-
-		-
-			message: """
-				#^Call to deprecated method getConfig\\(\\) of class GuzzleHttp\\\\ClientInterface\\:
-				ClientInterface\\:\\:getConfig will be removed in guzzlehttp/guzzle\\:8\\.0\\.$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/DrupalTestBrowser.php
-
-		-
-			message: "#^Class Drupal\\\\Tests\\\\Listeners\\\\DrupalListener implements deprecated interface PHPUnit\\\\Framework\\\\TestListener\\.$#"
-			count: 1
-			path: tests/Drupal/Tests/Listeners/DrupalListener.php
-
-		-
-			message: """
-				#^Usage of deprecated trait PHPUnit\\\\Framework\\\\TestListenerDefaultImplementation in class Drupal\\\\Tests\\\\Listeners\\\\DrupalListener\\:
-				The `TestListener` interface is deprecated$#
-			"""
-			count: 1
-			path: tests/Drupal/Tests/Listeners/DrupalListener.php
diff --git a/web/core/phpstan.neon.dist b/web/core/phpstan.neon.dist
index f28e9249f514f279ccd74d1761101d36aaa64850..005b9ae84c87a8b77c5686569578abc851aeaca8 100644
--- a/web/core/phpstan.neon.dist
+++ b/web/core/phpstan.neon.dist
@@ -1,7 +1,7 @@
 # Configuration file for PHPStan static code checking, see https://phpstan.org .
 # PHPStan is triggered on Drupal CI in commit-code-check.sh.
 includes:
-  - phpstan-baseline.neon
+  - .phpstan-baseline.php
   - phar://phpstan.phar/conf/bleedingEdge.neon
 
 parameters:
diff --git a/web/core/profiles/demo_umami/tests/src/Functional/DemoUmamiProfileTest.php b/web/core/profiles/demo_umami/tests/src/Functional/DemoUmamiProfileTest.php
index bfe1fa7221d8c9bee1780f6e647e1ef5f9ee2af6..70f7e4e08ebb44537c364ad93d5aa012f034fc47 100644
--- a/web/core/profiles/demo_umami/tests/src/Functional/DemoUmamiProfileTest.php
+++ b/web/core/profiles/demo_umami/tests/src/Functional/DemoUmamiProfileTest.php
@@ -174,10 +174,10 @@ public function testEditNodesByAdmin() {
       ->loadByProperties(['title' => 'Deep mediterranean quiche']);
     $node = reset($nodes);
     $this->drupalGet($node->toUrl('edit-form'));
-    $webassert->statusCodeEquals('200');
+    $webassert->statusCodeEquals(200);
 
     $this->submitForm([], 'Preview');
-    $webassert->statusCodeEquals('200');
+    $webassert->statusCodeEquals(200);
     $this->assertSession()->elementsCount('css', 'h1', 1);
     $this->clickLink('Back to content editing');
 
@@ -221,27 +221,27 @@ protected function testDemonstrationWarningMessage() {
 
     // Check when editing a node, the warning is visible.
     $this->drupalGet($recipe_node->toUrl('edit-form'));
-    $web_assert->statusCodeEquals('200');
+    $web_assert->statusCodeEquals(200);
     $web_assert->pageTextContains('This site is intended for demonstration purposes.');
 
     // Check when adding a node, the warning is visible.
     $this->drupalGet('node/add/recipe');
-    $web_assert->statusCodeEquals('200');
+    $web_assert->statusCodeEquals(200);
     $web_assert->pageTextContains('This site is intended for demonstration purposes.');
 
     // Check when looking at admin/content, the warning is visible.
     $this->drupalGet('admin/content');
-    $web_assert->statusCodeEquals('200');
+    $web_assert->statusCodeEquals(200);
     $web_assert->pageTextContains('This site is intended for demonstration purposes.');
 
     // Check when viewing a node, the warning is not visible.
     $this->drupalGet($recipe_node->toUrl());
-    $web_assert->statusCodeEquals('200');
+    $web_assert->statusCodeEquals(200);
     $web_assert->pageTextNotContains('This site is intended for demonstration purposes.');
 
     // Check when viewing the homepage, the warning is not visible.
     $this->drupalGet('<front>');
-    $web_assert->statusCodeEquals('200');
+    $web_assert->statusCodeEquals(200);
     $web_assert->pageTextNotContains('This site is intended for demonstration purposes.');
   }
 
diff --git a/web/core/profiles/standard/config/install/core.entity_view_display.node.article.teaser.yml b/web/core/profiles/standard/config/install/core.entity_view_display.node.article.teaser.yml
index 0b6cffbe78f97f5cc1b221fb84d6205bb792b289..d1f0d8cef05d703e097d6f31d3076d36a08e32d7 100644
--- a/web/core/profiles/standard/config/install/core.entity_view_display.node.article.teaser.yml
+++ b/web/core/profiles/standard/config/install/core.entity_view_display.node.article.teaser.yml
@@ -50,5 +50,3 @@ content:
     region: content
 hidden:
   comment: true
-  field_image: true
-  field_tags: true
diff --git a/web/core/profiles/test_language_negotiation/config/install/language.types.yml b/web/core/profiles/test_language_negotiation/config/install/language.types.yml
new file mode 100644
index 0000000000000000000000000000000000000000..9e411ba2c495538c5def06656685c3b1de3aa2d1
--- /dev/null
+++ b/web/core/profiles/test_language_negotiation/config/install/language.types.yml
@@ -0,0 +1,39 @@
+all:
+  - language_interface
+  - language_content
+  - language_url
+configurable:
+  - language_interface
+  - language_content
+negotiation:
+  language_content:
+    enabled:
+      test_language_negotiation_method: -10
+      language-url: -8
+      language-selected: 12
+    method_weights:
+      test_language_negotiation_method: -10
+      language-content-entity: -9
+      language-url: -8
+      language-session: -6
+      language-user: -4
+      language-browser: -2
+      language-interface: 9
+      language-selected: 12
+  language_url:
+    enabled:
+      language-url: 0
+      language-url-fallback: 1
+  language_interface:
+    enabled:
+      language-user-admin: -20
+      language-user: -19
+      language-url: -18
+      language-selected: -15
+    method_weights:
+      language-user-admin: -20
+      language-user: -19
+      language-url: -18
+      language-session: -17
+      language-browser: -16
+      language-selected: -15
diff --git a/web/core/profiles/test_language_negotiation/test_language_negotiation.info.yml b/web/core/profiles/test_language_negotiation/test_language_negotiation.info.yml
new file mode 100644
index 0000000000000000000000000000000000000000..a83b1cfb4347828417d8e6fb5ca7730a102211a3
--- /dev/null
+++ b/web/core/profiles/test_language_negotiation/test_language_negotiation.info.yml
@@ -0,0 +1,7 @@
+name: Testing language negotiation
+type: profile
+description: 'Minimal profile for running tests related the language negotiation.'
+version: VERSION
+hidden: true
+install:
+  - drupal:language
diff --git a/web/core/scripts/dev/commit-code-check.sh b/web/core/scripts/dev/commit-code-check.sh
index cc3c4bf2824a04969af95eefea48db0c9588bd12..0a1672b9c7405a54425aa56949a8d41871fea70c 100755
--- a/web/core/scripts/dev/commit-code-check.sh
+++ b/web/core/scripts/dev/commit-code-check.sh
@@ -112,7 +112,7 @@
 # This variable will be set to one when the file core/phpcs.xml.dist is changed.
 PHPCS_XML_DIST_FILE_CHANGED=0
 
-# This variable will be set to one when the files core/phpstan-baseline.neon or
+# This variable will be set to one when the files core/.phpstan-baseline.php or
 # core/phpstan.neon.dist are changed.
 PHPSTAN_DIST_FILE_CHANGED=0
 
@@ -153,7 +153,7 @@
     PHPCS_XML_DIST_FILE_CHANGED=1;
   fi;
 
-  if [[ $FILE == "core/phpstan-baseline.neon" || $FILE == "core/phpstan.neon.dist" ]]; then
+  if [[ $FILE == "core/.phpstan-baseline.php" || $FILE == "core/phpstan.neon.dist" ]]; then
     PHPSTAN_DIST_FILE_CHANGED=1;
   fi;
 
diff --git a/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/FormGroupingElementsTest.php b/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/FormGroupingElementsTest.php
index e289fc48baa2ffe89ba1f72e2393c14433bc625d..57f139442ed3a3cf58f899648d123589279c5744 100644
--- a/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/FormGroupingElementsTest.php
+++ b/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/FormGroupingElementsTest.php
@@ -134,7 +134,6 @@ public function testDetailsChildVisibility() {
 
     // Assert that both aria-expanded and aria-pressed are true.
     $this->assertEquals('true', $summary->getAttribute('aria-expanded'));
-    $this->assertEquals('true', $summary->getAttribute('aria-pressed'));
   }
 
   /**
@@ -166,4 +165,53 @@ public function testVerticalTabValidationVisibility() {
     $this->assertNotNull($assert_session->waitForElementVisible('css', '[name="element_2"].error'));
   }
 
+  /**
+   * Tests form submit with a required field in closed details element.
+   */
+  public function testDetailsContainsRequiredTextfield(): void {
+    $this->drupalGet('form_test/details-contains-required-textfield');
+    $details = $this->assertSession()->elementExists('css', 'details[data-drupal-selector="edit-meta"]');
+
+    // Make sure details element is not open at the beginning.
+    $this->assertFalse($details->hasAttribute('open'));
+
+    $textfield = $this->assertSession()->elementExists('css', 'input[name="required_textfield_in_details"]');
+
+    // The text field inside the details element is not visible too.
+    $this->assertFalse($textfield->isVisible(), 'Text field is not visible');
+
+    // Submit the form with invalid data in the required fields.
+    $this->assertSession()
+      ->elementExists('css', 'input[data-drupal-selector="edit-submit"]')
+      ->click();
+    // Confirm the required field is visible.
+    $this->assertTrue($textfield->isVisible(), 'Text field is visible');
+  }
+
+  /**
+   * Tests required field in closed details element with ajax form.
+   */
+  public function testDetailsContainsRequiredTextfieldAjaxForm(): void {
+    $this->drupalGet('form_test/details-contains-required-textfield/true');
+    $assert_session = $this->assertSession();
+    $textfield = $assert_session->elementExists('css', 'input[name="required_textfield_in_details"]');
+
+    // Submit the ajax form to open the details element at the first time.
+    $assert_session->elementExists('css', 'input[value="Submit Ajax"]')
+      ->click();
+
+    $assert_session->waitForElementVisible('css', 'input[name="required_textfield_in_details"]');
+
+    // Close the details element.
+    $assert_session->elementExists('css', 'form summary')
+      ->click();
+
+    // Submit the form with invalid data in the required fields without ajax.
+    $assert_session->elementExists('css', 'input[data-drupal-selector="edit-submit"]')
+      ->click();
+
+    // Confirm the required field is visible.
+    $this->assertTrue($textfield->isVisible(), 'Text field is visible');
+  }
+
 }
diff --git a/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/JavascriptStatesTest.php b/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/JavascriptStatesTest.php
index ab7425a252d8008c1806ac0e6f8490f48999073c..b5c0d9178906e38fc19aa3f067d3c9d6ae4325f7 100644
--- a/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/JavascriptStatesTest.php
+++ b/web/core/tests/Drupal/FunctionalJavascriptTests/Core/Form/JavascriptStatesTest.php
@@ -69,8 +69,10 @@ public function testJavascriptStates() {
     $this->doTextfieldTriggerTests();
     $this->doRadiosTriggerTests();
     $this->doSelectTriggerTests();
+    $this->doMultipleSelectTriggerTests();
     $this->doMultipleTriggerTests();
     $this->doNestedTriggerTests();
+    $this->doElementsDisabledStateTests();
   }
 
   /**
@@ -443,6 +445,63 @@ protected function doSelectTriggerTests() {
     $this->assertTrue($textfield_visible_value2_or_value3->isVisible());
   }
 
+  /**
+   * Tests states of elements triggered by a multiple select element.
+   */
+  protected function doMultipleSelectTriggerTests() {
+    $this->drupalGet('form-test/javascript-states-form');
+    $page = $this->getSession()->getPage();
+    // Find trigger and target elements.
+    $trigger = $page->findField('multiple_select_trigger[]');
+    $this->assertNotEmpty($trigger);
+    $item_visible_value2 = $this->assertSession()->elementExists('css', '#edit-item-visible-when-multiple-select-trigger-has-value2');
+    $item_visible_no_value = $this->assertSession()->elementExists('css', '#edit-item-visible-when-multiple-select-trigger-has-no-value');
+    $textfield_visible_value3 = $page->findField('textfield_visible_when_multiple_select_trigger_has_value3');
+    $this->assertNotEmpty($textfield_visible_value3);
+    $textfield_visible_value2_or_value3 = $page->findField('textfield_visible_when_multiple_select_trigger_has_value2_or_value3');
+    $this->assertNotEmpty($textfield_visible_value2_or_value3);
+    $textfield_visible_value2_and_value3 = $page->findField('textfield_visible_when_multiple_select_trigger_has_value2_and_value3');
+    $this->assertNotEmpty($textfield_visible_value2_and_value3);
+
+    // Verify initial state.
+    $this->assertFalse($item_visible_value2->isVisible());
+    $this->assertTrue($item_visible_no_value->isVisible());
+    $this->assertFalse($textfield_visible_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_or_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_and_value3->isVisible());
+    // Change state: select the 'Value 2' option.
+    $trigger->setValue('value2');
+    $this->assertTrue($item_visible_value2->isVisible());
+    $this->assertFalse($item_visible_no_value->isVisible());
+    $this->assertFalse($textfield_visible_value3->isVisible());
+    $this->assertTrue($textfield_visible_value2_or_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_and_value3->isVisible());
+    // Change state: select the 'Value 3' option.
+    $trigger->setValue('value3');
+    $this->assertFalse($item_visible_value2->isVisible());
+    $this->assertFalse($item_visible_no_value->isVisible());
+    $this->assertTrue($textfield_visible_value3->isVisible());
+    $this->assertTrue($textfield_visible_value2_or_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_and_value3->isVisible());
+    // Change state: select 'Value2' and 'Value 3' options.
+    $trigger->setValue(['value2', 'value3']);
+    $this->assertFalse($item_visible_value2->isVisible());
+    $this->assertFalse($item_visible_no_value->isVisible());
+    $this->assertFalse($textfield_visible_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_or_value3->isVisible());
+    $this->assertTrue($textfield_visible_value2_and_value3->isVisible());
+    // Restore initial trigger state (clear the values).
+    $trigger->setValue([]);
+    // Make sure the initial element states are restored.
+    $this->assertFalse($item_visible_value2->isVisible());
+    $this->assertFalse($textfield_visible_value3->isVisible());
+    $this->assertFalse($textfield_visible_value2_or_value3->isVisible());
+    // @todo These last two look to be correct, but the assertion is failing.
+    // @see https://www.drupal.org/project/drupal/issues/3367310
+    // $this->assertTrue($item_visible_no_value->isVisible());
+    // $this->assertFalse($textfield_visible_value2_and_value3->isVisible());
+  }
+
   /**
    * Tests states of elements triggered by multiple elements.
    */
@@ -493,4 +552,47 @@ protected function doNestedTriggerTests() {
     $this->assertEquals('1', $radios_opposite2->getValue());
   }
 
+  /**
+   * Tests the submit button, select and textarea disabled states.
+   *
+   * The element should be disabled when visit the form
+   * then they should enable when trigger by a checkbox.
+   */
+  public function doElementsDisabledStateTests(): void {
+    $this->drupalGet('form-test/javascript-states-form');
+    $session = $this->assertSession();
+
+    // The submit button should be disabled when visit the form.
+    $button = $session->elementExists('css', 'input[value="Submit button disabled when checkbox not checked"]');
+    $this->assertTrue($button->hasAttribute('disabled'));
+
+    // The submit button should be enabled when the checkbox is checked.
+    $session->elementExists('css', 'input[name="checkbox_enable_submit_button"]')->check();
+    $this->assertFalse($button->hasAttribute('disabled'));
+
+    // The text field should be disabled when visit the form.
+    $textfield = $session->elementExists('css', 'input[name="input_textfield"]');
+    $this->assertTrue($textfield->hasAttribute('disabled'));
+
+    // The text field should be enabled when the checkbox is checked.
+    $session->elementExists('css', 'input[name="checkbox_enable_input_textfield"]')->check();
+    $this->assertFalse($textfield->hasAttribute('disabled'));
+
+    // The select should be disabled when visit the form.
+    $select = $session->elementExists('css', 'select[name="test_select_disabled"]');
+    $this->assertTrue($select->hasAttribute('disabled'));
+
+    // The select should be enabled when the checkbox is checked.
+    $session->elementExists('css', 'input[name="checkbox_enable_select"]')->check();
+    $this->assertFalse($select->hasAttribute('disabled'));
+
+    // The textarea should be disabled when visit the form.
+    $textarea = $session->elementExists('css', 'textarea[name="test_textarea_disabled"]');
+    $this->assertTrue($textarea->hasAttribute('disabled'));
+
+    // The textarea should be enabled when the checkbox is checked.
+    $session->elementExists('css', 'input[name="checkbox_enable_textarea"]')->check();
+    $this->assertFalse($textarea->hasAttribute('disabled'));
+  }
+
 }
diff --git a/web/core/tests/Drupal/FunctionalJavascriptTests/MachineName/MachineNameTransliterationTest.php b/web/core/tests/Drupal/FunctionalJavascriptTests/MachineName/MachineNameTransliterationTest.php
index 8a6c37db1aed2b4e6bb038126d1850e0c02507a3..d223feab7b5a8d377314f771068e95794f73f2e6 100644
--- a/web/core/tests/Drupal/FunctionalJavascriptTests/MachineName/MachineNameTransliterationTest.php
+++ b/web/core/tests/Drupal/FunctionalJavascriptTests/MachineName/MachineNameTransliterationTest.php
@@ -12,6 +12,7 @@
  * Tests the machine name transliteration functionality.
  *
  * @group javascript
+ * @group #slow
  */
 class MachineNameTransliterationTest extends WebDriverTestBase {
 
diff --git a/web/core/tests/Drupal/FunctionalTests/BrowserTestBaseTest.php b/web/core/tests/Drupal/FunctionalTests/BrowserTestBaseTest.php
index 6ab657c6e0a6d92bae5bb656ed2cb6779486a4a2..e151df9926f00a6c429c57a6e48007aec109ec09 100644
--- a/web/core/tests/Drupal/FunctionalTests/BrowserTestBaseTest.php
+++ b/web/core/tests/Drupal/FunctionalTests/BrowserTestBaseTest.php
@@ -359,13 +359,13 @@ public function testFieldAssertsForCheckbox() {
 
     // Part 1 - Test by name.
     // Test that checkboxes are found/not found correctly by name, when using
-    // TRUE or FALSE to match their 'checked' state.
+    // '1' or '' to match their 'checked' state.
     $this->assertSession()->fieldExists('checkbox_enabled');
     $this->assertSession()->fieldExists('checkbox_disabled');
-    $this->assertSession()->fieldValueEquals('checkbox_enabled', TRUE);
-    $this->assertSession()->fieldValueEquals('checkbox_disabled', FALSE);
-    $this->assertSession()->fieldValueNotEquals('checkbox_enabled', FALSE);
-    $this->assertSession()->fieldValueNotEquals('checkbox_disabled', TRUE);
+    $this->assertSession()->fieldValueEquals('checkbox_enabled', '1');
+    $this->assertSession()->fieldValueEquals('checkbox_disabled', '');
+    $this->assertSession()->fieldValueNotEquals('checkbox_enabled', '');
+    $this->assertSession()->fieldValueNotEquals('checkbox_disabled', '1');
 
     // Test that we have legacy support.
     $this->assertSession()->fieldValueEquals('checkbox_enabled', '1');
@@ -373,7 +373,7 @@ public function testFieldAssertsForCheckbox() {
 
     // Test that the assertion fails correctly if given the right value.
     try {
-      $this->assertSession()->fieldValueNotEquals('checkbox_enabled', TRUE);
+      $this->assertSession()->fieldValueNotEquals('checkbox_enabled', '1');
       $this->fail('fieldValueNotEquals failed to throw an exception.');
     }
     catch (ExpectationException $e) {
@@ -382,11 +382,11 @@ public function testFieldAssertsForCheckbox() {
 
     // Part 2 - Test by ID.
     // Test that checkboxes are found/not found correctly by ID, when using
-    // TRUE or FALSE to match their 'checked' state.
-    $this->assertSession()->fieldValueEquals('edit-checkbox-enabled', TRUE);
-    $this->assertSession()->fieldValueEquals('edit-checkbox-disabled', FALSE);
-    $this->assertSession()->fieldValueNotEquals('edit-checkbox-enabled', FALSE);
-    $this->assertSession()->fieldValueNotEquals('edit-checkbox-disabled', TRUE);
+    // '1' or '' to match their 'checked' state.
+    $this->assertSession()->fieldValueEquals('edit-checkbox-enabled', '1');
+    $this->assertSession()->fieldValueEquals('edit-checkbox-disabled', '');
+    $this->assertSession()->fieldValueNotEquals('edit-checkbox-enabled', '');
+    $this->assertSession()->fieldValueNotEquals('edit-checkbox-disabled', '1');
 
     // Test that checkboxes are found by ID, when using NULL to ignore the
     // 'checked' state.
@@ -572,11 +572,11 @@ public function testDeprecationHeaders() {
    * Tests the dump() function provided by the var-dumper Symfony component.
    */
   public function testVarDump() {
-    // Append the stream capturer to the STDOUT stream, so that we can test the
+    // Append the stream capturer to the STDERR stream, so that we can test the
     // dump() output and also prevent it from actually outputting in this
     // particular test.
     stream_filter_register("capture", StreamCapturer::class);
-    stream_filter_append(STDOUT, "capture");
+    stream_filter_append(STDERR, "capture");
 
     // Dump some variables to check that dump() in test code produces output
     // on the command line that is running the test.
diff --git a/web/core/tests/Drupal/FunctionalTests/Datetime/TimestampTest.php b/web/core/tests/Drupal/FunctionalTests/Datetime/TimestampTest.php
index c84e0c875d284349f1b64163f31d0a5198bebc4d..e25448d6a181170777939a6ab5fc18d060af1ebb 100644
--- a/web/core/tests/Drupal/FunctionalTests/Datetime/TimestampTest.php
+++ b/web/core/tests/Drupal/FunctionalTests/Datetime/TimestampTest.php
@@ -152,6 +152,25 @@ public function testWidget() {
     $medium = DateFormat::load('medium')->getPattern();
     $this->drupalGet('entity_test/' . $id);
     $this->assertSession()->pageTextContains($date->format($medium));
+
+    // Build up a date in the UTC timezone.
+    $value = '2024-01-16 00:00:00';
+    $date = new DrupalDateTime($value, 'UTC');
+
+    // Set a default value for the field.
+    $this->field->setDefaultValue($date->getTimestamp())->save();
+
+    // Update the timezone to the system default.
+    $date->setTimezone(timezone_open(date_default_timezone_get()));
+
+    $this->drupalGet('entity_test/add');
+    $date_format = DateFormat::load('html_date')->getPattern();
+    $time_format = DateFormat::load('html_time')->getPattern();
+    // Make sure the default field value is set as the default value in the widget.
+    $this->assertSession()->fieldExists('field_timestamp[0][value][date]');
+    $this->assertSession()->fieldValueEquals('field_timestamp[0][value][date]', $date->format($date_format));
+    $this->assertSession()->fieldExists('field_timestamp[0][value][time]');
+    $this->assertSession()->fieldValueEquals('field_timestamp[0][value][time]', $date->format($time_format));
   }
 
 }
diff --git a/web/core/tests/Drupal/KernelTests/Config/DefaultConfigTest.php b/web/core/tests/Drupal/KernelTests/Config/DefaultConfigTest.php
index 396623bec75eed4c888970fa359fceca448ce259..2f35f8b7d08b8d509f0a71bf82f9a7e8fe85aed4 100644
--- a/web/core/tests/Drupal/KernelTests/Config/DefaultConfigTest.php
+++ b/web/core/tests/Drupal/KernelTests/Config/DefaultConfigTest.php
@@ -49,7 +49,7 @@ class DefaultConfigTest extends KernelTestBase {
    *
    * @dataProvider moduleListDataProvider
    */
-  public function testModuleConfig($module) {
+  public function testModuleConfig(string $module): void {
     $this->assertExtensionConfig($module, 'module');
   }
 
@@ -171,8 +171,8 @@ public function themeListDataProvider() {
    *   An array of module names to test, with both key and value being the name
    *   of the module.
    */
-  public function moduleListDataProvider() {
-    $modules_keyed = $this->coreModuleListDataProvider();
+  public static function moduleListDataProvider(): array {
+    $modules_keyed = self::coreModuleListDataProvider();
 
     // Add a deprecated module with config.
     $modules_keyed['deprecated_module'] = ['deprecated_module'];
diff --git a/web/core/tests/Drupal/KernelTests/Core/Config/ConfigExistsConstraintValidatorTest.php b/web/core/tests/Drupal/KernelTests/Core/Config/ConfigExistsConstraintValidatorTest.php
index 03992fd9c92180d5906a921169657de3198526d1..bb94ae83d7955040dc8d56fb272ab701a53fb54e 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Config/ConfigExistsConstraintValidatorTest.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Config/ConfigExistsConstraintValidatorTest.php
@@ -40,6 +40,10 @@ public function testValidation(): void {
 
     $this->installConfig('system');
     $this->assertCount(0, $data->validate());
+
+    // NULL should not trigger a validation error: a value may be nullable.
+    $data->setValue(NULL);
+    $this->assertCount(0, $data->validate());
   }
 
 }
diff --git a/web/core/tests/Drupal/KernelTests/Core/Database/DriverSpecificTransactionTestBase.php b/web/core/tests/Drupal/KernelTests/Core/Database/DriverSpecificTransactionTestBase.php
index 5d91cbd8ee74aaa321d140f444ec22ba46c58adf..61f51dc81a6486f1b3f8d0cc131c6ccf813c8831 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Database/DriverSpecificTransactionTestBase.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Database/DriverSpecificTransactionTestBase.php
@@ -3,8 +3,10 @@
 namespace Drupal\KernelTests\Core\Database;
 
 use Drupal\Core\Database\Database;
+use Drupal\Core\Database\Transaction\ClientConnectionTransactionState;
 use Drupal\Core\Database\Transaction\StackItem;
 use Drupal\Core\Database\Transaction\StackItemType;
+use Drupal\Core\Database\Transaction\TransactionManagerBase;
 use Drupal\Core\Database\TransactionExplicitCommitNotAllowedException;
 use Drupal\Core\Database\TransactionNameNonUniqueException;
 use Drupal\Core\Database\TransactionOutOfOrderException;
@@ -885,11 +887,30 @@ public function testTransactionManagerFailureOnPendingStackItems(): void {
     $testConnection = Database::getConnection('test_fail');
 
     // Add a fake item to the stack.
-    $reflectionMethod = new \ReflectionMethod(get_class($testConnection->transactionManager()), 'addStackItem');
-    $reflectionMethod->invoke($testConnection->transactionManager(), 'bar', new StackItem('qux', StackItemType::Savepoint));
+    $manager = $testConnection->transactionManager();
+    $reflectionMethod = new \ReflectionMethod($manager, 'addStackItem');
+    $reflectionMethod->invoke($manager, 'bar', new StackItem('qux', StackItemType::Root));
+    // Ensure transaction state can be determined during object destruction.
+    // This is necessary for the test to pass when xdebug.mode has the 'develop'
+    // option enabled.
+    $reflectionProperty = new \ReflectionProperty(TransactionManagerBase::class, 'connectionTransactionState');
+    $reflectionProperty->setValue($manager, ClientConnectionTransactionState::Active);
+
+    // Ensure that __destruct() results in an assertion error. Note that this
+    // will normally be called by PHP during the object's destruction but Drupal
+    // will commit all transactions when a database is closed thereby making
+    // this impossible to test unless it is called directly.
+    try {
+      $manager->__destruct();
+      $this->fail("Expected AssertionError error not thrown");
+    }
+    catch (\AssertionError $e) {
+      $this->assertStringStartsWith('Transaction $stack was not empty. Active stack: bar\\qux', $e->getMessage());
+    }
 
-    $this->expectException(\AssertionError::class);
-    $this->expectExceptionMessageMatches("/^Transaction .stack was not empty\\. Active stack: bar\\\\qux/");
+    // Clean up.
+    $reflectionProperty = new \ReflectionProperty(TransactionManagerBase::class, 'stack');
+    $reflectionProperty->setValue($manager, []);
     unset($testConnection);
     Database::closeConnection('test_fail');
   }
@@ -932,6 +953,10 @@ public function testConnectionDeprecations(): void {
     $this->expectDeprecation('Drupal\\Core\\Database\\Connection::popCommittableTransactions() is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use TransactionManagerInterface methods instead. See https://www.drupal.org/node/3381002');
     $this->expectDeprecation('Drupal\\Core\\Database\\Connection::doCommit() is deprecated in drupal:10.2.0 and is removed from drupal:11.0.0. Use TransactionManagerInterface methods instead. See https://www.drupal.org/node/3381002');
     $this->connection->popTransaction('foo');
+
+    // Ensure there are no outstanding transactions left. This is necessary for
+    // the test to pass when xdebug.mode has the 'develop' option enabled.
+    $this->connection->commitAll();
   }
 
 }
diff --git a/web/core/tests/Drupal/KernelTests/Core/Entity/ConfigEntityQueryTest.php b/web/core/tests/Drupal/KernelTests/Core/Entity/ConfigEntityQueryTest.php
index 18ee774338a79ae4f78891002b55d7777e7ca615..c0a0172a8f507a0bfd90ffdca767a4a140a6709d 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Entity/ConfigEntityQueryTest.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Entity/ConfigEntityQueryTest.php
@@ -499,6 +499,40 @@ public function testSortRange() {
       ->execute();
     $this->assertSame(['1', '2', '3'], array_values($this->queryResults));
 
+    // Omit optional parameters for the range and sort.
+    $this->queryResults = $this->entityStorage->getQuery()
+      ->range()
+      ->sort('id')
+      ->execute();
+    $this->assertSame(['1', '2', '3', '4', '5', '6', '7'], array_values($this->queryResults));
+
+    // Explicitly pass NULL for the range and sort.
+    $this->queryResults = $this->entityStorage->getQuery()
+      ->range(NULL, NULL)
+      ->sort('id')
+      ->execute();
+    $this->assertSame(['1', '2', '3', '4', '5', '6', '7'], array_values($this->queryResults));
+
+    // Omit the optional start parameter for the range.
+    $this->queryResults = $this->entityStorage->getQuery()
+      ->range(NULL, 1)
+      ->sort('id')
+      ->execute();
+    $this->assertSame(['1'], array_values($this->queryResults));
+
+    // Omit the optional length parameter for the range.
+    $this->queryResults = $this->entityStorage->getQuery()
+      ->range(4)
+      ->sort('id')
+      ->execute();
+    $this->assertSame(['5', '6', '7'], array_values($this->queryResults));
+
+    // Request an empty range.
+    $this->queryResults = $this->entityStorage->getQuery()
+      ->range(0, 0)
+      ->execute();
+    $this->assertEmpty($this->queryResults);
+
     // Apply a pager with limit 4.
     $this->queryResults = $this->entityStorage->getQuery()
       ->pager('4', 0)
diff --git a/web/core/tests/Drupal/KernelTests/Core/Extension/ExtensionExistsConstraintValidatorTest.php b/web/core/tests/Drupal/KernelTests/Core/Extension/ExtensionExistsConstraintValidatorTest.php
index f698279a56d6d1287f8883d234428bf61d6f4f46..9fec10ddff0808bdcd865d926de1acd9c8758571 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Extension/ExtensionExistsConstraintValidatorTest.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Extension/ExtensionExistsConstraintValidatorTest.php
@@ -31,8 +31,13 @@ public function testValidation(): void {
 
     /** @var \Drupal\Core\TypedData\TypedDataManagerInterface $typed_data */
     $typed_data = $this->container->get('typed_data_manager');
-    $data = $typed_data->create($definition, 'user');
 
+    // `core` provides many plugins without the need to install a module.
+    $data = $typed_data->create($definition, 'core');
+    $violations = $data->validate();
+    $this->assertCount(0, $violations);
+
+    $data->setValue('user');
     $violations = $data->validate();
     $this->assertCount(1, $violations);
     $this->assertSame("Module 'user' is not installed.", (string) $violations->get(0)->getMessage());
@@ -40,6 +45,10 @@ public function testValidation(): void {
     $this->enableModules(['user']);
     $this->assertCount(0, $data->validate());
 
+    // NULL should not trigger a validation error: a value may be nullable.
+    $data->setValue(NULL);
+    $this->assertCount(0, $data->validate());
+
     $definition->setConstraints(['ExtensionExists' => 'theme']);
     $data = $typed_data->create($definition, 'stark');
 
@@ -56,6 +65,17 @@ public function testValidation(): void {
       ->create($definition, 'stark');
     $this->assertCount(0, $data->validate());
 
+    // `core` provides many plugins without the need to install a module, but it
+    // does not work for themes.
+    $data = $typed_data->create($definition, 'core');
+    $violations = $data->validate();
+    $this->assertCount(1, $violations);
+    $this->assertSame("Theme 'core' is not installed.", (string) $violations->get(0)->getMessage());
+
+    // NULL should not trigger a validation error: a value may be nullable.
+    $data->setValue(NULL);
+    $this->assertCount(0, $data->validate());
+
     // Anything but a module or theme should raise an exception.
     $definition->setConstraints(['ExtensionExists' => 'profile']);
     $this->expectExceptionMessage("Unknown extension type: 'profile'");
diff --git a/web/core/tests/Drupal/KernelTests/Core/Installer/InstallerRedirectTraitTest.php b/web/core/tests/Drupal/KernelTests/Core/Installer/InstallerRedirectTraitTest.php
index 6b897941512acfeb7ee72bb958aa9fed9cd0b920..20d02777b106dd8601e9627552c7227308daa4c2 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Installer/InstallerRedirectTraitTest.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Installer/InstallerRedirectTraitTest.php
@@ -73,9 +73,9 @@ public function testShouldRedirectToInstaller($expected, $exception, $connection
     }
     catch (\Exception $e) {
       // Mock the trait.
-      $trait = $this->getMockBuilder(InstallerRedirectTrait::class)
+      $trait = $this->getMockBuilder(InstallerRedirectTraitMockableClass::class)
         ->onlyMethods(['isCli'])
-        ->getMockForTrait();
+        ->getMock();
 
       // Make sure that the method thinks we are not using the cli.
       $trait->expects($this->any())
@@ -125,3 +125,12 @@ public function testShouldRedirectToInstaller($expected, $exception, $connection
   }
 
 }
+
+/**
+ * A class using the InstallerRedirectTrait for mocking purposes.
+ */
+class InstallerRedirectTraitMockableClass {
+
+  use InstallerRedirectTrait;
+
+}
diff --git a/web/core/tests/Drupal/KernelTests/Core/Validation/UniqueValuesConstraintValidatorTest.php b/web/core/tests/Drupal/KernelTests/Core/Validation/UniqueValuesConstraintValidatorTest.php
index 7bfd326bc204cd0afacb64d9359fb0ca0ffb5053..dd8f0d3eff2ae05db3e96c9372979cb690a7d413 100644
--- a/web/core/tests/Drupal/KernelTests/Core/Validation/UniqueValuesConstraintValidatorTest.php
+++ b/web/core/tests/Drupal/KernelTests/Core/Validation/UniqueValuesConstraintValidatorTest.php
@@ -288,4 +288,42 @@ public function testValidationMultiple() {
 
   }
 
+  /**
+   * Tests the UniqueField validation constraint validator with regards to case-insensitivity.
+   *
+   * Case 5. Try to create another entity with existing value for unique field with different capitalization.
+   *
+   * @throws \Drupal\Core\Entity\EntityStorageException
+   *
+   * @covers ::validate
+   */
+  public function testValidationCaseInsensitive(): void {
+    // Create entity with two values for the testing field.
+    $definition = [
+      'id' => (int) rand(0, getrandmax()),
+      'user_id' => 0,
+      'field_test_text' => [
+        'text1',
+        'text2',
+      ],
+    ];
+    $entity = EntityTestUniqueConstraint::create($definition);
+    $entity->save();
+
+    // Create another entity with two values for the testing field, one identical
+    // to other value, but with different capitalization which should still trigger a validation error.
+    $definition = [
+      'id' => (int) rand(0, getrandmax()),
+      'user_id' => 0,
+      'field_test_text' => [
+        'Text1',
+        'text3',
+      ],
+    ];
+    $entity = EntityTestUniqueConstraint::create($definition);
+    $violations = $entity->validate();
+    $this->assertCount(1, $violations);
+    $this->assertEquals('field_test_text.0', $violations[0]->getPropertyPath());
+  }
+
 }
diff --git a/web/core/tests/Drupal/KernelTests/FileSystemModuleDiscoveryDataProviderTrait.php b/web/core/tests/Drupal/KernelTests/FileSystemModuleDiscoveryDataProviderTrait.php
index c955289fcfc79aa09865d726dc77b3df37c00d6b..9c142ae0d4bf0866980dfe33c311a8b3b8c7d146 100644
--- a/web/core/tests/Drupal/KernelTests/FileSystemModuleDiscoveryDataProviderTrait.php
+++ b/web/core/tests/Drupal/KernelTests/FileSystemModuleDiscoveryDataProviderTrait.php
@@ -13,7 +13,7 @@ trait FileSystemModuleDiscoveryDataProviderTrait {
    * @return array
    *   An array of module names to test.
    */
-  public function coreModuleListDataProvider() {
+  public static function coreModuleListDataProvider(): array {
     $prefix = dirname(__DIR__, 3) . DIRECTORY_SEPARATOR . 'modules';
     $module_dirs = array_keys(iterator_to_array(new \FilesystemIterator($prefix)));
     $module_names = array_map(function ($path) use ($prefix) {
diff --git a/web/core/tests/Drupal/KernelTests/KernelTestBaseTest.php b/web/core/tests/Drupal/KernelTests/KernelTestBaseTest.php
index f22ae1db2288b5b13f48acc7e99f16bddc62905d..91984854a302d66d73d59cd0cc03f2718c1a1805 100644
--- a/web/core/tests/Drupal/KernelTests/KernelTestBaseTest.php
+++ b/web/core/tests/Drupal/KernelTests/KernelTestBaseTest.php
@@ -341,11 +341,11 @@ public function testProfileModules() {
    * Tests the dump() function provided by the var-dumper Symfony component.
    */
   public function testVarDump() {
-    // Append the stream capturer to the STDOUT stream, so that we can test the
+    // Append the stream capturer to the STDERR stream, so that we can test the
     // dump() output and also prevent it from actually outputting in this
     // particular test.
     stream_filter_register("capture", StreamCapturer::class);
-    stream_filter_append(STDOUT, "capture");
+    stream_filter_append(STDERR, "capture");
 
     // Dump some variables.
     $this->enableModules(['system', 'user']);
diff --git a/web/core/tests/Drupal/TestTools/TestVarDumper.php b/web/core/tests/Drupal/TestTools/TestVarDumper.php
index 67d6136e155f909be5c0ed6f8e5f47af283cda39..dbf5af90f971807d885bfc0ba82bfbc2fcb333bc 100644
--- a/web/core/tests/Drupal/TestTools/TestVarDumper.php
+++ b/web/core/tests/Drupal/TestTools/TestVarDumper.php
@@ -22,7 +22,7 @@ class TestVarDumper {
   public static function cliHandler($var) {
     $cloner = new VarCloner();
     $dumper = new CliDumper();
-    fwrite(STDOUT, "\n");
+    fwrite(STDERR, "\n");
     $dumper->setColors(TRUE);
     $dumper->dump(
       $cloner->cloneVar($var),
@@ -30,7 +30,7 @@ function ($line, $depth, $indent_pad) {
         // A negative depth means "end of dump".
         if ($depth >= 0) {
           // Adds a two spaces indentation to the line.
-          fwrite(STDOUT, str_repeat($indent_pad, $depth) . $line . "\n");
+          fwrite(STDERR, str_repeat($indent_pad, $depth) . $line . "\n");
         }
       }
     );
diff --git a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/Attribute/Nonexistent.php b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/Attribute/Nonexistent.php
new file mode 100644
index 0000000000000000000000000000000000000000..45ed519aa40da8a60867f6d54203b4e13501ed2b
--- /dev/null
+++ b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/Attribute/Nonexistent.php
@@ -0,0 +1,9 @@
+<?php
+
+namespace Drupal\Tests\Component\Annotation\Doctrine\Fixtures\Attribute;
+
+// @phpstan-ignore-next-line
+#[NonexistentAttribute]
+final class Nonexistent
+{
+}
diff --git a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleAttribute.php b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleAttribute.php
index 0275fabb56f80042ee169b920c2788f732848435..abcd69fa12918af9c65ac4045b72a3571eed91b7 100644
--- a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleAttribute.php
+++ b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleAttribute.php
@@ -3,6 +3,6 @@
 namespace Drupal\Tests\Component\Annotation\Doctrine\Fixtures\ExtraAttributes;
 
 #[\Attribute]
-final class ExampleAttribute
+final class ExampleAttribute extends ExampleParentAttribute
 {
 }
diff --git a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleParentAttribute.php b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleParentAttribute.php
new file mode 100644
index 0000000000000000000000000000000000000000..ea1eaaa0f89afe12683552ab30dd391c5a3589c1
--- /dev/null
+++ b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleParentAttribute.php
@@ -0,0 +1,8 @@
+<?php
+
+namespace Drupal\Tests\Component\Annotation\Doctrine\Fixtures\ExtraAttributes;
+
+#[\Attribute]
+class ExampleParentAttribute {
+
+}
diff --git a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/StaticReflectionParserTest.php b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/StaticReflectionParserTest.php
index d929e48f6120b1cd902c38b818d61811e30335a9..85a99f3c353b6ee12467905c74629937385bead0 100644
--- a/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/StaticReflectionParserTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/StaticReflectionParserTest.php
@@ -15,8 +15,10 @@ class StaticReflectionParserTest extends TestCase {
 
   /**
    * @testWith ["AttributeClass", "\\Attribute", true]
+   *           ["AttributeClass", "attribute", true]
    *           ["AttributeClass", "Attribute", true]
    *           ["AttributeClass", "\\DoesNotExist", false]
+   *           ["Nonexistent", "NonexistentAttribute", false]
    *           ["MultipleAttributes", "Attribute", true]
    *           ["MultipleAttributes", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\Attribute\\AttributeClass", true]
    *           ["MultipleAttributes", "DoesNotExist", false]
@@ -26,15 +28,16 @@ class StaticReflectionParserTest extends TestCase {
    *           ["UsedAsQualified", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleAttribute", true]
    *           ["Qualified", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleAttribute", true]
    *           ["Relative", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\Attribute\\SubDir\\SubDirAttribute", true]
+   *           ["FullyQualified", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleParentAttribute", true]
+   *           ["Used", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleParentAttribute", true]
+   *           ["UsedAs", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleParentAttribute", true]
+   *           ["UsedAsQualified", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleParentAttribute", true]
+   *           ["Qualified", "Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\ExtraAttributes\\ExampleParentAttribute", true]
    */
   public function testAttribute(string $class, string $attribute_class, bool $expected) {
     $finder = MockFileFinder::create(__DIR__ . '/Fixtures/Attribute/' . $class . '.php');
     $parser = new StaticReflectionParser('\\Drupal\\Tests\\Component\\Annotation\\Doctrine\\Fixtures\\Attribute\\' . $class, $finder);
-    $this->assertSame($expected, $parser->hasClassAttribute($attribute_class), "'$class' has '$attribute_class'");
-    // Attribute names and namespaces are case-insensitive in PHP. Practically
-    // Composer autoloading makes this untrue but builtins like \Attribute are
-    // case-insensitive so we should support that.
-    $this->assertSame($expected, $parser->hasClassAttribute(strtoupper($attribute_class)), "'$class' has '$attribute_class'");
+    $this->assertSame($expected, $parser->hasClassAttribute($attribute_class), "'$class' has attribute that is a '$attribute_class'");
   }
 
 }
diff --git a/web/core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php b/web/core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php
index e48973a39f65f3f7fddca076c2285618224d5d96..fcf770d322eedbebe15f37b67872ee0c88106725 100644
--- a/web/core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Plugin/Context/ContextTest.php
@@ -49,9 +49,7 @@ public function testGetContextValue($expected, $context_value, $is_required, $da
     // throwing an exception if the definition requires it.
     else {
       // Create a mock definition.
-      $mock_definition = $this->getMockBuilder('Drupal\Component\Plugin\Context\ContextDefinitionInterface')
-        ->onlyMethods(['isRequired', 'getDataType'])
-        ->getMockForAbstractClass();
+      $mock_definition = $this->createMock('Drupal\Component\Plugin\Context\ContextDefinitionInterface');
 
       // Set expectation for isRequired().
       $mock_definition->expects($this->once())
@@ -103,9 +101,7 @@ public function providerHasContextValue() {
    * @dataProvider providerHasContextValue
    */
   public function testHasContextValue($has_context_value, $default_value): void {
-    $mock_definition = $this->getMockBuilder('Drupal\Component\Plugin\Context\ContextDefinitionInterface')
-      ->onlyMethods(['getDefaultValue'])
-      ->getMockForAbstractClass();
+    $mock_definition = $this->createMock('Drupal\Component\Plugin\Context\ContextDefinitionInterface');
 
     $mock_definition->expects($this->atLeastOnce())
       ->method('getDefaultValue')
@@ -121,9 +117,7 @@ public function testHasContextValue($has_context_value, $default_value): void {
    * @covers ::getContextValue
    */
   public function testDefaultValue() {
-    $mock_definition = $this->getMockBuilder('Drupal\Component\Plugin\Context\ContextDefinitionInterface')
-      ->onlyMethods(['getDefaultValue'])
-      ->getMockForAbstractClass();
+    $mock_definition = $this->createMock('Drupal\Component\Plugin\Context\ContextDefinitionInterface');
 
     $mock_definition->expects($this->once())
       ->method('getDefaultValue')
diff --git a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryCachedTraitTest.php b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryCachedTraitTest.php
index c6466ba669050a0d734de0a11cde504fe010bc40..fc477d196ba179876115fff1459d5f2463f63625 100644
--- a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryCachedTraitTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryCachedTraitTest.php
@@ -4,6 +4,7 @@
 
 namespace Drupal\Tests\Component\Plugin\Discovery;
 
+use Drupal\Component\Plugin\Discovery\DiscoveryCachedTrait;
 use PHPUnit\Framework\TestCase;
 
 /**
@@ -35,8 +36,9 @@ public function providerGetDefinition() {
    * @dataProvider providerGetDefinition
    */
   public function testGetDefinition($expected, $cached_definitions, $get_definitions, $plugin_id) {
-    // Mock a DiscoveryCachedTrait.
-    $trait = $this->getMockForTrait('Drupal\Component\Plugin\Discovery\DiscoveryCachedTrait');
+    $trait = $this->getMockBuilder(DiscoveryCachedTraitMockableClass::class)
+      ->onlyMethods(['getDefinitions'])
+      ->getMock();
     $reflection_definitions = new \ReflectionProperty($trait, 'definitions');
     // getDefinition() needs the ::$definitions property to be set in one of two
     // ways: 1) As existing cached data, or 2) as a side-effect of calling
@@ -64,3 +66,16 @@ public function testGetDefinition($expected, $cached_definitions, $get_definitio
   }
 
 }
+
+/**
+ * A class using the DiscoveryCachedTrait for mocking purposes.
+ */
+class DiscoveryCachedTraitMockableClass {
+
+  use DiscoveryCachedTrait;
+
+  public function getDefinitions(): array {
+    return [];
+  }
+
+}
diff --git a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php
index b18c95c0c3e7d31ce9bdfab76a46e4914b38792f..a1e72d23fe3a2ed6157e02d302d46d0244fd5544 100644
--- a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/DiscoveryTraitTest.php
@@ -4,6 +4,7 @@
 
 namespace Drupal\Tests\Component\Plugin\Discovery;
 
+use Drupal\Component\Plugin\Discovery\DiscoveryTrait;
 use Drupal\Component\Plugin\Exception\PluginNotFoundException;
 use PHPUnit\Framework\TestCase;
 
@@ -33,8 +34,7 @@ public function providerDoGetDefinition() {
    * @dataProvider providerDoGetDefinition
    */
   public function testDoGetDefinition($expected, $definitions, $plugin_id) {
-    // Mock the trait.
-    $trait = $this->getMockForTrait('Drupal\Component\Plugin\Discovery\DiscoveryTrait');
+    $trait = new DiscoveryTraitMockableClass();
     // Un-protect the method using reflection.
     $method_ref = new \ReflectionMethod($trait, 'doGetDefinition');
     // Call doGetDefinition, with $exception_on_invalid always FALSE.
@@ -64,8 +64,7 @@ public function providerDoGetDefinitionException() {
    * @uses \Drupal\Component\Plugin\Exception\PluginNotFoundException
    */
   public function testDoGetDefinitionException($expected, $definitions, $plugin_id) {
-    // Mock the trait.
-    $trait = $this->getMockForTrait('Drupal\Component\Plugin\Discovery\DiscoveryTrait');
+    $trait = new DiscoveryTraitMockableClass();
     // Un-protect the method using reflection.
     $method_ref = new \ReflectionMethod($trait, 'doGetDefinition');
     // Call doGetDefinition, with $exception_on_invalid always TRUE.
@@ -81,7 +80,9 @@ public function testGetDefinition($expected, $definitions, $plugin_id) {
     // Since getDefinition is a wrapper around doGetDefinition(), we can re-use
     // its data provider. We just have to tell abstract method getDefinitions()
     // to use the $definitions array.
-    $trait = $this->getMockForTrait('Drupal\Component\Plugin\Discovery\DiscoveryTrait');
+    $trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
+      ->onlyMethods(['getDefinitions'])
+      ->getMock();
     $trait->expects($this->once())
       ->method('getDefinitions')
       ->willReturn($definitions);
@@ -101,7 +102,9 @@ public function testGetDefinitionException($expected, $definitions, $plugin_id)
     // Since getDefinition is a wrapper around doGetDefinition(), we can re-use
     // its data provider. We just have to tell abstract method getDefinitions()
     // to use the $definitions array.
-    $trait = $this->getMockForTrait('Drupal\Component\Plugin\Discovery\DiscoveryTrait');
+    $trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
+      ->onlyMethods(['getDefinitions'])
+      ->getMock();
     $trait->expects($this->once())
       ->method('getDefinitions')
       ->willReturn($definitions);
@@ -129,9 +132,9 @@ public function providerHasDefinition() {
    * @dataProvider providerHasDefinition
    */
   public function testHasDefinition($expected, $plugin_id) {
-    $trait = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\DiscoveryTrait')
+    $trait = $this->getMockBuilder(DiscoveryTraitMockableClass::class)
       ->onlyMethods(['getDefinition'])
-      ->getMockForTrait();
+      ->getMock();
     // Set up our mocked getDefinition() to return TRUE for 'valid' and FALSE
     // for 'not_valid'.
     $trait->expects($this->once())
@@ -148,3 +151,16 @@ public function testHasDefinition($expected, $plugin_id) {
   }
 
 }
+
+/**
+ * A class using the DiscoveryTrait for mocking purposes.
+ */
+class DiscoveryTraitMockableClass {
+
+  use DiscoveryTrait;
+
+  public function getDefinitions(): array {
+    return [];
+  }
+
+}
diff --git a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/StaticDiscoveryDecoratorTest.php b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/StaticDiscoveryDecoratorTest.php
index b05a7be50281a7ce8b9ee8c987bdb1c9f21ae843..8ad7a989266b759f507764d99bc66e43aef0a021 100644
--- a/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/StaticDiscoveryDecoratorTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Plugin/Discovery/StaticDiscoveryDecoratorTest.php
@@ -4,6 +4,9 @@
 
 namespace Drupal\Tests\Component\Plugin\Discovery;
 
+use Drupal\Component\Plugin\Discovery\DiscoveryInterface;
+use Drupal\Component\Plugin\Discovery\StaticDiscovery;
+use Drupal\Component\Plugin\Discovery\StaticDiscoveryDecorator;
 use PHPUnit\Framework\TestCase;
 
 /**
@@ -24,9 +27,7 @@ class StaticDiscoveryDecoratorTest extends TestCase {
    *   called once.
    */
   public function getRegisterDefinitionsCallback() {
-    $mock_callable = $this->getMockBuilder(StaticDiscoveryDecoratorTestMockInterface::class)
-      ->onlyMethods(['registerDefinitionsCallback'])
-      ->getMock();
+    $mock_callable = $this->createMock(StaticDiscoveryDecoratorTestMockInterface::class);
     // Set expectations for the callback method.
     $mock_callable->expects($this->once())
       ->method('registerDefinitionsCallback');
@@ -62,9 +63,9 @@ public function providerGetDefinition() {
    */
   public function testGetDefinition($expected, $has_register_definitions, $exception_on_invalid, $definitions, $base_plugin_id) {
     // Mock our StaticDiscoveryDecorator.
-    $mock_decorator = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\StaticDiscoveryDecorator')
+    $mock_decorator = $this->getMockBuilder(StaticDiscoveryDecorator::class)
       ->disableOriginalConstructor()
-      ->addMethods(['registeredDefinitionCallback'])
+      ->onlyMethods([])
       ->getMock();
 
     // Set up the ::$registerDefinitions property.
@@ -86,9 +87,7 @@ public function testGetDefinition($expected, $has_register_definitions, $excepti
     $ref_definitions->setValue($mock_decorator, []);
 
     // Mock a decorated object.
-    $mock_decorated = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\DiscoveryInterface')
-      ->onlyMethods(['getDefinitions'])
-      ->getMockForAbstractClass();
+    $mock_decorated = $this->createMock(DiscoveryInterface::class);
     // Return our definitions from getDefinitions().
     $mock_decorated->expects($this->once())
       ->method('getDefinitions')
@@ -129,9 +128,9 @@ public function providerGetDefinitions() {
    */
   public function testGetDefinitions($has_register_definitions, $definitions) {
     // Mock our StaticDiscoveryDecorator.
-    $mock_decorator = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\StaticDiscoveryDecorator')
+    $mock_decorator = $this->getMockBuilder(StaticDiscoveryDecorator::class)
       ->disableOriginalConstructor()
-      ->addMethods(['registeredDefinitionCallback'])
+      ->onlyMethods([])
       ->getMock();
 
     // Set up the ::$registerDefinitions property.
@@ -153,9 +152,7 @@ public function testGetDefinitions($has_register_definitions, $definitions) {
     $ref_definitions->setValue($mock_decorator, []);
 
     // Mock a decorated object.
-    $mock_decorated = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\DiscoveryInterface')
-      ->onlyMethods(['getDefinitions'])
-      ->getMockForAbstractClass();
+    $mock_decorated = $this->createMock(DiscoveryInterface::class);
     // Our mocked method will return any arguments sent to it.
     $mock_decorated->expects($this->once())
       ->method('getDefinitions')
@@ -194,9 +191,9 @@ public function providerCall() {
    */
   public function testCall($method, $args) {
     // Mock a decorated object.
-    $mock_decorated = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\DiscoveryInterface')
-      ->addMethods([$method])
-      ->getMockForAbstractClass();
+    $mock_decorated = $this->getMockBuilder(StaticDiscoveryTestDecoratedClass::class)
+      ->onlyMethods([$method])
+      ->getMock();
     // Our mocked method will return any arguments sent to it.
     $mock_decorated->expects($this->once())
       ->method($method)
@@ -206,18 +203,13 @@ function () {
         }
       );
 
-    // Create a mock decorator.
-    $mock_decorator = $this->getMockBuilder('Drupal\Component\Plugin\Discovery\StaticDiscoveryDecorator')
-      ->disableOriginalConstructor()
-      ->getMock();
-    // Poke the decorated object into our decorator.
-    $ref_decorated = new \ReflectionProperty($mock_decorator, 'decorated');
-    $ref_decorated->setValue($mock_decorator, $mock_decorated);
+    // Create the decorator.
+    $decorator = new StaticDiscoveryDecorator($mock_decorated);
 
-    // Exercise __call.
+    // Exercise __call on the decorator.
     $this->assertEquals(
       $args,
-      \call_user_func_array([$mock_decorated, $method], $args)
+      \call_user_func_array([$decorator, $method], $args)
     );
   }
 
@@ -234,3 +226,22 @@ interface StaticDiscoveryDecoratorTestMockInterface {
   public function registerDefinitionsCallback();
 
 }
+
+/**
+ * A class extending StaticDiscovery for testing purposes.
+ */
+class StaticDiscoveryTestDecoratedClass extends StaticDiscovery {
+
+  public function getDefinitions(): array {
+    return [];
+  }
+
+  public function complexArguments(mixed ...$args): array {
+    return $args;
+  }
+
+  public function noArguments(): array {
+    return [];
+  }
+
+}
diff --git a/web/core/tests/Drupal/Tests/Component/Plugin/PluginManagerBaseTest.php b/web/core/tests/Drupal/Tests/Component/Plugin/PluginManagerBaseTest.php
index b4c5a6952e4d59b10e170a2ec85ac25b377c331d..ad9ba1ac9696fd9c4742625ae01a0d24abaf2e2b 100644
--- a/web/core/tests/Drupal/Tests/Component/Plugin/PluginManagerBaseTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Plugin/PluginManagerBaseTest.php
@@ -38,9 +38,7 @@ public function createInstanceCallback() {
    * Generates a mocked FactoryInterface object with known properties.
    */
   public function getMockFactoryInterface($expects_count) {
-    $mock_factory = $this->getMockBuilder('Drupal\Component\Plugin\Factory\FactoryInterface')
-      ->onlyMethods(['createInstance'])
-      ->getMockForAbstractClass();
+    $mock_factory = $this->createMock('Drupal\Component\Plugin\Factory\FactoryInterface');
     $mock_factory->expects($this->exactly($expects_count))
       ->method('createInstance')
       ->willReturnCallback([$this, 'createInstanceCallback']);
diff --git a/web/core/tests/Drupal/Tests/Component/Utility/UrlHelperTest.php b/web/core/tests/Drupal/Tests/Component/Utility/UrlHelperTest.php
index da578931b3ecdb43204d009b9f514d1999428ff2..f79915f18c6fb1296d83ae403fce8f2f476d8c14 100644
--- a/web/core/tests/Drupal/Tests/Component/Utility/UrlHelperTest.php
+++ b/web/core/tests/Drupal/Tests/Component/Utility/UrlHelperTest.php
@@ -51,7 +51,7 @@ public function testBuildQuery($query, $expected, $message) {
    *
    * @return array
    */
-  public function providerTestValidAbsoluteData() {
+  public static function providerTestValidAbsoluteData(): array {
     $urls = [
       'example.com',
       'www.example.com',
@@ -75,7 +75,7 @@ public function providerTestValidAbsoluteData() {
       '[FEDC:BA98:7654:3210:FEDC:BA98:7654:3210]:80/index.html',
     ];
 
-    return $this->dataEnhanceWithScheme($urls);
+    return self::dataEnhanceWithScheme($urls);
   }
 
   /**
@@ -89,7 +89,7 @@ public function providerTestValidAbsoluteData() {
    * @param string $scheme
    *   The scheme to test.
    */
-  public function testValidAbsolute($url, $scheme) {
+  public function testValidAbsolute(string $url, string $scheme): void {
     $test_url = $scheme . '://' . $url;
     $valid_url = UrlHelper::isValid($test_url, TRUE);
     $this->assertTrue($valid_url, $test_url . ' is a valid URL.');
@@ -100,13 +100,13 @@ public function testValidAbsolute($url, $scheme) {
    *
    * @return array
    */
-  public function providerTestInvalidAbsolute() {
+  public static function providerTestInvalidAbsolute(): array {
     $data = [
       '',
       'ex!ample.com',
       'ex%ample.com',
     ];
-    return $this->dataEnhanceWithScheme($data);
+    return self::dataEnhanceWithScheme($data);
   }
 
   /**
@@ -144,7 +144,7 @@ public function testUncompressInvalidString() {
    * @param string $scheme
    *   The scheme to test.
    */
-  public function testInvalidAbsolute($url, $scheme) {
+  public function testInvalidAbsolute(string $url, string $scheme): void {
     $test_url = $scheme . '://' . $url;
     $valid_url = UrlHelper::isValid($test_url, TRUE);
     $this->assertFalse($valid_url, $test_url . ' is NOT a valid URL.');
@@ -155,7 +155,7 @@ public function testInvalidAbsolute($url, $scheme) {
    *
    * @return array
    */
-  public function providerTestValidRelativeData() {
+  public static function providerTestValidRelativeData(): array {
     $data = [
       'paren(the)sis',
       'index.html#pagetop',
@@ -164,7 +164,7 @@ public function providerTestValidRelativeData() {
       'login.php?do=login&style=%23#pagetop',
     ];
 
-    return $this->dataEnhanceWithPrefix($data);
+    return self::dataEnhanceWithPrefix($data);
   }
 
   /**
@@ -178,7 +178,7 @@ public function providerTestValidRelativeData() {
    * @param string $prefix
    *   The prefix to test.
    */
-  public function testValidRelative($url, $prefix) {
+  public function testValidRelative(string $url, string $prefix): void {
     $test_url = $prefix . $url;
     $valid_url = UrlHelper::isValid($test_url);
     $this->assertTrue($valid_url, $test_url . ' is a valid URL.');
@@ -189,14 +189,14 @@ public function testValidRelative($url, $prefix) {
    *
    * @return array
    */
-  public function providerTestInvalidRelativeData() {
+  public static function providerTestInvalidRelativeData(): array {
     $data = [
       // cspell:disable-next-line
       'ex^mple',
       'example<>',
       'ex%ample',
     ];
-    return $this->dataEnhanceWithPrefix($data);
+    return self::dataEnhanceWithPrefix($data);
   }
 
   /**
@@ -210,7 +210,7 @@ public function providerTestInvalidRelativeData() {
    * @param string $prefix
    *   The prefix to test.
    */
-  public function testInvalidRelative($url, $prefix) {
+  public function testInvalidRelative(string $url, string $prefix): void {
     $test_url = $prefix . $url;
     $valid_url = UrlHelper::isValid($test_url);
     $this->assertFalse($valid_url, $test_url . ' is NOT a valid URL.');
@@ -553,7 +553,7 @@ public static function providerTestStripDangerousProtocols() {
    * @return array
    *   A list of provider data with schemes.
    */
-  protected function dataEnhanceWithScheme(array $urls) {
+  protected static function dataEnhanceWithScheme(array $urls): array {
     $url_schemes = ['http', 'https', 'ftp'];
     $data = [];
     foreach ($url_schemes as $scheme) {
@@ -573,7 +573,7 @@ protected function dataEnhanceWithScheme(array $urls) {
    * @return array
    *   A list of provider data with prefixes.
    */
-  protected function dataEnhanceWithPrefix(array $urls) {
+  protected static function dataEnhanceWithPrefix(array $urls): array {
     $prefixes = ['', '/'];
     $data = [];
     foreach ($prefixes as $prefix) {
diff --git a/web/core/tests/Drupal/Tests/Composer/Plugin/ProjectMessage/ConfigTest.php b/web/core/tests/Drupal/Tests/Composer/Plugin/ProjectMessage/ConfigTest.php
index f1ed747139552af1cc8130ea25a1a686d3f2f028..b0f0c23ef958f6452d8ac2cf86d1bbf1c8d44e1b 100644
--- a/web/core/tests/Drupal/Tests/Composer/Plugin/ProjectMessage/ConfigTest.php
+++ b/web/core/tests/Drupal/Tests/Composer/Plugin/ProjectMessage/ConfigTest.php
@@ -61,9 +61,7 @@ public function provideGetMessageText() {
    */
   public function testGetMessageText($expected, $config) {
     // Root package has our config.
-    $root = $this->getMockBuilder(RootPackageInterface::class)
-      ->onlyMethods(['getExtra'])
-      ->getMockForAbstractClass();
+    $root = $this->createMock(RootPackageInterface::class);
     $root->expects($this->once())
       ->method('getExtra')
       ->willReturn($config);
@@ -78,9 +76,7 @@ public function testGetMessageText($expected, $config) {
    */
   public function testDefaultFile() {
     // Root package has no extra field.
-    $root = $this->getMockBuilder(RootPackageInterface::class)
-      ->onlyMethods(['getExtra'])
-      ->getMockForAbstractClass();
+    $root = $this->createMock(RootPackageInterface::class);
     $root->expects($this->once())
       ->method('getExtra')
       ->willReturn([]);
diff --git a/web/core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php b/web/core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php
index 9e50d3c92bf077f9e03cbbea9a107fe814cfd831..25da3d51195457bb8e6083b4572964b013763220 100644
--- a/web/core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php
+++ b/web/core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php
@@ -248,7 +248,7 @@ public function testUnmanagedGitIgnoreWhenGitNotAvailable() {
   - Copy [web-root]/robots.txt from assets/robots-default.txt
 
 EOT;
-    $this->assertEquals($expected, $output);
+    $this->assertStringContainsString($expected, $output);
     $this->assertFileExists($sut . '/docroot/index.php');
     $this->assertFileDoesNotExist($sut . '/docroot/sites/default/.gitignore');
   }
diff --git a/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/ConfigTest.php b/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/ConfigTest.php
index bf154ca10fc5c3d808ecff0eb38094a51005ba25..442379723d3ddcb2d5635c454dfa7e34253b5d0c 100644
--- a/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/ConfigTest.php
+++ b/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/ConfigTest.php
@@ -38,9 +38,7 @@ public function testGetPathsForPackageMixedCase() {
    */
   public function testNoRootMergeConfig() {
     // Root package has no extra field.
-    $root = $this->getMockBuilder(RootPackageInterface::class)
-      ->onlyMethods(['getExtra'])
-      ->getMockForAbstractClass();
+    $root = $this->createMock(RootPackageInterface::class);
     $root->expects($this->once())
       ->method('getExtra')
       ->willReturn([]);
@@ -61,9 +59,7 @@ public function testNoRootMergeConfig() {
    */
   public function testRootMergeConfig() {
     // Root package has configuration in extra.
-    $root = $this->getMockBuilder(RootPackageInterface::class)
-      ->onlyMethods(['getExtra'])
-      ->getMockForAbstractClass();
+    $root = $this->createMock(RootPackageInterface::class);
     $root->expects($this->once())
       ->method('getExtra')
       ->willReturn([
@@ -90,9 +86,7 @@ public function testRootMergeConfig() {
    */
   public function testMixedCaseConfigCleanupPackages() {
     // Root package has configuration in extra.
-    $root = $this->getMockBuilder(RootPackageInterface::class)
-      ->onlyMethods(['getExtra'])
-      ->getMockForAbstractClass();
+    $root = $this->createMock(RootPackageInterface::class);
     $root->expects($this->once())
       ->method('getExtra')
       ->willReturn([
diff --git a/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/VendorHardeningPluginTest.php b/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/VendorHardeningPluginTest.php
index 0a5fcee9c451a9e9b9c16e467310bb47ee6eab95..1339f6ef243d68ed83f9455e058466a91297f117 100644
--- a/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/VendorHardeningPluginTest.php
+++ b/web/core/tests/Drupal/Tests/Composer/Plugin/VendorHardening/VendorHardeningPluginTest.php
@@ -113,8 +113,7 @@ public function testCleanAllPackages() {
       ->method('getAllCleanupPaths')
       ->willReturn(['drupal/package' => ['tests']]);
 
-    $package = $this->getMockBuilder(PackageInterface::class)
-      ->getMockForAbstractClass();
+    $package = $this->createMock(PackageInterface::class);
     $package->expects($this->any())
       ->method('getName')
       ->willReturn('drupal/package');
diff --git a/web/core/tests/Drupal/Tests/Core/Config/Entity/EntityDisplayModeBaseUnitTest.php b/web/core/tests/Drupal/Tests/Core/Config/Entity/EntityDisplayModeBaseUnitTest.php
index bc44483ed2023f46e9cf3d34f484f615a907fc6c..c71a84836c3b2a5d8a186320b73daaadf99a94c7 100644
--- a/web/core/tests/Drupal/Tests/Core/Config/Entity/EntityDisplayModeBaseUnitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Config/Entity/EntityDisplayModeBaseUnitTest.php
@@ -5,6 +5,7 @@
 namespace Drupal\Tests\Core\Config\Entity;
 
 use Drupal\Core\DependencyInjection\ContainerBuilder;
+use Drupal\Core\Entity\EntityDisplayModeBase;
 use Drupal\Core\Entity\EntityTypeManagerInterface;
 use Drupal\Tests\UnitTestCase;
 
@@ -92,11 +93,7 @@ public function testCalculateDependencies() {
         [$this->entityType, TRUE, $this->entityInfo],
       ]);
 
-    $this->entity = $this->getMockBuilder('\Drupal\Core\Entity\EntityDisplayModeBase')
-      ->setConstructorArgs([$values, $this->entityType])
-      ->addMethods(['getFilterFormat'])
-      ->getMock();
-
+    $this->entity = new EntityDisplayModeBaseTestableClass($values, $this->entityType);
     $dependencies = $this->entity->calculateDependencies()->getDependencies();
     $this->assertContains('test_module', $dependencies['module']);
   }
@@ -154,3 +151,9 @@ public function testGetTargetType() {
   }
 
 }
+
+/**
+ * A class extending EntityDisplayModeBase for testing purposes.
+ */
+class EntityDisplayModeBaseTestableClass extends EntityDisplayModeBase {
+}
diff --git a/web/core/tests/Drupal/Tests/Core/Database/ConnectionTest.php b/web/core/tests/Drupal/Tests/Core/Database/ConnectionTest.php
index 2522a8947619b1b19fc734479089195c32f4f270..fef5f84024562edc151689eec8460e659561ca3c 100644
--- a/web/core/tests/Drupal/Tests/Core/Database/ConnectionTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Database/ConnectionTest.php
@@ -982,4 +982,15 @@ public function testDeprecatedFetchModes(int $mode): void {
     $statement->setFetchMode($mode);
   }
 
+  /**
+   * {@inheritdoc}
+   */
+  public function tearDown(): void {
+    parent::tearDown();
+
+    // Removes the default connection added by the
+    // testFindCallerFromDebugBacktrace test.
+    Database::removeConnection('default');
+  }
+
 }
diff --git a/web/core/tests/Drupal/Tests/Core/Datetime/DateTest.php b/web/core/tests/Drupal/Tests/Core/Datetime/DateTest.php
index c9010bdcd7c7bd81b6d4a3c00075a302f2dfcbb8..9f94a58da35fea16e9dd10df06e454897027b83e 100644
--- a/web/core/tests/Drupal/Tests/Core/Datetime/DateTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Datetime/DateTest.php
@@ -191,8 +191,8 @@ public function testGetSampleDateFormats() {
    */
   public function testFormatTimeDiffUntil() {
     $expected = '1 second';
-    $request_time = $this->createTimestamp('2013-12-11 10:09:08');
-    $timestamp = $this->createTimestamp('2013-12-11 10:09:09');
+    $request_time = self::createTimestamp('2013-12-11 10:09:08');
+    $timestamp = self::createTimestamp('2013-12-11 10:09:09');
     $options = [];
 
     // Mocks the formatDiff function of the DateFormatter object.
@@ -224,8 +224,8 @@ public function testFormatTimeDiffUntil() {
    */
   public function testFormatTimeDiffSince() {
     $expected = '1 second';
-    $timestamp = $this->createTimestamp('2013-12-11 10:09:07');
-    $request_time = $this->createTimestamp('2013-12-11 10:09:08');
+    $timestamp = self::createTimestamp('2013-12-11 10:09:07');
+    $request_time = self::createTimestamp('2013-12-11 10:09:08');
     $options = [];
 
     // Mocks the formatDiff function of the DateFormatter object.
@@ -257,7 +257,7 @@ public function testFormatTimeDiffSince() {
    *
    * @covers ::formatDiff
    */
-  public function testFormatDiff($expected, $max_age, $timestamp1, $timestamp2, $options = []) {
+  public function testFormatDiff(string $expected, int $max_age, int $timestamp1, int $timestamp2, array $options = []): void {
     // Mocks a simple translateString implementation.
     $this->stringTranslation->expects($this->any())
       ->method('translateString')
@@ -281,9 +281,9 @@ public function testFormatDiff($expected, $max_age, $timestamp1, $timestamp2, $o
   /**
    * Data provider for testFormatDiff().
    */
-  public function providerTestFormatDiff() {
+  public static function providerTestFormatDiff(): array {
     // This is the fixed request time in the test.
-    $request_time = $this->createTimestamp('2013-12-11 10:09:08');
+    $request_time = self::createTimestamp('2013-12-11 10:09:08');
 
     $granularity_3 = ['granularity' => 3];
     $granularity_4 = ['granularity' => 4];
@@ -298,100 +298,100 @@ public function providerTestFormatDiff() {
       ['0 seconds', 0, $request_time, $request_time],
 
       // Checks for seconds only.
-      ['1 second', 1, $this->createTimestamp('2013-12-11 10:09:07'), $request_time],
-      ['1 second', 1, $this->createTimestamp('2013-12-11 10:09:07'), $request_time],
-      ['1 second', 1, $this->createTimestamp('2013-12-11 10:09:07'), $request_time, $granularity_3 + $langcode_en],
-      ['1 second', 1, $this->createTimestamp('2013-12-11 10:09:07'), $request_time, $granularity_4 + $langcode_lolspeak],
-      ['2 seconds', 1, $this->createTimestamp('2013-12-11 10:09:06'), $request_time],
-      ['59 seconds', 1, $this->createTimestamp('2013-12-11 10:08:09'), $request_time],
-      ['59 seconds', 1, $this->createTimestamp('2013-12-11 10:08:09'), $request_time],
+      ['1 second', 1, self::createTimestamp('2013-12-11 10:09:07'), $request_time],
+      ['1 second', 1, self::createTimestamp('2013-12-11 10:09:07'), $request_time],
+      ['1 second', 1, self::createTimestamp('2013-12-11 10:09:07'), $request_time, $granularity_3 + $langcode_en],
+      ['1 second', 1, self::createTimestamp('2013-12-11 10:09:07'), $request_time, $granularity_4 + $langcode_lolspeak],
+      ['2 seconds', 1, self::createTimestamp('2013-12-11 10:09:06'), $request_time],
+      ['59 seconds', 1, self::createTimestamp('2013-12-11 10:08:09'), $request_time],
+      ['59 seconds', 1, self::createTimestamp('2013-12-11 10:08:09'), $request_time],
 
       // Checks for minutes and possibly seconds.
-      ['1 minute', 60, $this->createTimestamp('2013-12-11 10:08:08'), $request_time],
-      ['1 minute', 60, $this->createTimestamp('2013-12-11 10:08:08'), $request_time],
-      ['1 minute 1 second', 1, $this->createTimestamp('2013-12-11 10:08:07'), $request_time],
-      ['1 minute 59 seconds', 1, $this->createTimestamp('2013-12-11 10:07:09'), $request_time],
-      ['2 minutes', 60, $this->createTimestamp('2013-12-11 10:07:08'), $request_time],
-      ['2 minutes 1 second', 1, $this->createTimestamp('2013-12-11 10:07:07'), $request_time],
-      ['2 minutes 2 seconds', 1, $this->createTimestamp('2013-12-11 10:07:06'), $request_time],
-      ['2 minutes 2 seconds', 1, $this->createTimestamp('2013-12-11 10:07:06'), $request_time, $granularity_3],
-      ['2 minutes 2 seconds', 1, $this->createTimestamp('2013-12-11 10:07:06'), $request_time, $granularity_4],
-      ['30 minutes', 60, $this->createTimestamp('2013-12-11 09:39:08'), $request_time],
-      ['59 minutes 59 seconds', 1, $this->createTimestamp('2013-12-11 09:09:09'), $request_time],
-      ['59 minutes 59 seconds', 1, $this->createTimestamp('2013-12-11 09:09:09'), $request_time],
+      ['1 minute', 60, self::createTimestamp('2013-12-11 10:08:08'), $request_time],
+      ['1 minute', 60, self::createTimestamp('2013-12-11 10:08:08'), $request_time],
+      ['1 minute 1 second', 1, self::createTimestamp('2013-12-11 10:08:07'), $request_time],
+      ['1 minute 59 seconds', 1, self::createTimestamp('2013-12-11 10:07:09'), $request_time],
+      ['2 minutes', 60, self::createTimestamp('2013-12-11 10:07:08'), $request_time],
+      ['2 minutes 1 second', 1, self::createTimestamp('2013-12-11 10:07:07'), $request_time],
+      ['2 minutes 2 seconds', 1, self::createTimestamp('2013-12-11 10:07:06'), $request_time],
+      ['2 minutes 2 seconds', 1, self::createTimestamp('2013-12-11 10:07:06'), $request_time, $granularity_3],
+      ['2 minutes 2 seconds', 1, self::createTimestamp('2013-12-11 10:07:06'), $request_time, $granularity_4],
+      ['30 minutes', 60, self::createTimestamp('2013-12-11 09:39:08'), $request_time],
+      ['59 minutes 59 seconds', 1, self::createTimestamp('2013-12-11 09:09:09'), $request_time],
+      ['59 minutes 59 seconds', 1, self::createTimestamp('2013-12-11 09:09:09'), $request_time],
 
       // Checks for hours and possibly minutes or seconds.
-      ['1 hour', 3600, $this->createTimestamp('2013-12-11 09:09:08'), $request_time],
-      ['1 hour', 3600, $this->createTimestamp('2013-12-11 09:09:08'), $request_time],
-      ['1 hour', 3600, $this->createTimestamp('2013-12-11 09:09:07'), $request_time],
-      ['1 hour', 3600, $this->createTimestamp('2013-12-11 09:09:06'), $request_time],
-      ['1 hour 1 minute', 60, $this->createTimestamp('2013-12-11 09:08:08'), $request_time],
-      ['1 hour 1 minute 1 second', 1, $this->createTimestamp('2013-12-11 09:08:07'), $request_time, $granularity_3],
-      ['1 hour 1 minute 2 seconds', 1, $this->createTimestamp('2013-12-11 09:08:06'), $request_time, $granularity_4],
-      ['1 hour 30 minutes', 60, $this->createTimestamp('2013-12-11 08:39:08'), $request_time],
-      ['2 hours', 3600, $this->createTimestamp('2013-12-11 08:09:08'), $request_time],
-      ['23 hours 59 minutes', 60, $this->createTimestamp('2013-12-10 10:10:08'), $request_time],
+      ['1 hour', 3600, self::createTimestamp('2013-12-11 09:09:08'), $request_time],
+      ['1 hour', 3600, self::createTimestamp('2013-12-11 09:09:08'), $request_time],
+      ['1 hour', 3600, self::createTimestamp('2013-12-11 09:09:07'), $request_time],
+      ['1 hour', 3600, self::createTimestamp('2013-12-11 09:09:06'), $request_time],
+      ['1 hour 1 minute', 60, self::createTimestamp('2013-12-11 09:08:08'), $request_time],
+      ['1 hour 1 minute 1 second', 1, self::createTimestamp('2013-12-11 09:08:07'), $request_time, $granularity_3],
+      ['1 hour 1 minute 2 seconds', 1, self::createTimestamp('2013-12-11 09:08:06'), $request_time, $granularity_4],
+      ['1 hour 30 minutes', 60, self::createTimestamp('2013-12-11 08:39:08'), $request_time],
+      ['2 hours', 3600, self::createTimestamp('2013-12-11 08:09:08'), $request_time],
+      ['23 hours 59 minutes', 60, self::createTimestamp('2013-12-10 10:10:08'), $request_time],
 
       // Checks for days and possibly hours, minutes or seconds.
-      ['1 day', 86400, $this->createTimestamp('2013-12-10 10:09:08'), $request_time],
-      ['1 day', 86400, $this->createTimestamp('2013-12-10 10:09:07'), $request_time],
-      ['1 day 1 hour', 3600, $this->createTimestamp('2013-12-10 09:09:08'), $request_time],
-      ['1 day 1 hour 1 minute', 60, $this->createTimestamp('2013-12-10 09:08:07'), $request_time, $granularity_3 + $langcode_en],
-      ['1 day 1 hour 1 minute 1 second', 1, $this->createTimestamp('2013-12-10 09:08:07'), $request_time, $granularity_4 + $langcode_lolspeak],
-      ['1 day 2 hours 2 minutes 2 seconds', 1, $this->createTimestamp('2013-12-10 08:07:06'), $request_time, $granularity_4],
-      ['2 days', 86400, $this->createTimestamp('2013-12-09 10:09:08'), $request_time],
-      ['2 days', 86400, $this->createTimestamp('2013-12-09 10:07:08'), $request_time],
-      ['2 days 2 hours', 3600, $this->createTimestamp('2013-12-09 08:09:08'), $request_time],
-      ['2 days 2 hours 2 minutes', 60, $this->createTimestamp('2013-12-09 08:07:06'), $request_time, $granularity_3 + $langcode_en],
-      ['2 days 2 hours 2 minutes 2 seconds', 1, $this->createTimestamp('2013-12-09 08:07:06'), $request_time, $granularity_4 + $langcode_lolspeak],
+      ['1 day', 86400, self::createTimestamp('2013-12-10 10:09:08'), $request_time],
+      ['1 day', 86400, self::createTimestamp('2013-12-10 10:09:07'), $request_time],
+      ['1 day 1 hour', 3600, self::createTimestamp('2013-12-10 09:09:08'), $request_time],
+      ['1 day 1 hour 1 minute', 60, self::createTimestamp('2013-12-10 09:08:07'), $request_time, $granularity_3 + $langcode_en],
+      ['1 day 1 hour 1 minute 1 second', 1, self::createTimestamp('2013-12-10 09:08:07'), $request_time, $granularity_4 + $langcode_lolspeak],
+      ['1 day 2 hours 2 minutes 2 seconds', 1, self::createTimestamp('2013-12-10 08:07:06'), $request_time, $granularity_4],
+      ['2 days', 86400, self::createTimestamp('2013-12-09 10:09:08'), $request_time],
+      ['2 days', 86400, self::createTimestamp('2013-12-09 10:07:08'), $request_time],
+      ['2 days 2 hours', 3600, self::createTimestamp('2013-12-09 08:09:08'), $request_time],
+      ['2 days 2 hours 2 minutes', 60, self::createTimestamp('2013-12-09 08:07:06'), $request_time, $granularity_3 + $langcode_en],
+      ['2 days 2 hours 2 minutes 2 seconds', 1, self::createTimestamp('2013-12-09 08:07:06'), $request_time, $granularity_4 + $langcode_lolspeak],
 
       // Checks for weeks and possibly days, hours, minutes or seconds.
-      ['1 week', 7 * 86400, $this->createTimestamp('2013-12-04 10:09:08'), $request_time],
-      ['1 week 1 day', 86400, $this->createTimestamp('2013-12-03 10:09:08'), $request_time],
-      ['2 weeks', 7 * 86400, $this->createTimestamp('2013-11-27 10:09:08'), $request_time],
-      ['2 weeks 2 days', 86400, $this->createTimestamp('2013-11-25 08:07:08'), $request_time],
-      ['2 weeks 2 days 2 hours 2 minutes', 60, $this->createTimestamp('2013-11-25 08:07:08'), $request_time, $granularity_4],
-      ['4 weeks', 7 * 86400, $this->createTimestamp('2013-11-13 10:09:08'), $request_time],
-      ['4 weeks 1 day', 86400, $this->createTimestamp('2013-11-12 10:09:08'), $request_time],
+      ['1 week', 7 * 86400, self::createTimestamp('2013-12-04 10:09:08'), $request_time],
+      ['1 week 1 day', 86400, self::createTimestamp('2013-12-03 10:09:08'), $request_time],
+      ['2 weeks', 7 * 86400, self::createTimestamp('2013-11-27 10:09:08'), $request_time],
+      ['2 weeks 2 days', 86400, self::createTimestamp('2013-11-25 08:07:08'), $request_time],
+      ['2 weeks 2 days 2 hours 2 minutes', 60, self::createTimestamp('2013-11-25 08:07:08'), $request_time, $granularity_4],
+      ['4 weeks', 7 * 86400, self::createTimestamp('2013-11-13 10:09:08'), $request_time],
+      ['4 weeks 1 day', 86400, self::createTimestamp('2013-11-12 10:09:08'), $request_time],
 
       // Checks for months and possibly days, hours, minutes or seconds.
-      ['1 month', 30 * 86400, $this->createTimestamp('2013-11-11 10:09:08'), $request_time],
-      ['1 month', 30 * 86400, $this->createTimestamp('2013-11-11 10:09:07'), $request_time],
-      ['1 month', 30 * 86400, $this->createTimestamp('2013-11-11 09:09:08'), $request_time],
-      ['1 month', 30 * 86400, $this->createTimestamp('2013-11-11 09:08:07'), $request_time, $granularity_3],
-      ['1 month', 30 * 86400, $this->createTimestamp('2013-11-11 09:08:07'), $request_time, $granularity_4],
-      ['1 month 4 weeks', 7 * 86400, $this->createTimestamp('2013-10-13 10:09:08'), $request_time],
-      ['1 month 4 weeks 1 day', 86400, $this->createTimestamp('2013-10-13 10:09:08'), $request_time, $granularity_3],
-      ['1 month 4 weeks', 7 * 86400, $this->createTimestamp('2013-10-12 10:09:08'), $request_time],
-      ['1 month 4 weeks 2 days', 86400, $this->createTimestamp('2013-10-12 10:09:08'), $request_time, $granularity_3],
-      ['2 months', 30 * 86400, $this->createTimestamp('2013-10-11 10:09:08'), $request_time],
-      ['2 months', 30 * 86400, $this->createTimestamp('2013-10-10 10:09:08'), $request_time],
-      ['2 months', 30 * 86400, $this->createTimestamp('2013-10-09 08:07:06'), $request_time],
-      ['2 months', 30 * 86400, $this->createTimestamp('2013-10-09 08:07:06'), $request_time, $granularity_3],
-      ['2 months', 30 * 86400, $this->createTimestamp('2013-10-09 08:07:06'), $request_time, $granularity_4],
-      ['6 months', 30 * 86400, $this->createTimestamp('2013-06-09 10:09:08'), $request_time],
-      ['11 months', 30 * 86400, $this->createTimestamp('2013-01-11 07:09:08'), $request_time],
-      ['11 months 4 weeks', 7 * 86400, $this->createTimestamp('2012-12-12 10:09:08'), $request_time],
-      ['11 months 4 weeks 2 days', 86400, $this->createTimestamp('2012-12-12 10:09:08'), $request_time, $granularity_3],
+      ['1 month', 30 * 86400, self::createTimestamp('2013-11-11 10:09:08'), $request_time],
+      ['1 month', 30 * 86400, self::createTimestamp('2013-11-11 10:09:07'), $request_time],
+      ['1 month', 30 * 86400, self::createTimestamp('2013-11-11 09:09:08'), $request_time],
+      ['1 month', 30 * 86400, self::createTimestamp('2013-11-11 09:08:07'), $request_time, $granularity_3],
+      ['1 month', 30 * 86400, self::createTimestamp('2013-11-11 09:08:07'), $request_time, $granularity_4],
+      ['1 month 4 weeks', 7 * 86400, self::createTimestamp('2013-10-13 10:09:08'), $request_time],
+      ['1 month 4 weeks 1 day', 86400, self::createTimestamp('2013-10-13 10:09:08'), $request_time, $granularity_3],
+      ['1 month 4 weeks', 7 * 86400, self::createTimestamp('2013-10-12 10:09:08'), $request_time],
+      ['1 month 4 weeks 2 days', 86400, self::createTimestamp('2013-10-12 10:09:08'), $request_time, $granularity_3],
+      ['2 months', 30 * 86400, self::createTimestamp('2013-10-11 10:09:08'), $request_time],
+      ['2 months', 30 * 86400, self::createTimestamp('2013-10-10 10:09:08'), $request_time],
+      ['2 months', 30 * 86400, self::createTimestamp('2013-10-09 08:07:06'), $request_time],
+      ['2 months', 30 * 86400, self::createTimestamp('2013-10-09 08:07:06'), $request_time, $granularity_3],
+      ['2 months', 30 * 86400, self::createTimestamp('2013-10-09 08:07:06'), $request_time, $granularity_4],
+      ['6 months', 30 * 86400, self::createTimestamp('2013-06-09 10:09:08'), $request_time],
+      ['11 months', 30 * 86400, self::createTimestamp('2013-01-11 07:09:08'), $request_time],
+      ['11 months 4 weeks', 7 * 86400, self::createTimestamp('2012-12-12 10:09:08'), $request_time],
+      ['11 months 4 weeks 2 days', 86400, self::createTimestamp('2012-12-12 10:09:08'), $request_time, $granularity_3],
 
       // Checks for years and possibly months, days, hours, minutes or seconds.
-      ['1 year', 365 * 86400, $this->createTimestamp('2012-12-11 10:09:08'), $request_time],
-      ['1 year', 365 * 86400, $this->createTimestamp('2012-12-11 10:08:08'), $request_time],
-      ['1 year', 365 * 86400, $this->createTimestamp('2012-12-10 10:09:08'), $request_time],
-      ['2 years', 365 * 86400, $this->createTimestamp('2011-12-11 10:09:08'), $request_time],
-      ['2 years', 365 * 86400, $this->createTimestamp('2011-12-11 10:07:08'), $request_time],
-      ['2 years', 365 * 86400, $this->createTimestamp('2011-12-09 10:09:08'), $request_time],
-      ['2 years 2 months', 30 * 86400, $this->createTimestamp('2011-10-09 08:07:06'), $request_time, $granularity_3],
-      ['2 years 2 months', 30 * 86400, $this->createTimestamp('2011-10-09 08:07:06'), $request_time, $granularity_4],
-      ['10 years', 365 * 86400, $this->createTimestamp('2003-12-11 10:09:08'), $request_time],
-      ['100 years', 365 * 86400, $this->createTimestamp('1913-12-11 10:09:08'), $request_time],
+      ['1 year', 365 * 86400, self::createTimestamp('2012-12-11 10:09:08'), $request_time],
+      ['1 year', 365 * 86400, self::createTimestamp('2012-12-11 10:08:08'), $request_time],
+      ['1 year', 365 * 86400, self::createTimestamp('2012-12-10 10:09:08'), $request_time],
+      ['2 years', 365 * 86400, self::createTimestamp('2011-12-11 10:09:08'), $request_time],
+      ['2 years', 365 * 86400, self::createTimestamp('2011-12-11 10:07:08'), $request_time],
+      ['2 years', 365 * 86400, self::createTimestamp('2011-12-09 10:09:08'), $request_time],
+      ['2 years 2 months', 30 * 86400, self::createTimestamp('2011-10-09 08:07:06'), $request_time, $granularity_3],
+      ['2 years 2 months', 30 * 86400, self::createTimestamp('2011-10-09 08:07:06'), $request_time, $granularity_4],
+      ['10 years', 365 * 86400, self::createTimestamp('2003-12-11 10:09:08'), $request_time],
+      ['100 years', 365 * 86400, self::createTimestamp('1913-12-11 10:09:08'), $request_time],
 
       // Checks the non-strict option vs. strict (default).
-      ['1 second', 1, $this->createTimestamp('2013-12-11 10:09:08'), $this->createTimestamp('2013-12-11 10:09:07'), $non_strict],
-      ['0 seconds', 0, $this->createTimestamp('2013-12-11 10:09:08'), $this->createTimestamp('2013-12-11 10:09:07')],
+      ['1 second', 1, self::createTimestamp('2013-12-11 10:09:08'), self::createTimestamp('2013-12-11 10:09:07'), $non_strict],
+      ['0 seconds', 0, self::createTimestamp('2013-12-11 10:09:08'), self::createTimestamp('2013-12-11 10:09:07')],
 
       // Checks granularity limit.
-      ['2 years 3 months 1 week', 7 * 86400, $this->createTimestamp('2011-08-30 11:15:57'), $request_time, $granularity_3],
+      ['2 years 3 months 1 week', 7 * 86400, self::createTimestamp('2011-08-30 11:15:57'), $request_time, $granularity_3],
     ];
 
     return $data;
@@ -455,7 +455,7 @@ public function testRfc2822DateFormat(): void {
    * @return int
    *   The UNIX timestamp.
    */
-  private function createTimestamp($dateTimeString) {
+  private static function createTimestamp(string $dateTimeString): int {
     return \DateTime::createFromFormat('Y-m-d G:i:s', $dateTimeString)->getTimestamp();
   }
 
diff --git a/web/core/tests/Drupal/Tests/Core/Datetime/DrupalDateTimeTest.php b/web/core/tests/Drupal/Tests/Core/Datetime/DrupalDateTimeTest.php
index fc0213793f135352cc4fb713c7909b5be5c9648e..57c32baf0bb7304b3dbe451fb335a5894e227078 100644
--- a/web/core/tests/Drupal/Tests/Core/Datetime/DrupalDateTimeTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Datetime/DrupalDateTimeTest.php
@@ -271,4 +271,23 @@ public function testRfc2822DateFormat() {
     }
   }
 
+  /**
+   * Test to avoid serialization of formatTranslationCache.
+   */
+  public function testSleep(): void {
+    $tz = new \DateTimeZone(date_default_timezone_get());
+    $date = new DrupalDateTime('now', $tz, ['langcode' => 'en']);
+
+    // Override timestamp before serialize.
+    $date->setTimestamp(12345678);
+
+    $vars = $date->__sleep();
+    $this->assertContains('langcode', $vars);
+    $this->assertContains('dateTimeObject', $vars);
+    $this->assertNotContains('formatTranslationCache', $vars);
+
+    $unserialized_date = unserialize(serialize($date));
+    $this->assertSame(12345678, $unserialized_date->getTimestamp());
+  }
+
 }
diff --git a/web/core/tests/Drupal/Tests/Core/DrupalKernel/DrupalKernelTest.php b/web/core/tests/Drupal/Tests/Core/DrupalKernel/DrupalKernelTest.php
index 95630123c3483bc0dc91faf357f40f94d6adc963..1e2c1e7c60e319351d62c1781b528ba7f8d364d2 100644
--- a/web/core/tests/Drupal/Tests/Core/DrupalKernel/DrupalKernelTest.php
+++ b/web/core/tests/Drupal/Tests/Core/DrupalKernel/DrupalKernelTest.php
@@ -135,8 +135,8 @@ public function testFindSitePath() {
     $request->server->set('SERVER_NAME', 'www.example.org');
     $request->server->set('SERVER_PORT', '8888');
     $request->server->set('SCRIPT_NAME', '/index.php');
-    $this->assertEquals('sites/example', DrupalKernel::findSitePath($request, TRUE, $vfs_root->url('drupal_root')));
-    $this->assertEquals('sites/example', DrupalKernel::findSitePath($request, FALSE, $vfs_root->url('drupal_root')));
+    $this->assertEquals('sites/example', DrupalKernel::findSitePath($request, TRUE, $vfs_root->url()));
+    $this->assertEquals('sites/example', DrupalKernel::findSitePath($request, FALSE, $vfs_root->url()));
   }
 
   /**
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/BaseFieldDefinitionTest.php b/web/core/tests/Drupal/Tests/Core/Entity/BaseFieldDefinitionTest.php
index 7583848a1ecf68977abc5d2a73df09eb6e0ca0c6..1cafe065f7b0eb57a54ee7644588bbbd108a5af3 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/BaseFieldDefinitionTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/BaseFieldDefinitionTest.php
@@ -220,7 +220,7 @@ public function testFieldInitialValue() {
     // Set the field item list class to be used to avoid requiring the typed
     // data manager to retrieve it.
     $definition->setClass('Drupal\Core\Field\FieldItemList');
-    $this->assertEquals($expected_default_value, $definition->getInitialValue($entity));
+    $this->assertEquals($expected_default_value, $definition->getInitialValue());
 
     $data_definition = $this->getMockBuilder('Drupal\Core\TypedData\DataDefinition')
       ->disableOriginalConstructor()
@@ -232,19 +232,19 @@ public function testFieldInitialValue() {
 
     // Set default value only with a literal.
     $definition->setInitialValue($default_value['value']);
-    $this->assertEquals($expected_default_value, $definition->getInitialValue($entity));
+    $this->assertEquals($expected_default_value, $definition->getInitialValue());
 
     // Set default value with an indexed array.
     $definition->setInitialValue($expected_default_value);
-    $this->assertEquals($expected_default_value, $definition->getInitialValue($entity));
+    $this->assertEquals($expected_default_value, $definition->getInitialValue());
 
     // Set default value with an empty array.
     $definition->setInitialValue([]);
-    $this->assertEquals([], $definition->getInitialValue($entity));
+    $this->assertEquals([], $definition->getInitialValue());
 
     // Set default value with NULL.
     $definition->setInitialValue(NULL);
-    $this->assertEquals([], $definition->getInitialValue($entity));
+    $this->assertEquals([], $definition->getInitialValue());
   }
 
   /**
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/ContentEntityBaseUnitTest.php b/web/core/tests/Drupal/Tests/Core/Entity/ContentEntityBaseUnitTest.php
index 6d7951bc97436236678b523340abe9c2e9ecb794..2cf483611f2e16a6561c14e314c03afdde8598a0 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/ContentEntityBaseUnitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/ContentEntityBaseUnitTest.php
@@ -619,9 +619,7 @@ public function testGetFields($expected, $include_computed, $is_computed, $field
     // Mock field definition objects for each element of $field_definitions.
     $mocked_field_definitions = [];
     foreach ($field_definitions as $name) {
-      $mock_definition = $this->getMockBuilder('Drupal\Core\Field\FieldDefinitionInterface')
-        ->onlyMethods(['isComputed'])
-        ->getMockForAbstractClass();
+      $mock_definition = $this->createMock('Drupal\Core\Field\FieldDefinitionInterface');
       // Set expectations for isComputed(). isComputed() gets called whenever
       // $include_computed is FALSE, but not otherwise. It returns the value of
       // $is_computed.
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/EntityStorageBaseTest.php b/web/core/tests/Drupal/Tests/Core/Entity/EntityStorageBaseTest.php
index bc6621b719e1ebf337b79cfd61e3c7bee27d19f9..de87cce4435dd6ff63e74f3fc6b333048f171826 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/EntityStorageBaseTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/EntityStorageBaseTest.php
@@ -22,9 +22,7 @@ class EntityStorageBaseTest extends UnitTestCase {
    *   The mocked entity.
    */
   public function generateEntityInterface($id) {
-    $mock_entity = $this->getMockBuilder('\Drupal\Core\Entity\EntityInterface')
-      ->onlyMethods(['id'])
-      ->getMockForAbstractClass();
+    $mock_entity = $this->createMock('\Drupal\Core\Entity\EntityInterface');
     $mock_entity->expects($this->any())
       ->method('id')
       ->willReturn((string) $id);
@@ -153,9 +151,7 @@ public function testLoadMultiple($expected, $load_multiple, $query) {
       ->willReturn($load_multiple);
 
     // Make our EntityTypeInterface mock so that we can turn off static caching.
-    $mock_entity_type = $this->getMockBuilder('\Drupal\Core\Entity\EntityTypeInterface')
-      ->onlyMethods(['isStaticallyCacheable'])
-      ->getMockForAbstractClass();
+    $mock_entity_type = $this->createMock('\Drupal\Core\Entity\EntityTypeInterface');
     // Disallow caching.
     $mock_entity_type->expects($this->any())
       ->method('isStaticallyCacheable')
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/EntityTypeManagerTest.php b/web/core/tests/Drupal/Tests/Core/Entity/EntityTypeManagerTest.php
index 5ab49683c7e9d3e0531b5bdd2333fb9e9c2390ee..86504ffa595895808413001d1307a70a04c30181 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/EntityTypeManagerTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/EntityTypeManagerTest.php
@@ -246,18 +246,52 @@ public function testGetFormObject() {
     $this->assertEquals('yellow', $banana_form->color);
   }
 
+  /**
+   * Provides test data for testGetFormObjectInvalidOperation().
+   *
+   * @return array
+   *   Test data.
+   */
+  public function provideFormObjectInvalidOperationData(): array {
+    return [
+      'missing_form_handler' => [
+        'test_entity_type',
+        'edit',
+        '',
+        'The "test_entity_type" entity type did not specify a "edit" form class.',
+      ],
+      'missing_form_handler_class' => [
+        'test_entity_type',
+        'edit',
+        'Drupal\test_entity_type\Form\NonExistingClass',
+        'The "edit" form handler of the "test_entity_type" entity type specifies a non-existent class "Drupal\test_entity_type\Form\NonExistingClass".',
+      ],
+    ];
+  }
+
   /**
    * Tests the getFormObject() method with an invalid operation.
    *
    * @covers ::getFormObject
+   *
+   * @dataProvider provideFormObjectInvalidOperationData
    */
-  public function testGetFormObjectInvalidOperation() {
+  public function testGetFormObjectInvalidOperation(string $entity_type_id, string $operation, string $form_class, string $exception_message): void {
     $entity = $this->prophesize(EntityTypeInterface::class);
-    $entity->getFormClass('edit')->willReturn('');
-    $this->setUpEntityTypeDefinitions(['test_entity_type' => $entity]);
+    $entity->getFormClass($operation)->willReturn(NULL);
+    if (!$form_class) {
+      $entity->getHandlerClasses()->willReturn([]);
+    }
+    else {
+      $entity->getHandlerClasses()->willReturn([
+        'form' => [$operation => $form_class],
+      ]);
+    }
+    $this->setUpEntityTypeDefinitions([$entity_type_id => $entity]);
 
     $this->expectException(InvalidPluginDefinitionException::class);
-    $this->entityTypeManager->getFormObject('test_entity_type', 'edit');
+    $this->expectExceptionMessage($exception_message);
+    $this->entityTypeManager->getFormObject($entity_type_id, $operation);
   }
 
   /**
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php b/web/core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php
index c564a3e17f1ec6f74e59cdb1bb91df16305a7f1d..2ac0a72f001df2edc7a7173cb0d312edcd6b2212 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/EntityUnitTest.php
@@ -103,7 +103,7 @@ protected function setUp(): void {
       ->method('getListCacheTags')
       ->willReturn([$this->entityTypeId . '_list']);
 
-    $this->entityTypeManager = $this->getMockForAbstractClass(EntityTypeManagerInterface::class);
+    $this->entityTypeManager = $this->createMock(EntityTypeManagerInterface::class);
     $this->entityTypeManager->expects($this->any())
       ->method('getDefinition')
       ->with($this->entityTypeId)
@@ -255,7 +255,7 @@ public function testLoad() {
 
     $class_name = get_class($this->entity);
 
-    $entity_type_repository = $this->getMockForAbstractClass(EntityTypeRepositoryInterface::class);
+    $entity_type_repository = $this->createMock(EntityTypeRepositoryInterface::class);
     $entity_type_repository->expects($this->once())
       ->method('getEntityTypeFromClass')
       ->with($class_name)
@@ -289,7 +289,7 @@ public function testLoadMultiple() {
 
     $class_name = get_class($this->entity);
 
-    $entity_type_repository = $this->getMockForAbstractClass(EntityTypeRepositoryInterface::class);
+    $entity_type_repository = $this->createMock(EntityTypeRepositoryInterface::class);
     $entity_type_repository->expects($this->once())
       ->method('getEntityTypeFromClass')
       ->with($class_name)
@@ -321,7 +321,7 @@ public function testCreate() {
 
     $class_name = get_class($this->entity);
 
-    $entity_type_repository = $this->getMockForAbstractClass(EntityTypeRepositoryInterface::class);
+    $entity_type_repository = $this->createMock(EntityTypeRepositoryInterface::class);
     $entity_type_repository->expects($this->once())
       ->method('getEntityTypeFromClass')
       ->with($class_name)
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php b/web/core/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php
index 2fc1f84b3f45a58f66c308423c3d0161e5bc40ad..d6b7c2f9d722c4167d137c55e0571d95b3cac6f5 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/EntityUrlTest.php
@@ -110,27 +110,52 @@ public function testToUrlNoId() {
   }
 
   /**
-   * Tests the toUrl() method without specifying the $rel parameter..
+   * Tests the toUrl() method without specifying the $rel parameter.
+   *
+   * It should throw an exception when neither canonical and edit-form link
+   * templates exist if no parameters are passed in.
    *
    * @covers ::toUrl
    */
-  public function testToUrlDefault() {
+  public function testToUrlDefaultException(): void {
     $values = ['id' => $this->entityId];
     $entity = $this->getEntity(UrlTestEntity::class, $values);
+    $this->entityType->getUriCallback()->willReturn(NULL);
 
     $this->expectException(UndefinedLinkTemplateException::class);
     $this->expectExceptionMessage("Cannot generate default URL because no link template 'canonical' or 'edit-form' was found for the '" . $this->entityTypeId . "' entity type");
     $entity->toUrl();
+  }
 
+  /**
+   * Tests the toUrl() method without specifying the $rel parameter.
+   *
+   * It should return the edit-form or canonical link templates by default if
+   * they are registered.
+   *
+   * @covers ::toUrl
+   */
+  public function testToUrlDefaultFallback(): void {
+    $values = ['id' => $this->entityId, 'langcode' => $this->langcode];
+    $entity = $this->getEntity(UrlTestEntity::class, $values);
     $this->registerLinkTemplate('edit-form');
     /** @var \Drupal\Core\Url $url */
     $url = $entity->toUrl();
-    $this->assertUrl('entity.test_entity.edit_form', ['test_entity' => $this->entityId], $entity, FALSE, $url);
+    $this->assertUrl('entity.test_entity.edit_form', ['test_entity' => $this->entityId], $entity, TRUE, $url);
 
     $this->registerLinkTemplate('canonical');
     /** @var \Drupal\Core\Url $url */
     $url = $entity->toUrl();
-    $this->assertUrl('entity.test_entity.canonical', ['test_entity' => $this->entityId], $entity, FALSE, $url);
+    $this->assertUrl('entity.test_entity.canonical', ['test_entity' => $this->entityId], $entity, TRUE, $url);
+
+    // Register multiple link templates with 2 that share the same path.
+    $this->entityType->getLinkTemplates()->willReturn([
+      'canonical' => "/test-entity/{test_entity}/canonical",
+      'edit-form' => "/test-entity/{test_entity}/edit-form",
+      'foobar' => "/test-entity/{test_entity}/canonical",
+    ]);
+    $url = $entity->toUrl();
+    $this->assertUrl('entity.test_entity.canonical', ['test_entity' => $this->entityId], $entity, TRUE, $url);
   }
 
   /**
@@ -385,6 +410,9 @@ public function testToUrlUriCallback(array $bundle_info, $uri_callback) {
     /** @var \Drupal\Core\Url $url */
     $url = $entity->toUrl('canonical');
     $this->assertUrl('<none>', [], $entity, TRUE, $url);
+
+    $url = $entity->toUrl();
+    $this->assertUrl('<none>', [], $entity, TRUE, $url);
   }
 
   /**
diff --git a/web/core/tests/Drupal/Tests/Core/Entity/TypedData/EntityAdapterUnitTest.php b/web/core/tests/Drupal/Tests/Core/Entity/TypedData/EntityAdapterUnitTest.php
index 3b4de81d80b11deafd2697d3572a53dcaf501004..89b78dd560e43bde86e7ebbf4ad6ed7ba8170ff5 100644
--- a/web/core/tests/Drupal/Tests/Core/Entity/TypedData/EntityAdapterUnitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Entity/TypedData/EntityAdapterUnitTest.php
@@ -195,7 +195,7 @@ protected function setUp(): void {
       ->method('createFieldItemList')
       ->willReturn($this->fieldItemList);
 
-    $this->entityFieldManager = $this->getMockForAbstractClass(EntityFieldManagerInterface::class);
+    $this->entityFieldManager = $this->createMock(EntityFieldManagerInterface::class);
 
     $container = new ContainerBuilder();
     $container->set('entity_type.manager', $this->entityTypeManager);
diff --git a/web/core/tests/Drupal/Tests/Core/Error/DrupalLogErrorTest.php b/web/core/tests/Drupal/Tests/Core/Error/DrupalLogErrorTest.php
index d07c425ea54554e08d2986a2b3f95a134d0696e6..4bd3e8bbab4f10079a30ccda9600e0d4dffe772a 100644
--- a/web/core/tests/Drupal/Tests/Core/Error/DrupalLogErrorTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Error/DrupalLogErrorTest.php
@@ -19,7 +19,7 @@ class DrupalLogErrorTest extends UnitTestCase {
    *
    * @dataProvider provideFatalExitCodeData
    */
-  public function testFatalExitCode(string $script, string $output, string $errorOutput, bool $processIsSuccessful) {
+  public function testFatalExitCode(string $script, string $output, string $errorOutput, bool $processIsSuccessful): void {
     // We need to override the current working directory for invocations from
     // run-tests.sh to work properly.
     $process = new PhpProcess($script, $this->root);
@@ -32,9 +32,9 @@ public function testFatalExitCode(string $script, string $output, string $errorO
     $this->assertSame($processIsSuccessful, $process->isSuccessful());
   }
 
-  public function provideFatalExitCodeData() {
+  public function provideFatalExitCodeData(): array {
     $verbose = "\$GLOBALS['config']['system.logging']['error_level'] = 'verbose';";
-    $scriptBody = $this->getScriptBody();
+    $scriptBody = self::getScriptBody();
     $data['normal'] = [
       "<?php\n\$fatal = TRUE;\n$scriptBody",
       "kernel test: This is a test message in test_function (line 456 of test.module).\n",
@@ -50,7 +50,7 @@ public function provideFatalExitCodeData() {
     return $data;
   }
 
-  protected function getScriptBody() {
+  protected static function getScriptBody(): string {
     return <<<'EOT'
 if (PHP_SAPI !== 'cli') {
   return;
diff --git a/web/core/tests/Drupal/Tests/Core/EventSubscriber/RssResponseRelativeUrlFilterTest.php b/web/core/tests/Drupal/Tests/Core/EventSubscriber/RssResponseRelativeUrlFilterTest.php
index b97522dee6e7b7b5467883241f241f1061725bea..70e4cfb32d02bdeaa2f6f5291876eb743894bcd0 100644
--- a/web/core/tests/Drupal/Tests/Core/EventSubscriber/RssResponseRelativeUrlFilterTest.php
+++ b/web/core/tests/Drupal/Tests/Core/EventSubscriber/RssResponseRelativeUrlFilterTest.php
@@ -26,7 +26,7 @@ public function providerTestOnResponse() {
 <channel>
   <title>Drupal.org</title>
   <link>https://www.drupal.org</link>
-  <description>Come for the software, stay for the community
+  <description>Come for the software &amp; stay for the community
 Drupal is an open source content management platform powering millions of websites and applications. It’s built, used, and supported by an active and diverse community of people around the world.</description>
   <language>en</language>
   <item>
@@ -45,7 +45,7 @@ public function providerTestOnResponse() {
 <channel>
   <title>Drupal.org</title>
   <link>https://www.drupal.org</link>
-  <description>Come for the software, stay for the community
+  <description>Come for the software &amp; stay for the community
 Drupal is an open source content management platform powering millions of websites and applications. It’s built, used, and supported by an active and diverse community of people around the world.</description>
   <language>en</language>
   <item>
diff --git a/web/core/tests/Drupal/Tests/Core/Extension/InfoParserUnitTest.php b/web/core/tests/Drupal/Tests/Core/Extension/InfoParserUnitTest.php
index bf70c5522d47b4838eacb3400b18de6e87e12ff8..027eeb40c3a12064325d67826315e8c7dd846721 100644
--- a/web/core/tests/Drupal/Tests/Core/Extension/InfoParserUnitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Extension/InfoParserUnitTest.php
@@ -55,94 +55,101 @@ public function testInfoParserNonExisting() {
   /**
    * Tests if correct exception is thrown for a broken info file.
    *
-   * @covers ::parse
+   * @param string $yaml
+   *   The YAML to use to create the file to parse.
+   * @param string $expected_exception_message
+   *   The expected exception message.
+   *
+   * @dataProvider providerInfoException
    */
-  public function testInfoParserBroken() {
-    $broken_info = <<<BROKEN_INFO
-# info.yml for testing broken YAML parsing exception handling.
-name: File
-type: module
-description: 'Defines a file field type.'
-package: Core
-version: VERSION
-core_version_requirement: '*'
-dependencies::;;
-  - field
-BROKEN_INFO;
+  public function testInfoException($yaml, $expected_exception_message): void {
 
     vfsStream::setup('modules');
     vfsStream::create([
       'fixtures' => [
-        'broken.info.txt' => $broken_info,
+        "broken.info.txt" => $yaml,
+        "broken-duplicate.info.txt" => $yaml,
       ],
     ]);
-    $filename = vfsStream::url('modules/fixtures/broken.info.txt');
-    $this->expectException('\Drupal\Core\Extension\InfoParserException');
-    $this->expectExceptionMessage('broken.info.txt');
-    $this->infoParser->parse($filename);
+
+    try {
+      $this->infoParser->parse(vfsStream::url("modules/fixtures/broken.info.txt"));
+    }
+    catch (InfoParserException $exception) {
+      $this->assertSame("$expected_exception_message vfs://modules/fixtures/broken.info.txt", $exception->getMessage());
+    }
+
+    $this->expectException(InfoParserException::class);
+    $this->expectExceptionMessage("$expected_exception_message vfs://modules/fixtures/broken-duplicate.info.txt");
+    $this->infoParser->parse(vfsStream::url("modules/fixtures/broken-duplicate.info.txt"));
   }
 
   /**
-   * Tests that missing required keys are detected.
-   *
-   * @covers ::parse
+   * Data provider for testInfoException().
    */
-  public function testInfoParserMissingKeys() {
-    $missing_keys = <<<MISSING_KEYS
-# info.yml for testing missing name, description, and type keys.
+  public static function providerInfoException(): array {
+    return [
+      'missing required key, type' => [
+    <<<YML
+name: File
+description: Missing key
 package: Core
 version: VERSION
 dependencies:
   - field
-MISSING_KEYS;
-
-    vfsStream::setup('modules');
-    vfsStream::create([
-      'fixtures' => [
-        'missing_keys.info.txt' => $missing_keys,
+YML,
+        "Missing required keys (type) in",
       ],
-    ]);
-    $filename = vfsStream::url('modules/fixtures/missing_keys.info.txt');
-    $this->expectException('\Drupal\Core\Extension\InfoParserException');
-    $this->expectExceptionMessage('Missing required keys (type, name) in vfs://modules/fixtures/missing_keys.info.txt');
-    $this->infoParser->parse($filename);
+      'missing core_version_requirement' => [
+      <<<YML
+version: VERSION
+type: module
+name: Skynet
+dependencies:
+  - self_awareness
+YML,
+        "The 'core_version_requirement' key must be present in",
+      ],
+      'missing two required keys' => [
+      <<<YML
+package: Core
+version: VERSION
+dependencies:
+  - field
+YML,
+        'Missing required keys (type, name) in',
+      ],
+    ];
   }
 
   /**
-   * Tests that a missing 'core_version_requirement' key is detected.
+   * Tests that the correct exception is thrown for a broken info file.
    *
    * @covers ::parse
    */
-  public function testMissingCoreVersionRequirement() {
-    $missing_core_version_requirement = <<<MISSING_CORE_VERSION_REQUIREMENT
-# info.yml for testing core_version_requirement.
-version: VERSION
+  public function testInfoParserBroken() {
+    $broken_info = <<<BROKEN_INFO
+# info.yml for testing broken YAML parsing exception handling.
+name: File
 type: module
-name: Skynet
-dependencies:
-  - self_awareness
-MISSING_CORE_VERSION_REQUIREMENT;
+description: 'Defines a file field type.'
+package: Core
+version: VERSION
+core_version_requirement: '*'
+dependencies::;;
+  - field
+BROKEN_INFO;
 
     vfsStream::setup('modules');
     vfsStream::create([
       'fixtures' => [
-        'missing_core_version_requirement.info.txt' => $missing_core_version_requirement,
-        'missing_core_version_requirement-duplicate.info.txt' => $missing_core_version_requirement,
+        'broken.info.txt' => $broken_info,
       ],
     ]);
-    $exception_message = "The 'core_version_requirement' key must be present in vfs://modules/fixtures/missing_core_version_requirement";
-    // Set the expected exception for the 2nd call to parse().
+    $filename = vfsStream::url('modules/fixtures/broken.info.txt');
     $this->expectException('\Drupal\Core\Extension\InfoParserException');
-    $this->expectExceptionMessage("$exception_message-duplicate.info.txt");
-
-    try {
-      $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_core_version_requirement.info.txt'));
-    }
-    catch (InfoParserException $exception) {
-      $this->assertSame("$exception_message.info.txt", $exception->getMessage());
-
-      $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_core_version_requirement-duplicate.info.txt'));
-    }
+    $this->expectExceptionMessage('Unable to parse vfs://modules/fixtures/broken.info.txt');
+    $this->infoParser->parse($filename);
   }
 
   /**
@@ -169,43 +176,6 @@ public function testTestingPackageMissingCoreVersionRequirement() {
     $this->assertSame($info_values['core_version_requirement'], \Drupal::VERSION);
   }
 
-  /**
-   * Tests that missing required key is detected.
-   *
-   * @covers ::parse
-   */
-  public function testInfoParserMissingKey() {
-    $missing_key = <<<MISSING_KEY
-# info.yml for testing missing type key.
-name: File
-description: 'Defines a file field type.'
-package: Core
-version: VERSION
-dependencies:
-  - field
-MISSING_KEY;
-
-    vfsStream::setup('modules');
-    vfsStream::create([
-      'fixtures' => [
-        'missing_key.info.txt' => $missing_key,
-        'missing_key-duplicate.info.txt' => $missing_key,
-      ],
-    ]);
-    // Set the expected exception for the 2nd call to parse().
-    $this->expectException(InfoParserException::class);
-    $this->expectExceptionMessage('Missing required keys (type) in vfs://modules/fixtures/missing_key-duplicate.info.txt');
-    try {
-      $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_key.info.txt'));
-    }
-    catch (InfoParserException $exception) {
-      $this->assertSame('Missing required keys (type) in vfs://modules/fixtures/missing_key.info.txt', $exception->getMessage());
-
-      $this->infoParser->parse(vfsStream::url('modules/fixtures/missing_key-duplicate.info.txt'));
-    }
-
-  }
-
   /**
    * Tests common info file.
    *
diff --git a/web/core/tests/Drupal/Tests/Core/Field/FieldItemListTest.php b/web/core/tests/Drupal/Tests/Core/Field/FieldItemListTest.php
index e50b29b344fdc9047dd6b0832b29075af01952be..70c7358bf01cd81dbfe3a13a165515c7a7270853 100644
--- a/web/core/tests/Drupal/Tests/Core/Field/FieldItemListTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Field/FieldItemListTest.php
@@ -6,6 +6,7 @@
 
 use Drupal\Core\DependencyInjection\ContainerBuilder;
 use Drupal\Core\Field\FieldDefinitionInterface;
+use Drupal\Core\Field\FieldItemBase;
 use Drupal\Core\Field\FieldItemInterface;
 use Drupal\Core\Field\FieldItemList;
 use Drupal\Core\Field\FieldStorageDefinitionInterface;
@@ -77,12 +78,12 @@ public function testEquals($expected, FieldItemInterface $first_field_item = NUL
   /**
    * Data provider for testEquals.
    */
-  public function providerTestEquals() {
+  public static function providerTestEquals() {
     // Tests field item lists with no values.
     $datasets[] = [TRUE];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_a */
-    $field_item_a = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_a = new FieldItemTestClass();
     $field_item_a->setValue([1]);
     // Tests field item lists where one has a value and one does not.
     $datasets[] = [FALSE, $field_item_a];
@@ -91,22 +92,22 @@ public function providerTestEquals() {
     $datasets[] = [TRUE, $field_item_a, $field_item_a];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $fv */
-    $field_item_b = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_b = new FieldItemTestClass();
     $field_item_b->setValue([2]);
     // Tests field item lists where both have the different values.
     $datasets[] = [FALSE, $field_item_a, $field_item_b];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $fv */
-    $field_item_c = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_c = new FieldItemTestClass();
     $field_item_c->setValue(['0' => 1, '1' => 2]);
-    $field_item_d = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_d = new FieldItemTestClass();
     $field_item_d->setValue(['1' => 2, '0' => 1]);
 
     // Tests field item lists where both have the differently ordered values.
     $datasets[] = [TRUE, $field_item_c, $field_item_d];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_e */
-    $field_item_e = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_e = new FieldItemTestClass();
     $field_item_e->setValue(['2']);
 
     // Tests field item lists where both have same values but different data
@@ -114,10 +115,10 @@ public function providerTestEquals() {
     $datasets[] = [TRUE, $field_item_b, $field_item_e];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_f */
-    $field_item_f = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_f = new FieldItemTestClass();
     $field_item_f->setValue(['0' => 1, '1' => 2, '2' => 3]);
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_g */
-    $field_item_g = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_g = new FieldItemTestClass();
     $field_item_g->setValue(['0' => 1, '1' => 2, '2' => 4]);
 
     // Tests field item lists where both have same values for the non-computed
@@ -126,10 +127,10 @@ public function providerTestEquals() {
     $datasets[] = [TRUE, $field_item_f, $field_item_g];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_h */
-    $field_item_h = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_h = new FieldItemTestClass();
     $field_item_h->setValue(['0' => 1, '1' => 2, '3' => 3]);
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_i */
-    $field_item_i = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_i = new FieldItemTestClass();
     $field_item_i->setValue(['0' => 1, '1' => 2, '3' => 4]);
 
     // Tests field item lists where both have same values for the non-computed
@@ -138,16 +139,16 @@ public function providerTestEquals() {
     $datasets[] = [TRUE, $field_item_h, $field_item_i];
 
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_j */
-    $field_item_j = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_j = new FieldItemTestClass();
     $field_item_j->setValue(['0' => 1]);
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_k */
-    $field_item_k = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_k = new FieldItemTestClass();
     $field_item_k->setValue(['0' => 1, '1' => NULL]);
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_l */
-    $field_item_l = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_l = new FieldItemTestClass();
     $field_item_l->setValue(['0' => 1, '1' => FALSE]);
     /** @var \Drupal\Core\Field\FieldItemBase  $field_item_m */
-    $field_item_m = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $field_item_m = new FieldItemTestClass();
     $field_item_m->setValue(['0' => 1, '1' => '']);
 
     // Tests filter properties with a NULL value. Empty strings or other false-y
@@ -229,11 +230,11 @@ public function testHasAffectingChanges($expected, FieldItemInterface $first_fie
    */
   public function testEqualsEmptyItems() {
     /** @var \Drupal\Core\Field\FieldItemBase  $fv */
-    $first_field_item = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $first_field_item = new FieldItemTestClass();
     $first_field_item->setValue(['0' => 1, '1' => 2]);
-    $second_field_item = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $second_field_item = new FieldItemTestClass();
     $second_field_item->setValue(['1' => 2, '0' => 1]);
-    $empty_field_item = $this->getMockForAbstractClass('Drupal\Core\Field\FieldItemBase', [], '', FALSE);
+    $empty_field_item = new FieldItemTestClass();
     // Mock the field type manager and place it in the container.
     $field_type_manager = $this->createMock('Drupal\Core\Field\FieldTypePluginManagerInterface');
     $container = new ContainerBuilder();
@@ -355,3 +356,21 @@ public function testDefaultValuesFormSubmit() {
   }
 
 }
+
+/**
+ * A class extending FieldItemBase for testing purposes.
+ */
+class FieldItemTestClass extends FieldItemBase {
+
+  public function __construct() {
+  }
+
+  public static function propertyDefinitions(FieldStorageDefinitionInterface $field_definition): array {
+    return [];
+  }
+
+  public static function schema(FieldStorageDefinitionInterface $field_definition): array {
+    return [];
+  }
+
+}
diff --git a/web/core/tests/Drupal/Tests/Core/Form/ConfigFormBaseTraitTest.php b/web/core/tests/Drupal/Tests/Core/Form/ConfigFormBaseTraitTest.php
index 89c277ded385f0ed610322cbfdf51b79b302dd20..0604fda0b4b7f28d69d3f577a021e75b84b08c8d 100644
--- a/web/core/tests/Drupal/Tests/Core/Form/ConfigFormBaseTraitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Form/ConfigFormBaseTraitTest.php
@@ -45,26 +45,26 @@ public function testConfig() {
    * @covers ::config
    */
   public function testConfigFactoryException() {
-    $trait = $this->getMockForTrait('Drupal\Core\Form\ConfigFormBaseTrait');
-    $config_method = new \ReflectionMethod($trait, 'config');
+    $testObject = new ConfiguredTrait();
 
     // There is no config factory available this should result in an exception.
     $this->expectException(\LogicException::class);
     $this->expectExceptionMessage('No config factory available for ConfigFormBaseTrait');
-    $config_method->invoke($trait, 'editable.config');
+    $config_method = new \ReflectionMethod($testObject, 'config');
+    $config_method->invoke($testObject, 'editable.config');
   }
 
   /**
    * @covers ::config
    */
   public function testConfigFactoryExceptionInvalidProperty() {
-    $trait = $this->getMockForTrait('Drupal\Core\Form\ConfigFormBaseTrait');
-    $config_method = new \ReflectionMethod($trait, 'config');
+    $testObject = new ConfiguredTrait();
 
     // There is no config factory available this should result in an exception.
     $this->expectException(\LogicException::class);
     $this->expectExceptionMessage('No config factory available for ConfigFormBaseTrait');
-    $config_method->invoke($trait, 'editable.config');
+    $config_method = new \ReflectionMethod($testObject, 'config');
+    $config_method->invoke($testObject, 'editable.config');
   }
 
 }
diff --git a/web/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php b/web/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php
index fe5f2c4d4570f3e65f5fb5ef88ccf7a19e539651..77de7e2e4e004a3771d1ef1e9bced6c3b0a5fdcf 100644
--- a/web/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php
@@ -595,7 +595,7 @@ public function testExceededFileSize() {
   /**
    * @covers ::buildForm
    */
-  public function testGetPostAjaxRequest() {
+  public function testPostAjaxRequest(): void {
     $request = new Request([FormBuilderInterface::AJAX_FORM_REQUEST => TRUE], ['form_id' => 'different_form_id']);
     $request->setMethod('POST');
     $this->requestStack->push($request);
@@ -615,6 +615,30 @@ public function testGetPostAjaxRequest() {
     $this->assertSame('test-form', $form['#id']);
   }
 
+  /**
+   * @covers ::buildForm
+   */
+  public function testGetAjaxRequest(): void {
+    $request = new Request([FormBuilderInterface::AJAX_FORM_REQUEST => TRUE]);
+    $request->query->set('form_id', 'different_form_id');
+    $request->setMethod('GET');
+    $this->requestStack->push($request);
+
+    $form_state = (new FormState())
+      ->setUserInput([FormBuilderInterface::AJAX_FORM_REQUEST => TRUE])
+      ->setMethod('get')
+      ->setAlwaysProcess()
+      ->disableRedirect()
+      ->set('ajax', TRUE);
+
+    $form_id = '\Drupal\Tests\Core\Form\TestForm';
+    $expected_form = (new TestForm())->buildForm([], $form_state);
+
+    $form = $this->formBuilder->buildForm($form_id, $form_state);
+    $this->assertFormElement($expected_form, $form, 'test');
+    $this->assertSame('test-form', $form['#id']);
+  }
+
   /**
    * @covers ::buildForm
    *
diff --git a/web/core/tests/Drupal/Tests/Core/Form/FormValidatorTest.php b/web/core/tests/Drupal/Tests/Core/Form/FormValidatorTest.php
index db334a0feef60deeb8da273be753929dda67c81c..4be62209529f34c4e55a33c8ef9730e963940ecd 100644
--- a/web/core/tests/Drupal/Tests/Core/Form/FormValidatorTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Form/FormValidatorTest.php
@@ -373,10 +373,7 @@ public function testElementValidate() {
    * @dataProvider providerTestPerformRequiredValidation
    */
   public function testPerformRequiredValidation($element, $expected_message, $call_watchdog) {
-    $form_validator = $this->getMockBuilder('Drupal\Core\Form\FormValidator')
-      ->setConstructorArgs([new RequestStack(), $this->getStringTranslationStub(), $this->csrfToken, $this->logger, $this->formErrorHandler])
-      ->addMethods(['setError'])
-      ->getMock();
+    $form_validator = new FormValidator(new RequestStack(), $this->getStringTranslationStub(), $this->csrfToken, $this->logger, $this->formErrorHandler);
 
     if ($call_watchdog) {
       $this->logger->expects($this->once())
diff --git a/web/core/tests/Drupal/Tests/Core/Image/ImageTest.php b/web/core/tests/Drupal/Tests/Core/Image/ImageTest.php
index 80cb15d75162bd21181f79c09c79d92670647f43..53788d4b84b8e10da9f1a90b289d50b0afb31f8e 100644
--- a/web/core/tests/Drupal/Tests/Core/Image/ImageTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Image/ImageTest.php
@@ -339,7 +339,7 @@ public function testScaleAndCropWidth() {
       ->method('execute')
       ->will($this->returnArgument(0));
 
-    $ret = $this->image->scaleAndCrop(34, 50, FALSE);
+    $ret = $this->image->scaleAndCrop(34, 50);
     $this->assertEquals(5, $ret['x']);
   }
 
diff --git a/web/core/tests/Drupal/Tests/Core/Logger/LoggerChannelTest.php b/web/core/tests/Drupal/Tests/Core/Logger/LoggerChannelTest.php
index b0896b3fc4ff3529c6823b9c29e7fd54bf480e3f..1caed3b429e5ba61e83679fe3a24d2e6d10a0147 100644
--- a/web/core/tests/Drupal/Tests/Core/Logger/LoggerChannelTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Logger/LoggerChannelTest.php
@@ -7,6 +7,7 @@
 use Drupal\Core\Logger\LoggerChannel;
 use Drupal\Core\Session\AccountInterface;
 use Drupal\Tests\UnitTestCase;
+use Symfony\Component\HttpFoundation\HeaderBag;
 use Symfony\Component\HttpFoundation\Request;
 use Symfony\Component\HttpFoundation\RequestStack;
 use Psr\Log\LoggerInterface;
@@ -142,7 +143,7 @@ public function providerTestLog() {
     $request_mock->expects($this->any())
       ->method('getClientIp')
       ->willReturn('127.0.0.1');
-    $request_mock->headers = $this->createMock('Symfony\Component\HttpFoundation\ParameterBag');
+    $request_mock->headers = $this->createMock(HeaderBag::class);
 
     // No request or account.
     $cases[] = [
diff --git a/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextDefinitionTest.php b/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextDefinitionTest.php
index 6a54511a545a2b5913fd2f61e83aa0279c78dd02..c0b5c289615d13b6a91f53216f90d470d87d8311 100644
--- a/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextDefinitionTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextDefinitionTest.php
@@ -35,15 +35,7 @@ public function providerGetDataDefinition() {
    */
   public function testGetDataDefinition($is_multiple) {
     $data_type = 'valid';
-    $mock_data_definition = $this->getMockBuilder(ContextDefinitionInterface::class)
-      ->onlyMethods([
-        'getConstraints',
-        'setLabel',
-        'setDescription',
-        'setRequired',
-        'setConstraints',
-      ])
-      ->getMockForAbstractClass();
+    $mock_data_definition = $this->createMock(ContextDefinitionInterface::class);
     $mock_data_definition->expects($this->once())
       ->method('setLabel')
       ->willReturnSelf();
@@ -118,8 +110,7 @@ public function testGetDataDefinitionInvalidType($is_multiple) {
     // Since we're trying to make getDataDefinition() throw an exception in
     // isolation, we use a data type which is not valid.
     $data_type = 'not_valid';
-    $mock_data_definition = $this->getMockBuilder('\Drupal\Core\TypedData\ListDataDefinitionInterface')
-      ->getMockForAbstractClass();
+    $mock_data_definition = $this->createMock('\Drupal\Core\TypedData\ListDataDefinitionInterface');
 
     // Follow code paths for both multiple and non-multiple definitions.
     $create_definition_method = 'createDataDefinition';
diff --git a/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextTest.php b/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextTest.php
index 4e2d49a288298dc5a22a3e68e3aa30bc22ea4b88..ba24da9008c29f1d403754c5af0b087ca0cdad91 100644
--- a/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Plugin/Context/ContextTest.php
@@ -85,9 +85,7 @@ public function testNullDataValue() {
    */
   public function testSetContextValueTypedData() {
 
-    $this->contextDefinition = $this->getMockBuilder('Drupal\Core\Plugin\Context\ContextDefinitionInterface')
-      ->onlyMethods(['getDefaultValue', 'getDataDefinition'])
-      ->getMockForAbstractClass();
+    $this->contextDefinition = $this->createMock('Drupal\Core\Plugin\Context\ContextDefinitionInterface');
 
     $typed_data = $this->createMock('Drupal\Core\TypedData\TypedDataInterface');
     $context = new Context($this->contextDefinition, $typed_data);
@@ -141,9 +139,7 @@ public function testSetContextValueCacheableDependency() {
   protected function setUpDefaultValue($default_value = NULL) {
     $mock_data_definition = $this->createMock('Drupal\Core\TypedData\DataDefinitionInterface');
 
-    $this->contextDefinition = $this->getMockBuilder('Drupal\Core\Plugin\Context\ContextDefinitionInterface')
-      ->onlyMethods(['getDefaultValue', 'getDataDefinition'])
-      ->getMockForAbstractClass();
+    $this->contextDefinition = $this->createMock('Drupal\Core\Plugin\Context\ContextDefinitionInterface');
 
     $this->contextDefinition->expects($this->once())
       ->method('getDefaultValue')
diff --git a/web/core/tests/Drupal/Tests/Core/Routing/ContentTypeHeaderMatcherTest.php b/web/core/tests/Drupal/Tests/Core/Routing/ContentTypeHeaderMatcherTest.php
index da8facef8ddae3b79641dd434487ddee8b00d0f0..3eb53af4daaafd6663de874474e7f3f49bc23617 100644
--- a/web/core/tests/Drupal/Tests/Core/Routing/ContentTypeHeaderMatcherTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Routing/ContentTypeHeaderMatcherTest.php
@@ -6,7 +6,7 @@
 
 use Drupal\Core\Routing\ContentTypeHeaderMatcher;
 use Drupal\Tests\UnitTestCase;
-use Symfony\Component\HttpFoundation\ParameterBag;
+use Symfony\Component\HttpFoundation\HeaderBag;
 use Symfony\Component\HttpFoundation\Request;
 use Symfony\Component\HttpKernel\Exception\UnsupportedMediaTypeHttpException;
 
@@ -130,7 +130,7 @@ public function testContentTypeRequestHeaderMissing() {
     $routes = $this->fixtures->contentRouteCollection();
     $request = Request::create('path/two', 'POST');
     // Delete all request headers that Request::create() sets by default.
-    $request->headers = new ParameterBag();
+    $request->headers = new HeaderBag();
     $this->expectException(UnsupportedMediaTypeHttpException::class);
     $this->expectExceptionMessage('No "Content-Type" request header specified');
     $matcher->filter($routes, $request);
diff --git a/web/core/tests/Drupal/Tests/Core/StackMiddleware/NegotiationMiddlewareTest.php b/web/core/tests/Drupal/Tests/Core/StackMiddleware/NegotiationMiddlewareTest.php
index 8e5cc374e0d0b305d53f7cc5c69d10b68c64fb7b..594d6075db0ee52f406b5c3ee0b4838d2c191f7e 100644
--- a/web/core/tests/Drupal/Tests/Core/StackMiddleware/NegotiationMiddlewareTest.php
+++ b/web/core/tests/Drupal/Tests/Core/StackMiddleware/NegotiationMiddlewareTest.php
@@ -6,7 +6,7 @@
 
 use Drupal\Core\StackMiddleware\NegotiationMiddleware;
 use Drupal\Tests\UnitTestCase;
-use Symfony\Component\HttpFoundation\ParameterBag;
+use Symfony\Component\HttpFoundation\InputBag;
 use Symfony\Component\HttpFoundation\Request;
 use Symfony\Component\HttpFoundation\Response;
 use Symfony\Component\HttpKernel\HttpKernelInterface;
@@ -99,11 +99,9 @@ public function testHandle() {
     $request->setRequestFormat()->shouldNotBeCalled();
 
     // Some getContentType calls we don't really care about but have to mock.
-    $request_data = $this->prophesize(ParameterBag::class);
-    $request_data->get('ajax_iframe_upload', FALSE)->willReturn(FALSE)->shouldBeCalled();
     $request_mock = $request->reveal();
-    $request_mock->query = new ParameterBag([]);
-    $request_mock->request = $request_data->reveal();
+    $request_mock->query = new InputBag();
+    $request_mock->request = new InputBag();
 
     // Calling kernel app with default arguments.
     $this->app->handle($request_mock, HttpKernelInterface::MAIN_REQUEST, TRUE)
@@ -139,11 +137,9 @@ public function testSetFormat() {
 
     // Some calls we don't care about.
     $request->setRequestFormat()->shouldNotBeCalled();
-    $request_data = $this->prophesize(ParameterBag::class);
-    $request_data->get('ajax_iframe_upload', FALSE)->willReturn(FALSE)->shouldBeCalled();
     $request_mock = $request->reveal();
-    $request_mock->query = new ParameterBag([]);
-    $request_mock->request = $request_data->reveal();
+    $request_mock->query = new InputBag();
+    $request_mock->request = new InputBag();
 
     // Trigger handle.
     $content_negotiation->registerFormat('david', 'geeky/david');
diff --git a/web/core/tests/Drupal/Tests/Core/StringTranslation/PluralTranslatableMarkupTest.php b/web/core/tests/Drupal/Tests/Core/StringTranslation/PluralTranslatableMarkupTest.php
index 738c85f9f1d0f639a57f6835ad643a58966743a9..a2cd7082266aa74726a9487d21269a841115b946 100644
--- a/web/core/tests/Drupal/Tests/Core/StringTranslation/PluralTranslatableMarkupTest.php
+++ b/web/core/tests/Drupal/Tests/Core/StringTranslation/PluralTranslatableMarkupTest.php
@@ -43,4 +43,12 @@ public function providerPluralTranslatableMarkupSerialization() {
     ];
   }
 
+  /**
+   * Tests when the plural translation is missing.
+   */
+  public function testMissingPluralTranslation() {
+    $markup = PluralTranslatableMarkup::createFromTranslatedString(2, 'There is no plural delimiter @count');
+    $this->assertEquals('There is no plural delimiter 2', $markup->render());
+  }
+
 }
diff --git a/web/core/tests/Drupal/Tests/Core/StringTranslation/StringTranslationTraitTest.php b/web/core/tests/Drupal/Tests/Core/StringTranslation/StringTranslationTraitTest.php
index 69cea9cae73501c60cc1dbdb7d990412b24fab71..dcb0a2ba8bda3a881dc39dcc0fffe98eebd899d0 100644
--- a/web/core/tests/Drupal/Tests/Core/StringTranslation/StringTranslationTraitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/StringTranslation/StringTranslationTraitTest.php
@@ -5,6 +5,7 @@
 namespace Drupal\Tests\Core\StringTranslation;
 
 use Drupal\Core\StringTranslation\PluralTranslatableMarkup;
+use Drupal\Core\StringTranslation\StringTranslationTrait;
 use Drupal\Core\StringTranslation\TranslatableMarkup;
 use Drupal\Core\StringTranslation\TranslationInterface;
 use Drupal\Tests\UnitTestCase;
@@ -17,19 +18,9 @@
 class StringTranslationTraitTest extends UnitTestCase {
 
   /**
-   * A reflection of self::$translation.
-   *
-   * @var \ReflectionClass
+   * The object under test that uses StringTranslationTrait.
    */
-  protected $reflection;
-
-  /**
-   * The mock under test that uses StringTranslationTrait.
-   *
-   * @var object
-   * @see \PHPUnit\Framework\MockObject\Generator::getObjectForTrait()
-   */
-  protected $translation;
+  protected object $testObject;
 
   /**
    * {@inheritdoc}
@@ -37,24 +28,29 @@ class StringTranslationTraitTest extends UnitTestCase {
   protected function setUp(): void {
     parent::setUp();
 
-    $this->translation = $this->getObjectForTrait('\Drupal\Core\StringTranslation\StringTranslationTrait');
-    $mock = $this->prophesize(TranslationInterface::class);
-    $mock->translate(Argument::cetera())->shouldNotBeCalled();
-    $mock->formatPlural(Argument::cetera())->shouldNotBeCalled();
-    $mock->translateString(Argument::cetera())->will(function ($args) {
+    // Prepare a mock translation service to pass to the trait.
+    $translation = $this->prophesize(TranslationInterface::class);
+    $translation->translate(Argument::cetera())->shouldNotBeCalled();
+    $translation->formatPlural(Argument::cetera())->shouldNotBeCalled();
+    $translation->translateString(Argument::cetera())->will(function ($args) {
       return $args[0]->getUntranslatedString();
     });
-    $this->translation->setStringTranslation($mock->reveal());
-    $this->reflection = new \ReflectionClass(get_class($this->translation));
+
+    // Set up the object under test.
+    $this->testObject = new class() {
+
+      use StringTranslationTrait;
+
+    };
+    $this->testObject->setStringTranslation($translation->reveal());
   }
 
   /**
    * @covers ::t
    */
-  public function testT() {
-    $method = $this->reflection->getMethod('t');
-
-    $result = $method->invoke($this->translation, 'something');
+  public function testT(): void {
+    $invokableT = new \ReflectionMethod($this->testObject, 't');
+    $result = $invokableT->invoke($this->testObject, 'something');
     $this->assertInstanceOf(TranslatableMarkup::class, $result);
     $this->assertEquals('something', $result);
   }
@@ -62,10 +58,12 @@ public function testT() {
   /**
    * @covers ::formatPlural
    */
-  public function testFormatPlural() {
-    $method = $this->reflection->getMethod('formatPlural');
-
-    $result = $method->invoke($this->translation, 2, 'apple', 'apples');
+  public function testFormatPlural(): void {
+    $invokableFormatPlural = new \ReflectionMethod($this->testObject, 'formatPlural');
+    $result = $invokableFormatPlural->invoke($this->testObject, 1, 'apple', 'apples');
+    $this->assertInstanceOf(PluralTranslatableMarkup::class, $result);
+    $this->assertEquals('apple', $result);
+    $result = $invokableFormatPlural->invoke($this->testObject, 2, 'apple', 'apples');
     $this->assertInstanceOf(PluralTranslatableMarkup::class, $result);
     $this->assertEquals('apples', $result);
   }
diff --git a/web/core/tests/Drupal/Tests/Core/Test/TestSetupTraitTest.php b/web/core/tests/Drupal/Tests/Core/Test/TestSetupTraitTest.php
index e3affb3e77885d9af5cba718b922305554a66e75..5cbdd2b900d06a18f1df1e71147c7970b471f6fe 100644
--- a/web/core/tests/Drupal/Tests/Core/Test/TestSetupTraitTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Test/TestSetupTraitTest.php
@@ -36,7 +36,11 @@ public function testChangeDatabasePrefix() {
 
     // Create a mock for testing the trait and set a few properties that are
     // used to avoid unnecessary set up.
-    $test_setup = $this->getMockForTrait(TestSetupTrait::class);
+    $test_setup = new class() {
+
+      use TestSetupTrait;
+
+    };
 
     $reflection = new \ReflectionClass($test_setup);
     $reflection->getProperty('databasePrefix')->setValue($test_setup, 'testDbPrefix');
diff --git a/web/core/tests/Drupal/Tests/Core/Utility/ErrorTest.php b/web/core/tests/Drupal/Tests/Core/Utility/ErrorTest.php
index 476a2de79c6a4c0a0f3fb0c9921eba1a0f7dfa94..9d6c740675b401e9b2323e19145b5975c0585de5 100644
--- a/web/core/tests/Drupal/Tests/Core/Utility/ErrorTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Utility/ErrorTest.php
@@ -23,7 +23,7 @@ class ErrorTest extends UnitTestCase {
    *
    * @dataProvider providerTestGetLastCaller
    */
-  public function testGetLastCaller($backtrace, $expected) {
+  public function testGetLastCaller(array $backtrace, array $expected): void {
     $this->assertSame($expected, Error::getLastCaller($backtrace));
   }
 
@@ -33,30 +33,30 @@ public function testGetLastCaller($backtrace, $expected) {
    * @return array
    *   An array of parameter data.
    */
-  public function providerTestGetLastCaller() {
+  public static function providerTestGetLastCaller(): array {
     $data = [];
 
     // Test with just one item. This should default to the function being
     // main().
-    $single_item = [$this->createBacktraceItem()];
-    $data[] = [$single_item, $this->createBacktraceItem('main()')];
+    $single_item = [self::createBacktraceItem()];
+    $data[] = [$single_item, self::createBacktraceItem('main()')];
 
     // Add a second item, without a class.
     $two_items = $single_item;
-    $two_items[] = $this->createBacktraceItem('test_function_two');
-    $data[] = [$two_items, $this->createBacktraceItem('test_function_two()')];
+    $two_items[] = self::createBacktraceItem('test_function_two');
+    $data[] = [$two_items, self::createBacktraceItem('test_function_two()')];
 
     // Add a second item, with a class.
     $two_items = $single_item;
-    $two_items[] = $this->createBacktraceItem('test_function_two', 'TestClass');
-    $data[] = [$two_items, $this->createBacktraceItem('TestClass->test_function_two()')];
+    $two_items[] = self::createBacktraceItem('test_function_two', 'TestClass');
+    $data[] = [$two_items, self::createBacktraceItem('TestClass->test_function_two()')];
 
     // Add ignored functions to backtrace. They should get removed.
     foreach (['debug', '_drupal_error_handler', '_drupal_exception_handler'] as $function) {
       $two_items = $single_item;
       // Push to the start of the backtrace.
-      array_unshift($two_items, $this->createBacktraceItem($function));
-      $data[] = [$single_item, $this->createBacktraceItem('main()')];
+      array_unshift($two_items, self::createBacktraceItem($function));
+      $data[] = [$single_item, self::createBacktraceItem('main()')];
     }
 
     return $data;
@@ -67,12 +67,12 @@ public function providerTestGetLastCaller() {
    *
    * @param array $backtrace
    *   The test backtrace array.
-   * @param array $expected
-   *   The expected return array.
+   * @param string $expected
+   *   The expected backtrace as a string.
    *
    * @dataProvider providerTestFormatBacktrace
    */
-  public function testFormatBacktrace($backtrace, $expected) {
+  public function testFormatBacktrace(array $backtrace, string $expected): void {
     $this->assertSame($expected, Error::formatBacktrace($backtrace));
   }
 
@@ -81,30 +81,30 @@ public function testFormatBacktrace($backtrace, $expected) {
    *
    * @return array
    */
-  public function providerTestFormatBacktrace() {
+  public static function providerTestFormatBacktrace(): array {
     $data = [];
 
     // Test with no function, main should be in the backtrace.
-    $data[] = [[$this->createBacktraceItem(NULL, NULL)], "main() (Line: 10)\n"];
+    $data[] = [[self::createBacktraceItem(NULL, NULL)], "main() (Line: 10)\n"];
 
-    $base = [$this->createBacktraceItem()];
+    $base = [self::createBacktraceItem()];
     $data[] = [$base, "test_function() (Line: 10)\n"];
 
     // Add a second item.
     $second_item = $base;
-    $second_item[] = $this->createBacktraceItem('test_function_2');
+    $second_item[] = self::createBacktraceItem('test_function_2');
 
     $data[] = [$second_item, "test_function() (Line: 10)\ntest_function_2() (Line: 10)\n"];
 
     // Add a second item, with a class.
     $second_item_class = $base;
-    $second_item_class[] = $this->createBacktraceItem('test_function_2', 'TestClass');
+    $second_item_class[] = self::createBacktraceItem('test_function_2', 'TestClass');
 
     $data[] = [$second_item_class, "test_function() (Line: 10)\nTestClass->test_function_2() (Line: 10)\n"];
 
     // Add a second item, with a class.
     $second_item_args = $base;
-    $second_item_args[] = $this->createBacktraceItem('test_function_2', NULL, ['string', 10, new \stdClass()]);
+    $second_item_args[] = self::createBacktraceItem('test_function_2', NULL, ['string', 10, new \stdClass()]);
 
     $data[] = [$second_item_args, "test_function() (Line: 10)\ntest_function_2('string', 10, Object) (Line: 10)\n"];
 
@@ -116,7 +116,7 @@ public function providerTestFormatBacktrace() {
    *
    * @param string|null $function
    *   (optional) The function name to use in the backtrace item.
-   * @param string $class
+   * @param string|null $class
    *   (optional) The class to use in the backtrace item.
    * @param array $args
    *   (optional) An array of function arguments to add to the backtrace item.
@@ -126,7 +126,7 @@ public function providerTestFormatBacktrace() {
    * @return array
    *   A backtrace array item.
    */
-  protected function createBacktraceItem($function = 'test_function', $class = NULL, array $args = [], $line = 10) {
+  protected static function createBacktraceItem(?string $function = 'test_function', ?string $class = NULL, array $args = [], int $line = 10): array {
     $backtrace = [
       'file' => 'test_file',
       'line' => $line,
diff --git a/web/core/tests/Drupal/Tests/Core/Validation/Plugin/Validation/Constraint/PrimitiveTypeConstraintValidatorTest.php b/web/core/tests/Drupal/Tests/Core/Validation/Plugin/Validation/Constraint/PrimitiveTypeConstraintValidatorTest.php
index 0bbf9c024e4c9ed735d924c87b337d4fb1a648c5..10e15a6b71244f6667826ef7761c7c8db361990e 100644
--- a/web/core/tests/Drupal/Tests/Core/Validation/Plugin/Validation/Constraint/PrimitiveTypeConstraintValidatorTest.php
+++ b/web/core/tests/Drupal/Tests/Core/Validation/Plugin/Validation/Constraint/PrimitiveTypeConstraintValidatorTest.php
@@ -28,7 +28,7 @@ class PrimitiveTypeConstraintValidatorTest extends UnitTestCase {
    *
    * @dataProvider provideTestValidate
    */
-  public function testValidate(PrimitiveInterface $typed_data, $value, $valid) {
+  public function testValidate(PrimitiveInterface $typed_data, string|TranslatableMarkup|int|float|array|null $value, bool $valid): void {
     $context = $this->createMock(ExecutionContextInterface::class);
     $context->expects($this->any())
       ->method('getObject')
@@ -50,7 +50,7 @@ public function testValidate(PrimitiveInterface $typed_data, $value, $valid) {
     $validate->validate($value, $constraint);
   }
 
-  public function provideTestValidate() {
+  public static function provideTestValidate(): array {
     $data = [];
     $data[] = [new BooleanData(DataDefinition::create('boolean')), NULL, TRUE];
 
diff --git a/web/core/tests/Drupal/Tests/PerformanceTestTrait.php b/web/core/tests/Drupal/Tests/PerformanceTestTrait.php
index 63a3a07cd731509a53b4b25ff28bdc3b3e9267d4..dbaa0508a032d005b8fd1dc1163fd721f1d604ea 100644
--- a/web/core/tests/Drupal/Tests/PerformanceTestTrait.php
+++ b/web/core/tests/Drupal/Tests/PerformanceTestTrait.php
@@ -318,7 +318,11 @@ private function openTelemetryTracing(array $messages, string $service_name): vo
       ResourceAttributes::DEPLOYMENT_ENVIRONMENT => 'local',
     ])));
 
-    $transport = (new OtlpHttpTransportFactory())->create($collector, 'application/x-protobuf');
+    $otel_collector_headers = getenv('OTEL_COLLECTOR_HEADERS') ?: [];
+    if ($otel_collector_headers) {
+      $otel_collector_headers = json_decode($otel_collector_headers, TRUE);
+    }
+    $transport = (new OtlpHttpTransportFactory())->create($collector, 'application/x-protobuf', $otel_collector_headers);
     $exporter = new SpanExporter($transport);
     $tracerProvider = new TracerProvider(new SimpleSpanProcessor($exporter), NULL, $resource);
     $tracer = $tracerProvider->getTracer('Drupal');
diff --git a/web/core/tests/Drupal/Tests/UnitTestCaseTest.php b/web/core/tests/Drupal/Tests/UnitTestCaseTest.php
index 4d5a7948a87742d7fabaa7acf13e2383a2438dd9..033923cf1c4b760f769a5ffeede977caa43da3ae 100644
--- a/web/core/tests/Drupal/Tests/UnitTestCaseTest.php
+++ b/web/core/tests/Drupal/Tests/UnitTestCaseTest.php
@@ -17,11 +17,11 @@ class UnitTestCaseTest extends UnitTestCase {
    * Tests the dump() function in a test run in the same process.
    */
   public function testVarDumpSameProcess() {
-    // Append the stream capturer to the STDOUT stream, so that we can test the
+    // Append the stream capturer to the STDERR stream, so that we can test the
     // dump() output and also prevent it from actually outputting in this
     // particular test.
     stream_filter_register("capture", StreamCapturer::class);
-    stream_filter_append(STDOUT, "capture");
+    stream_filter_append(STDERR, "capture");
 
     // Dump some variables.
     $object = (object) [
@@ -40,11 +40,11 @@ public function testVarDumpSameProcess() {
    * @runInSeparateProcess
    */
   public function testVarDumpSeparateProcess() {
-    // Append the stream capturer to the STDOUT stream, so that we can test the
+    // Append the stream capturer to the STDERR stream, so that we can test the
     // dump() output and also prevent it from actually outputting in this
     // particular test.
     stream_filter_register("capture", StreamCapturer::class);
-    stream_filter_append(STDOUT, "capture");
+    stream_filter_append(STDERR, "capture");
 
     // Dump some variables.
     $object = (object) [
diff --git a/web/core/themes/claro/css/base/variables.css b/web/core/themes/claro/css/base/variables.css
index 2f36f8bf7cc1fc4e8a00010cbc4175e08c57bd14..3b37b992cef1535ba966473eeb4f6413779b868b 100644
--- a/web/core/themes/claro/css/base/variables.css
+++ b/web/core/themes/claro/css/base/variables.css
@@ -254,4 +254,30 @@
    */
   --layout-region-edit-width: min(60rem, 100%);
   --layout-region-edit-extended-width: min(68rem, 100%);
+  /**
+   * Vertical Tabs.
+   *
+   * These are shared between the vertical tabs and media library.
+   * @see ../components/vertical-tabs.pcss.css
+   * @see ../theme/media-library.pcss.css
+   */
+  --vertical-tabs-margin-vertical: var(--space-s);
+  --vertical-tabs-border-radius: var(--details-accordion-border-size-radius);
+  --vertical-tabs-shadow: var(--details-box-shadow);
+  --vertical-tabs-border-color: var(--details-border-color);
+  --vertical-tabs-border-size: 1px;
+  --vertical-tabs-border: var(--vertical-tabs-border-size) solid var(--vertical-tabs-border-color);
+  --vertical-tabs-menu-item-shadow-extraspace: 0.5rem;
+  --vertical-tabs-menu-item--top-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -2);
+  --vertical-tabs-menu-item--right-margin: calc(var(--vertical-tabs-border-size) * -1);
+  --vertical-tabs-menu-item--bottom-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
+  --vertical-tabs-menu-item--left-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
+  --vertical-tabs-menu-separator-color: var(--color-gray-200);
+  --vertical-tabs-menu-separator-size: 1px;
+  --vertical-tabs-menu-width: 20em;
+  --vertical-tabs-pane-width: calc(100% - var(--vertical-tabs-menu-width));
+  --vertical-tabs-menu-link-focus-border-size: var(--details-summary-focus-border-size);
+  --vertical-tabs-menu-link--active-border-size: 0.25rem;
+  --vertical-tabs-menu-link--active-border-color: var(--color-absolutezero);
+  --vertical-tabs-menu--z-index: 0;
 }
diff --git a/web/core/themes/claro/css/base/variables.pcss.css b/web/core/themes/claro/css/base/variables.pcss.css
index 3b2cd3f646e332010030e8f74e100e867a9e8f24..0561a6665fefae2cebe29213634645fa2ca9cf5d 100644
--- a/web/core/themes/claro/css/base/variables.pcss.css
+++ b/web/core/themes/claro/css/base/variables.pcss.css
@@ -248,4 +248,30 @@
    */
   --layout-region-edit-width: min(960px, 100%);
   --layout-region-edit-extended-width: min(1088px, 100%);
+  /**
+   * Vertical Tabs.
+   *
+   * These are shared between the vertical tabs and media library.
+   * @see ../components/vertical-tabs.pcss.css
+   * @see ../theme/media-library.pcss.css
+   */
+  --vertical-tabs-margin-vertical: var(--space-s);
+  --vertical-tabs-border-radius: var(--details-accordion-border-size-radius);
+  --vertical-tabs-shadow: var(--details-box-shadow);
+  --vertical-tabs-border-color: var(--details-border-color);
+  --vertical-tabs-border-size: 1px;
+  --vertical-tabs-border: var(--vertical-tabs-border-size) solid var(--vertical-tabs-border-color);
+  --vertical-tabs-menu-item-shadow-extraspace: 0.5rem;
+  --vertical-tabs-menu-item--top-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -2);
+  --vertical-tabs-menu-item--right-margin: calc(var(--vertical-tabs-border-size) * -1);
+  --vertical-tabs-menu-item--bottom-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
+  --vertical-tabs-menu-item--left-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
+  --vertical-tabs-menu-separator-color: var(--color-gray-200);
+  --vertical-tabs-menu-separator-size: 1px;
+  --vertical-tabs-menu-width: 20em;
+  --vertical-tabs-pane-width: calc(100% - var(--vertical-tabs-menu-width));
+  --vertical-tabs-menu-link-focus-border-size: var(--details-summary-focus-border-size);
+  --vertical-tabs-menu-link--active-border-size: 4px;
+  --vertical-tabs-menu-link--active-border-color: var(--color-absolutezero);
+  --vertical-tabs-menu--z-index: 0;
 }
diff --git a/web/core/themes/claro/css/components/tableselect.css b/web/core/themes/claro/css/components/tableselect.css
index c26d82301f9f6412b539b14b17aa59ebd15ed3eb..0baa5b2c29d2e45cf83e446a4d58603e6a5f7189 100644
--- a/web/core/themes/claro/css/components/tableselect.css
+++ b/web/core/themes/claro/css/components/tableselect.css
@@ -134,5 +134,5 @@ tr.selected td {
 .position-sticky thead {
   position: sticky;
   z-index: 500;
-  top: var(--drupal-displace-offset-top);
+  top: var(--drupal-displace-offset-top, 0);
 }
diff --git a/web/core/themes/claro/css/components/tableselect.pcss.css b/web/core/themes/claro/css/components/tableselect.pcss.css
index 015280fd1f3599465e01c79154efa0e251196775..6d5bce7b010254c3fe42c1678b7a81734fc0d4fc 100644
--- a/web/core/themes/claro/css/components/tableselect.pcss.css
+++ b/web/core/themes/claro/css/components/tableselect.pcss.css
@@ -120,5 +120,5 @@ tr.selected td {
 .position-sticky thead {
   position: sticky;
   z-index: 500;
-  top: var(--drupal-displace-offset-top);
+  top: var(--drupal-displace-offset-top, 0);
 }
diff --git a/web/core/themes/claro/css/components/vertical-tabs.css b/web/core/themes/claro/css/components/vertical-tabs.css
index f00e953cbb091413e5b2a5b050e33cb84ba278b5..2fded23efd8df00217799b084eacd87ba931918e 100644
--- a/web/core/themes/claro/css/components/vertical-tabs.css
+++ b/web/core/themes/claro/css/components/vertical-tabs.css
@@ -12,31 +12,6 @@
  * Replaces /core/misc/vertical-tabs.css.
  */
 
-:root {
-  /**
-   * Vertical Tabs.
-   */
-  --vertical-tabs-margin-vertical: var(--space-s);
-  --vertical-tabs-border-radius: var(--details-accordion-border-size-radius);
-  --vertical-tabs-shadow: var(--details-box-shadow);
-  --vertical-tabs-border-color: var(--details-border-color);
-  --vertical-tabs-border-size: 1px;
-  --vertical-tabs-border: var(--vertical-tabs-border-size) solid var(--vertical-tabs-border-color);
-  --vertical-tabs-menu-item-shadow-extraspace: 0.5rem;
-  --vertical-tabs-menu-item--top-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -2);
-  --vertical-tabs-menu-item--right-margin: calc(var(--vertical-tabs-border-size) * -1);
-  --vertical-tabs-menu-item--bottom-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
-  --vertical-tabs-menu-item--left-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
-  --vertical-tabs-menu-separator-color: var(--color-gray-200);
-  --vertical-tabs-menu-separator-size: 1px;
-  --vertical-tabs-menu-width: 20em;
-  --vertical-tabs-pane-width: calc(100% - var(--vertical-tabs-menu-width));
-  --vertical-tabs-menu-link-focus-border-size: var(--details-summary-focus-border-size);
-  --vertical-tabs-menu-link--active-border-size: 0.25rem;
-  --vertical-tabs-menu-link--active-border-color: var(--color-absolutezero);
-  --vertical-tabs-menu--z-index: 0;
-}
-
 /**
  * Main wrapper of vertical tabs.
  * This wrapper div is added by JavaScript.
@@ -218,6 +193,12 @@
   border-end-start-radius: var(--base-border-radius);
 }
 
+@media (forced-colors: active) {
+  .vertical-tabs__menu-item.is-selected .vertical-tabs__menu-link::before {
+    border-inline-start: var(--vertical-tabs-menu-link--active-border-size) solid canvastext;
+  }
+}
+
 .vertical-tabs__menu-item.is-selected .vertical-tabs__menu-link:hover::before {
   background: none;
 }
diff --git a/web/core/themes/claro/css/components/vertical-tabs.pcss.css b/web/core/themes/claro/css/components/vertical-tabs.pcss.css
index c85061f70b88a0fdbfb0a09c5b3c32825bafdf99..fbc0002f8a317e6e97de3861bf3da72f7df32659 100644
--- a/web/core/themes/claro/css/components/vertical-tabs.pcss.css
+++ b/web/core/themes/claro/css/components/vertical-tabs.pcss.css
@@ -5,31 +5,6 @@
  * Replaces /core/misc/vertical-tabs.css.
  */
 
-:root {
-  /**
-   * Vertical Tabs.
-   */
-  --vertical-tabs-margin-vertical: var(--space-s);
-  --vertical-tabs-border-radius: var(--details-accordion-border-size-radius);
-  --vertical-tabs-shadow: var(--details-box-shadow);
-  --vertical-tabs-border-color: var(--details-border-color);
-  --vertical-tabs-border-size: 1px;
-  --vertical-tabs-border: var(--vertical-tabs-border-size) solid var(--vertical-tabs-border-color);
-  --vertical-tabs-menu-item-shadow-extraspace: 0.5rem;
-  --vertical-tabs-menu-item--top-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -2);
-  --vertical-tabs-menu-item--right-margin: calc(var(--vertical-tabs-border-size) * -1);
-  --vertical-tabs-menu-item--bottom-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
-  --vertical-tabs-menu-item--left-margin: calc(var(--vertical-tabs-menu-item-shadow-extraspace) * -1);
-  --vertical-tabs-menu-separator-color: var(--color-gray-200);
-  --vertical-tabs-menu-separator-size: 1px;
-  --vertical-tabs-menu-width: 20em;
-  --vertical-tabs-pane-width: calc(100% - var(--vertical-tabs-menu-width));
-  --vertical-tabs-menu-link-focus-border-size: var(--details-summary-focus-border-size);
-  --vertical-tabs-menu-link--active-border-size: 4px;
-  --vertical-tabs-menu-link--active-border-color: var(--color-absolutezero);
-  --vertical-tabs-menu--z-index: 0;
-}
-
 /**
  * Main wrapper of vertical tabs.
  * This wrapper div is added by JavaScript.
@@ -195,6 +170,10 @@
   border-start-end-radius: 0;
   border-end-end-radius: 0;
   border-end-start-radius: var(--base-border-radius);
+
+  @media (forced-colors: active) {
+    border-inline-start: var(--vertical-tabs-menu-link--active-border-size) solid canvastext;
+  }
 }
 
 .vertical-tabs__menu-item.is-selected .vertical-tabs__menu-link:hover::before {
diff --git a/web/core/themes/claro/css/theme/views_ui.admin.theme.css b/web/core/themes/claro/css/theme/views_ui.admin.theme.css
index 1dbca86662747150b7e405a7cecf673a5d6c29e5..50cbeabd2c4174fd191e79b496aaf44aca5e5b2e 100644
--- a/web/core/themes/claro/css/theme/views_ui.admin.theme.css
+++ b/web/core/themes/claro/css/theme/views_ui.admin.theme.css
@@ -520,6 +520,14 @@ td.group-title {
   margin-bottom: 0.9375rem;
 }
 
+.views-edit-view.disabled .views-displays {
+  background-color: var(--color-red-020);
+}
+
+.views-edit-view.disabled .views-display-column {
+  background: var(--color-white);
+}
+
 /* The contents of the popup dialog on the views edit form. */
 
 .views-filterable-options .form-type-checkbox {
diff --git a/web/core/themes/claro/css/theme/views_ui.admin.theme.pcss.css b/web/core/themes/claro/css/theme/views_ui.admin.theme.pcss.css
index 82c89cc3240590d6c92e7891ada8ca1ac5afe193..80372bfd15937cd9cf5a5433d43030f778a8fab2 100644
--- a/web/core/themes/claro/css/theme/views_ui.admin.theme.pcss.css
+++ b/web/core/themes/claro/css/theme/views_ui.admin.theme.pcss.css
@@ -412,7 +412,12 @@ td.group-title {
 .views-edit-view {
   margin-bottom: 15px;
 }
-
+.views-edit-view.disabled .views-displays {
+  background-color: var(--color-red-020);
+}
+.views-edit-view.disabled .views-display-column {
+  background: var(--color-white);
+}
 /* The contents of the popup dialog on the views edit form. */
 .views-filterable-options .form-type-checkbox {
   padding: 5px 8px;
diff --git a/web/core/themes/claro/templates/navigation/menu-local-task.html.twig b/web/core/themes/claro/templates/navigation/menu-local-task.html.twig
index f74c56ae5e549dec3b9c66fa1d710ffe9bf28cef..b135a5ddcf3b5d04d5c353c7dfcd8dec2c346e68 100644
--- a/web/core/themes/claro/templates/navigation/menu-local-task.html.twig
+++ b/web/core/themes/claro/templates/navigation/menu-local-task.html.twig
@@ -26,7 +26,7 @@
 <li{{ attributes.addClass(classes) }}>
   {{ link }}
   {% if is_active and level == 'primary' %}
-    <button class="reset-appearance tabs__trigger" aria-label="{{ 'Tabs display toggle'|t }}" data-drupal-nav-tabs-trigger>
+    <button class="reset-appearance tabs__trigger" type="button" aria-label="{{ 'Tabs display toggle'|t }}" data-drupal-nav-tabs-trigger>
       {% include "@claro/../images/src/hamburger-menu.svg" %}
     </button>
   {% endif %}
diff --git a/web/core/themes/claro/tests/src/Functional/NodeTitleTest.php b/web/core/themes/claro/tests/src/Functional/NodeTitleTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..a97827f779da486460172c72bc4c8c4cd252fb10
--- /dev/null
+++ b/web/core/themes/claro/tests/src/Functional/NodeTitleTest.php
@@ -0,0 +1,16 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\claro\Functional;
+
+use Drupal\Tests\system\Functional\Theme\NodeTitleTestBase;
+
+/**
+ * Tests node title for claro.
+ *
+ * @group node
+ */
+class NodeTitleTest extends NodeTitleTestBase {
+
+}
diff --git a/web/core/themes/olivero/css/components/wide-content.css b/web/core/themes/olivero/css/components/wide-content.css
index 6a999a6905b038a215099eac54ec54a7fc81eb5d..ec527f1a11d910da9e39649f43358d38f37312e3 100644
--- a/web/core/themes/olivero/css/components/wide-content.css
+++ b/web/core/themes/olivero/css/components/wide-content.css
@@ -52,8 +52,8 @@
 
 /* Ensure that image doesn't overlap layout builder sections when editing layouts. */
 
-.layout-builder .wide-content {
+.layout-builder .wide-content,
+.region--hero .wide-content {
   max-width: 100%;
-  margin-inline-start: 0;
-  margin-inline-end: 0;
+  margin-inline: 0;
 }
diff --git a/web/core/themes/olivero/css/components/wide-content.pcss.css b/web/core/themes/olivero/css/components/wide-content.pcss.css
index f9c6e0345a23a535b26b87759dfc79adea5a4d4a..4eb6008dd72447be51c637c7657d68fc96989a3e 100644
--- a/web/core/themes/olivero/css/components/wide-content.pcss.css
+++ b/web/core/themes/olivero/css/components/wide-content.pcss.css
@@ -39,8 +39,8 @@
 }
 
 /* Ensure that image doesn't overlap layout builder sections when editing layouts. */
-.layout-builder .wide-content {
+.layout-builder .wide-content,
+.region--hero .wide-content {
   max-width: 100%;
-  margin-inline-start: 0;
-  margin-inline-end: 0;
+  margin-inline: 0;
 }
diff --git a/web/core/themes/olivero/css/layout/region-hero.css b/web/core/themes/olivero/css/layout/region-hero.css
index f739ad92bbf682882bb09d4e628ae06c7c9dfff8..d3c5598944fccda190e5e0be91fcff75d921aaf8 100644
--- a/web/core/themes/olivero/css/layout/region-hero.css
+++ b/web/core/themes/olivero/css/layout/region-hero.css
@@ -13,3 +13,8 @@
 .region--hero > *:last-child {
   margin-block-end: 0;
 }
+
+.region--hero .wide-content {
+  max-width: 100%;
+  margin-inline: 0;
+}
diff --git a/web/core/themes/olivero/css/layout/region-hero.pcss.css b/web/core/themes/olivero/css/layout/region-hero.pcss.css
index 4e2526a39358c6a28fc650a6e7b4c9b8f1013556..310a37567f1a5f69b9c29d02d07e1acabc264fd6 100644
--- a/web/core/themes/olivero/css/layout/region-hero.pcss.css
+++ b/web/core/themes/olivero/css/layout/region-hero.pcss.css
@@ -9,4 +9,9 @@
   & > *:last-child {
     margin-block-end: 0;
   }
+
+  .wide-content {
+    max-width: 100%;
+    margin-inline: 0;
+  }
 }
diff --git a/web/core/themes/olivero/js/messages.js b/web/core/themes/olivero/js/messages.js
index 942e7ca4088759731404dfdf986fe9efcfc0a72c..3b34f3eb95c0479f353ca3c3d4227262855da6c0 100644
--- a/web/core/themes/olivero/js/messages.js
+++ b/web/core/themes/olivero/js/messages.js
@@ -14,25 +14,26 @@
     const messageContainer = message.querySelector(
       '[data-drupal-selector="messages-container"]',
     );
-
-    const closeBtnWrapper = document.createElement('div');
-    closeBtnWrapper.setAttribute('class', 'messages__button');
-
-    const closeBtn = document.createElement('button');
-    closeBtn.setAttribute('type', 'button');
-    closeBtn.setAttribute('class', 'messages__close');
-
-    const closeBtnText = document.createElement('span');
-    closeBtnText.setAttribute('class', 'visually-hidden');
-    closeBtnText.innerText = Drupal.t('Close message');
-
-    messageContainer.appendChild(closeBtnWrapper);
-    closeBtnWrapper.appendChild(closeBtn);
-    closeBtn.appendChild(closeBtnText);
-
-    closeBtn.addEventListener('click', () => {
-      message.classList.add('hidden');
-    });
+    if (!messageContainer.querySelector('.messages__button')) {
+      const closeBtnWrapper = document.createElement('div');
+      closeBtnWrapper.setAttribute('class', 'messages__button');
+
+      const closeBtn = document.createElement('button');
+      closeBtn.setAttribute('type', 'button');
+      closeBtn.setAttribute('class', 'messages__close');
+
+      const closeBtnText = document.createElement('span');
+      closeBtnText.setAttribute('class', 'visually-hidden');
+      closeBtnText.innerText = Drupal.t('Close message');
+
+      messageContainer.appendChild(closeBtnWrapper);
+      closeBtnWrapper.appendChild(closeBtn);
+      closeBtn.appendChild(closeBtnText);
+
+      closeBtn.addEventListener('click', () => {
+        message.classList.add('hidden');
+      });
+    }
   };
 
   /**
diff --git a/web/core/themes/olivero/templates/content/page-title.html.twig b/web/core/themes/olivero/templates/content/page-title.html.twig
index 37296e7e72491fdafe7ea0e05c126a9962231231..d95cde8436267748f5606b8d6e472ac257800faa 100644
--- a/web/core/themes/olivero/templates/content/page-title.html.twig
+++ b/web/core/themes/olivero/templates/content/page-title.html.twig
@@ -20,7 +20,7 @@
 %}
 
 {{ title_prefix }}
-{% if title|render|striptags|trim %}
+{% if (title|render|striptags|trim is not empty) %}
   <h1{{ title_attributes.addClass(classes) }}>{{ title }}</h1>
 {% endif %}
 {{ title_suffix }}
diff --git a/web/core/themes/olivero/tests/src/Functional/NodeTitleTest.php b/web/core/themes/olivero/tests/src/Functional/NodeTitleTest.php
new file mode 100644
index 0000000000000000000000000000000000000000..d0c7d88b1b7b1389ae5d566ed694d1323ae76faf
--- /dev/null
+++ b/web/core/themes/olivero/tests/src/Functional/NodeTitleTest.php
@@ -0,0 +1,16 @@
+<?php
+
+declare(strict_types=1);
+
+namespace Drupal\Tests\olivero\Functional;
+
+use Drupal\Tests\system\Functional\Theme\NodeTitleTestBase;
+
+/**
+ * Tests node title for olivero.
+ *
+ * @group node
+ */
+class NodeTitleTest extends NodeTitleTestBase {
+
+}
diff --git a/web/core/themes/stable9/css/views_ui/views_ui.admin.theme.css b/web/core/themes/stable9/css/views_ui/views_ui.admin.theme.css
index c510ed45844ee16ca9967fe605bb6ee111d97847..993229e26e77ea5b1109eb9a0615fab85d28e5c8 100644
--- a/web/core/themes/stable9/css/views_ui/views_ui.admin.theme.css
+++ b/web/core/themes/stable9/css/views_ui/views_ui.admin.theme.css
@@ -568,7 +568,12 @@ td.group-title {
 .views-edit-view {
   margin-bottom: 15px;
 }
-
+.views-edit-view.disabled .views-displays {
+  background-color: #fff4f4;
+}
+.views-edit-view.disabled .views-display-column {
+  background: white;
+}
 /* The contents of the popup dialog on the views edit form. */
 .views-filterable-options .form-type-checkbox {
   padding: 5px 8px;