From 21187f202460cb45bdd0246f81bd09f29ffc8e2b Mon Sep 17 00:00:00 2001 From: "lee.5151" <lee.5151@osu.edu> Date: Thu, 11 Apr 2024 10:45:11 -0400 Subject: [PATCH] Upgrading drupal/core-recommended (10.2.3 => 10.2.5) --- .gitattributes | 3 + composer.json | 4 +- composer.lock | 32 +- vendor/composer/autoload_classmap.php | 3 + vendor/composer/autoload_static.php | 3 + vendor/composer/installed.json | 36 +- vendor/composer/installed.php | 68 +- web/core/.cspell.json | 3 +- web/core/.phpstan-baseline.php | 3446 ++++++++++++++++ web/core/MAINTAINERS.txt | 1 + web/core/assets/scaffold/files/gitattributes | 3 + web/core/includes/form.inc | 1 - web/core/includes/install.inc | 2 +- web/core/lib/Drupal.php | 2 +- .../Doctrine/StaticReflectionParser.php | 10 +- .../Drupal/Component/Plugin/PluginBase.php | 2 +- .../Plugin/PluginInspectionInterface.php | 2 +- .../lib/Drupal/Core/Block/Attribute/Block.php | 2 +- .../ConfigExistsConstraintValidator.php | 5 + .../lib/Drupal/Core/Database/Connection.php | 25 + .../lib/Drupal/Core/Database/Database.php | 54 +- .../Core/Database/Query/SelectInterface.php | 2 +- .../lib/Drupal/Core/Database/Transaction.php | 5 + .../Transaction/TransactionManagerBase.php | 15 +- .../Drupal/Core/Datetime/DrupalDateTime.php | 13 +- .../FieldWidget/TimestampDatetimeWidget.php | 3 +- .../Compiler/RegisterStreamWrappersPass.php | 15 +- .../lib/Drupal/Core/Entity/EntityBase.php | 30 +- .../Drupal/Core/Entity/EntityTypeManager.php | 6 +- .../DefaultSelection.php | 6 + .../Drupal/Core/Entity/Query/QueryBase.php | 4 +- .../RssResponseRelativeUrlFilter.php | 10 +- .../Drupal/Core/Extension/DatabaseDriver.php | 7 +- .../ExtensionExistsConstraintValidator.php | 14 + .../lib/Drupal/Core/Field/FormatterBase.php | 12 +- .../Field/FieldType/EntityReferenceItem.php | 6 +- web/core/lib/Drupal/Core/Form/FormBuilder.php | 8 +- .../Core/Queue/QueueDatabaseFactory.php | 14 +- .../Core/Queue/QueueFactoryInterface.php | 21 + web/core/lib/Drupal/Core/Render/Renderer.php | 9 +- .../PluralTranslatableMarkup.php | 19 +- .../Core/Test/FunctionalTestSetupTrait.php | 3 +- .../Constraint/UniqueFieldValueValidator.php | 22 +- web/core/misc/cspell/dictionary.txt | 5 - web/core/misc/cspell/drupal-dictionary.txt | 3 + web/core/misc/details-aria.js | 1 - web/core/misc/details.js | 13 + web/core/misc/drupal.js | 8 +- web/core/misc/form.js | 10 +- web/core/misc/states.js | 15 +- web/core/misc/tableheader.js | 2 +- web/core/modules/big_pipe/js/big_pipe.js | 7 +- .../tests/src/Functional/BigPipeTest.php | 40 +- web/core/modules/block/js/block.js | 2 +- .../DisplayVariant/BlockPageVariantTest.php | 10 +- .../block_content/src/BlockContentForm.php | 28 +- .../src/Plugin/Derivative/BlockContent.php | 2 +- .../Functional/BlockContentCreationTest.php | 37 +- .../src/Kernel/BlockContentDeriverTest.php | 57 + .../src/Functional/BookBreadcrumbTest.php | 2 +- .../tests/src/Functional/BookTestTrait.php | 2 +- web/core/modules/ckeditor5/css/editor.css | 5 + .../ckeditor5/css/essentials.admin.css | 7 + .../modules/ckeditor5/css/language.admin.css | 6 + .../modules/ckeditor5/css/style.admin.css | 6 + .../modules/ckeditor5/js/build/drupalImage.js | 2 +- web/core/modules/ckeditor5/js/ckeditor5.js | 25 +- .../ui/imagealternativetextformview.js | 2 +- .../FunctionalJavascript/CKEditor5Test.php | 78 + web/core/modules/comment/src/CommentForm.php | 4 +- .../comment/src/CommentLazyBuilders.php | 4 +- .../src/Functional/CommentInterfaceTest.php | 11 + .../src/Functional/CommentThreadingTest.php | 10 +- .../Rest/CommentResourceTestBase.php | 3 + .../src/Functional/ConfigEntityListTest.php | 2 +- ...figInstallProfileUnmetDependenciesTest.php | 2 +- .../ConfigImportSubscriber.php | 3 +- .../views/filter/ModerationStateFilter.php | 5 +- ...ation_filter_via_revision_relationship.yml | 351 ++ .../content_moderation_test_views.module | 23 + .../src/Functional/ModerationFormTest.php | 4 +- .../ViewsModerationStateFilterTest.php | 2 +- .../Kernel/ViewsModerationStateFilterTest.php | 28 + .../content_translation.admin.js | 7 +- .../ContentTranslationUITestBase.php | 3 +- .../ContentTranslationConfigUITest.php | 47 + .../src/Functional/Views/FilterDateTest.php | 27 +- web/core/modules/field/field.module | 3 + .../src/Functional/Number/NumberFieldTest.php | 2 +- .../EntityReferenceItemTest.php | 11 + .../field_ui/src/Form/FieldConfigEditForm.php | 2 +- .../src/Functional/ManageDisplayTest.php | 2 +- .../FunctionalJavascript/ManageFieldsTest.php | 1 + web/core/modules/file/file.api.php | 17 +- web/core/modules/file/file.module | 2 + .../file/src/Upload/FileUploadHandler.php | 50 +- .../file/src/Validation/FileValidator.php | 3 + .../tests/file_test/file_test.services.yml | 5 + .../DummyMultipleStreamWrapper.php | 10 + .../Functional/FileOnTranslatedEntityTest.php | 2 +- .../PrivateFileOnTranslatedEntityTest.php | 45 +- .../FileFieldWidgetClaroThemeTest.php | 1 + .../tests/src/Kernel/FileSaveUploadTest.php | 70 + .../tests/src/Kernel/LegacyValidatorTest.php | 3 + web/core/modules/forum/forum.routing.yml | 1 + web/core/modules/forum/src/ForumManager.php | 3 + .../src/Functional/ForumTermAccessTest.php | 93 + web/core/modules/image/image.admin.inc | 7 +- web/core/modules/image/image.module | 14 + .../ImageStyleDownloadController.php | 6 + .../src/Functional/ImageAdminStylesTest.php | 34 + .../src/Functional/ImageDimensionsTest.php | 2 +- .../src/Functional/ImageFieldDisplayTest.php | 20 +- .../tests/src/Functional/BlockContentTest.php | 2 +- .../EntityTestComputedFieldTest.php | 3 +- .../src/Functional/EntityTestMapFieldTest.php | 2 +- .../tests/src/Functional/EntityTestTest.php | 2 +- .../JsonApiFunctionalDateFieldTest.php | 6 +- .../tests/src/Functional/MediaTest.php | 2 +- .../src/Functional/MenuLinkContentTest.php | 2 +- .../tests/src/Functional/ResourceTestBase.php | 4 +- .../jsonapi/tests/src/Functional/TermTest.php | 2 +- web/core/modules/language/language.module | 27 +- ...guageConfigInstallOverrideExistingTest.php | 42 + .../Unit/ContentLanguageSettingsUnitTest.php | 2 +- .../LanguageNegotiationContentEntityTest.php | 4 +- .../src/Plugin/Block/FieldBlock.php | 38 +- .../Plugin/Layout/MultiWidthLayoutBase.php | 3 - .../LayoutBuilderDefaultValuesTest.php | 119 +- .../tests/src/Kernel/EntityViewAlterTest.php | 64 + web/core/modules/locale/locale.install | 6 + .../src/Functional/LocaleInstallTest.php | 47 + .../src/Functional/LocalePluralFormatTest.php | 2 +- .../src/Kernel/LocaleConfigSubscriberTest.php | 5 +- .../modules/media/src/OEmbed/UrlResolver.php | 2 +- .../src/Functional/MediaOverviewPageTest.php | 6 + .../Functional/Rest/MediaResourceTestBase.php | 3 + .../tests/src/Functional/UrlResolverTest.php | 8 +- .../src/Unit/MediaLibrarySelectFormTest.php | 12 +- .../src/Form/MenuLinkContentForm.php | 7 +- .../tests/src/Kernel/MenuLinksTest.php | 16 + .../tests/src/Functional/MenuUiTest.php | 10 +- .../migrate/src/Plugin/migrate/id_map/Sql.php | 15 +- .../tests/src/Unit/MigrateSqlIdMapTest.php | 40 +- .../modules/node/migrations/d6_node_type.yml | 20 +- .../modules/node/migrations/d7_node_type.yml | 20 +- web/core/modules/node/src/NodeViewBuilder.php | 4 +- .../src/Functional/NodeRevisionsAllTest.php | 3 - .../src/Functional/NodeRevisionsTest.php | 3 - .../Functional/Rest/NodeResourceTestBase.php | 3 + .../Kernel/Migrate/d6/MigrateNodeTypeTest.php | 12 +- .../Kernel/Migrate/d7/MigrateNodeTypeTest.php | 12 +- .../ResponsiveImageFieldDisplayTest.php | 4 +- ...sponsiveImageStyleConfigEntityUnitTest.php | 2 +- .../Functional/CookieResourceTestTrait.php | 4 - .../tests/src/Functional/ResourceTest.php | 1 + .../rest/tests/src/Unit/CollectRoutesTest.php | 6 +- .../EntityResourceValidationTraitTest.php | 1 - .../SearchMultilingualEntityTest.php | 2 +- .../src/Functional/ShortcutLinksTest.php | 2 +- .../system/src/PathBasedBreadcrumbBuilder.php | 14 +- .../src/Entity/EntityTestComputedField.php | 11 + .../ComputedTestCacheableIntegerItemList.php | 36 + .../ComputedTestCacheableStringItemList.php | 4 + .../EntityTestComputedFieldNormalizerTest.php | 6 + .../modules/form_test/form_test.routing.yml | 9 + ...stDetailsContainsRequiredTextfieldForm.php | 64 + .../src/Form/JavascriptStatesForm.php | 173 + .../Entity/EntityComputedFieldTest.php | 76 + .../src/Functional/Form/CheckboxTest.php | 5 +- .../tests/src/Functional/Form/StorageTest.php | 1 + .../src/Functional/Form/ValidationTest.php | 1 + .../src/Functional/Menu/MenuRouterTest.php | 4 +- .../System/SitesDirectoryHardeningTest.php | 2 +- .../Functional/Theme/NodeTitleTestBase.php | 78 + .../Functional/Theme/TwigDebugMarkupTest.php | 8 +- .../src/Functional/Theme/TwigTransTest.php | 2 +- .../FunctionalJavascript/ModuleFilterTest.php | 1 + .../System/DateFormatTest.php | 4 +- .../Kernel/Extension/ModuleHandlerTest.php | 2 + .../taxonomy/migrations/d6_taxonomy_term.yml | 3 +- .../taxonomy/migrations/d7_taxonomy_term.yml | 3 +- .../src/Functional/TelephoneFieldTest.php | 2 +- .../toolbar/js/toolbar.anti-flicker.js | 2 +- .../tests/src/Functional/TourTestBase.php | 3 +- .../tests/src/Functional/TrackerTest.php | 14 +- .../UpdateSemverTestBaselineTrait.php | 4 +- .../UserSelection.php | 3 + .../src/Functional/UserLoginHttpTest.php | 22 +- .../Views/HandlerFieldUserNameTest.php | 8 +- .../src/Unit/Views/Argument/RolesRidTest.php | 2 +- web/core/modules/views/js/base.js | 2 +- .../Plugin/views/cache/CachePluginBase.php | 2 +- .../views/display/DisplayPluginBase.php | 2 +- .../views/src/Plugin/views/filter/Combine.php | 3 +- .../src/Plugin/views/filter/NumericFilter.php | 19 +- web/core/modules/views/src/ViewExecutable.php | 11 - ...w.test_argument_default_node_with_page.yml | 243 ++ .../tests/src/Functional/Handler/AreaTest.php | 2 +- .../src/Functional/Handler/FieldWebTest.php | 87 +- .../Functional/Plugin/ArgumentDefaultTest.php | 30 + .../Functional/Plugin/DisplayPageWebTest.php | 8 +- .../src/Functional/Plugin/DisplayTest.php | 22 +- .../tests/src/Functional/Plugin/PagerTest.php | 2 +- .../src/Kernel/Handler/FilterCombineTest.php | 59 + .../Controller/ViewAjaxControllerTest.php | 2 +- .../Unit/Plugin/field/FieldPluginBaseTest.php | 13 +- .../Plugin/views/filter/NumericFilterTest.php | 118 + .../views_ui/css/views_ui.admin.theme.css | 7 +- web/core/modules/views_ui/js/ajax.js | 2 +- web/core/modules/views_ui/js/views-admin.js | 2 +- .../src/Functional/OverrideDisplaysTest.php | 1 + .../workspaces/css/workspaces.off-canvas.css | 6 + .../css/workspaces.off-canvas.pcss.css | 6 + .../workspaces/src/WorkspaceListBuilder.php | 5 +- .../tests/src/Functional/WorkspaceTest.php | 10 + web/core/package.json | 3 +- web/core/phpcs.xml.dist | 2 + web/core/phpstan-baseline.neon | 3623 ----------------- web/core/phpstan.neon.dist | 2 +- .../src/Functional/DemoUmamiProfileTest.php | 14 +- ...ntity_view_display.node.article.teaser.yml | 2 - .../config/install/language.types.yml | 39 + .../test_language_negotiation.info.yml | 7 + web/core/scripts/dev/commit-code-check.sh | 4 +- .../Core/Form/FormGroupingElementsTest.php | 50 +- .../Core/Form/JavascriptStatesTest.php | 102 + .../MachineNameTransliterationTest.php | 1 + .../FunctionalTests/BrowserTestBaseTest.php | 26 +- .../Datetime/TimestampTest.php | 19 + .../KernelTests/Config/DefaultConfigTest.php | 6 +- .../ConfigExistsConstraintValidatorTest.php | 4 + .../DriverSpecificTransactionTestBase.php | 33 +- .../Core/Entity/ConfigEntityQueryTest.php | 34 + ...ExtensionExistsConstraintValidatorTest.php | 22 +- .../Installer/InstallerRedirectTraitTest.php | 13 +- .../UniqueValuesConstraintValidatorTest.php | 38 + ...SystemModuleDiscoveryDataProviderTrait.php | 2 +- .../Drupal/KernelTests/KernelTestBaseTest.php | 4 +- .../tests/Drupal/TestTools/TestVarDumper.php | 4 +- .../Fixtures/Attribute/Nonexistent.php | 9 + .../ExtraAttributes/ExampleAttribute.php | 2 +- .../ExampleParentAttribute.php | 8 + .../Doctrine/StaticReflectionParserTest.php | 13 +- .../Component/Plugin/Context/ContextTest.php | 12 +- .../Discovery/DiscoveryCachedTraitTest.php | 19 +- .../Plugin/Discovery/DiscoveryTraitTest.php | 32 +- .../StaticDiscoveryDecoratorTest.php | 61 +- .../Plugin/PluginManagerBaseTest.php | 4 +- .../Tests/Component/Utility/UrlHelperTest.php | 28 +- .../Plugin/ProjectMessage/ConfigTest.php | 8 +- .../Functional/ManageGitIgnoreTest.php | 2 +- .../Plugin/VendorHardening/ConfigTest.php | 12 +- .../VendorHardeningPluginTest.php | 3 +- .../Entity/EntityDisplayModeBaseUnitTest.php | 13 +- .../Tests/Core/Database/ConnectionTest.php | 11 + .../Drupal/Tests/Core/Datetime/DateTest.php | 172 +- .../Core/Datetime/DrupalDateTimeTest.php | 19 + .../Core/DrupalKernel/DrupalKernelTest.php | 4 +- .../Core/Entity/BaseFieldDefinitionTest.php | 10 +- .../Core/Entity/ContentEntityBaseUnitTest.php | 4 +- .../Core/Entity/EntityStorageBaseTest.php | 8 +- .../Core/Entity/EntityTypeManagerTest.php | 42 +- .../Tests/Core/Entity/EntityUnitTest.php | 8 +- .../Tests/Core/Entity/EntityUrlTest.php | 36 +- .../TypedData/EntityAdapterUnitTest.php | 2 +- .../Tests/Core/Error/DrupalLogErrorTest.php | 8 +- .../RssResponseRelativeUrlFilterTest.php | 4 +- .../Core/Extension/InfoParserUnitTest.php | 160 +- .../Tests/Core/Field/FieldItemListTest.php | 53 +- .../Core/Form/ConfigFormBaseTraitTest.php | 12 +- .../Tests/Core/Form/FormBuilderTest.php | 26 +- .../Tests/Core/Form/FormValidatorTest.php | 5 +- .../Drupal/Tests/Core/Image/ImageTest.php | 2 +- .../Tests/Core/Logger/LoggerChannelTest.php | 3 +- .../Plugin/Context/ContextDefinitionTest.php | 13 +- .../Tests/Core/Plugin/Context/ContextTest.php | 8 +- .../Routing/ContentTypeHeaderMatcherTest.php | 4 +- .../NegotiationMiddlewareTest.php | 14 +- .../PluralTranslatableMarkupTest.php | 8 + .../StringTranslationTraitTest.php | 52 +- .../Tests/Core/Test/TestSetupTraitTest.php | 6 +- .../Drupal/Tests/Core/Utility/ErrorTest.php | 42 +- .../PrimitiveTypeConstraintValidatorTest.php | 4 +- .../Drupal/Tests/PerformanceTestTrait.php | 6 +- .../tests/Drupal/Tests/UnitTestCaseTest.php | 8 +- web/core/themes/claro/css/base/variables.css | 26 + .../themes/claro/css/base/variables.pcss.css | 26 + .../claro/css/components/tableselect.css | 2 +- .../claro/css/components/tableselect.pcss.css | 2 +- .../claro/css/components/vertical-tabs.css | 31 +- .../css/components/vertical-tabs.pcss.css | 29 +- .../claro/css/theme/views_ui.admin.theme.css | 8 + .../css/theme/views_ui.admin.theme.pcss.css | 7 +- .../navigation/menu-local-task.html.twig | 2 +- .../tests/src/Functional/NodeTitleTest.php | 16 + .../olivero/css/components/wide-content.css | 6 +- .../css/components/wide-content.pcss.css | 6 +- .../themes/olivero/css/layout/region-hero.css | 5 + .../olivero/css/layout/region-hero.pcss.css | 5 + web/core/themes/olivero/js/messages.js | 39 +- .../templates/content/page-title.html.twig | 2 +- .../tests/src/Functional/NodeTitleTest.php | 16 + .../css/views_ui/views_ui.admin.theme.css | 7 +- 304 files changed, 7610 insertions(+), 4763 deletions(-) create mode 100644 web/core/.phpstan-baseline.php create mode 100644 web/core/lib/Drupal/Core/Queue/QueueFactoryInterface.php create mode 100644 web/core/modules/content_moderation/tests/modules/content_moderation_test_views/config/install/views.view.test_content_moderation_filter_via_revision_relationship.yml create mode 100644 web/core/modules/content_translation/tests/src/FunctionalJavascript/ContentTranslationConfigUITest.php create mode 100644 web/core/modules/file/tests/file_test/src/StreamWrapper/DummyMultipleStreamWrapper.php create mode 100644 web/core/modules/file/tests/src/Kernel/FileSaveUploadTest.php create mode 100644 web/core/modules/forum/tests/src/Functional/ForumTermAccessTest.php create mode 100644 web/core/modules/language/tests/src/Functional/LanguageConfigInstallOverrideExistingTest.php create mode 100644 web/core/modules/layout_builder/tests/src/Kernel/EntityViewAlterTest.php create mode 100644 web/core/modules/locale/tests/src/Functional/LocaleInstallTest.php create mode 100644 web/core/modules/system/tests/modules/entity_test/src/Plugin/Field/ComputedTestCacheableIntegerItemList.php create mode 100644 web/core/modules/system/tests/modules/form_test/src/Form/FormTestDetailsContainsRequiredTextfieldForm.php create mode 100644 web/core/modules/system/tests/src/Functional/Entity/EntityComputedFieldTest.php create mode 100644 web/core/modules/system/tests/src/Functional/Theme/NodeTitleTestBase.php create mode 100644 web/core/modules/views/tests/modules/views_test_config/test_views/views.view.test_argument_default_node_with_page.yml create mode 100644 web/core/modules/views/tests/src/Unit/Plugin/views/filter/NumericFilterTest.php delete mode 100644 web/core/phpstan-baseline.neon create mode 100644 web/core/profiles/test_language_negotiation/config/install/language.types.yml create mode 100644 web/core/profiles/test_language_negotiation/test_language_negotiation.info.yml create mode 100644 web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/Attribute/Nonexistent.php create mode 100644 web/core/tests/Drupal/Tests/Component/Annotation/Doctrine/Fixtures/ExtraAttributes/ExampleParentAttribute.php create mode 100644 web/core/themes/claro/tests/src/Functional/NodeTitleTest.php create mode 100644 web/core/themes/olivero/tests/src/Functional/NodeTitleTest.php diff --git a/.gitattributes b/.gitattributes index 76ea8feeb1..e7b792f840 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 f524b607c2..4b8b5cdc62 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 e9bc03b329..4d92915111 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 f23a83ca7e..b0b4c629c8 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 4178a3fe5c..106c890ea6 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 42ebef38dd..d05426d283 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 61b123d80c..9a2199916a 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 1cba7aee11..78c3c99b60 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 0000000000..fd7b759bd9 --- /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 ae502c7aa1..48499be2a1 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 76ea8feeb1..e7b792f840 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 d3aeb4577e..1cb064e275 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 083776a537..6d2c291260 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 e8930b5fb7..d16d0d14a8 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 10b9441c1a..ce1aa0c083 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 67691784b3..6a8955b0a1 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 ab89a06f16..9924c2b097 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 3e5fbc6be8..275e399395 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 590a3056a1..83067c2c1b 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 cdaf0d19dd..5a097673ec 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 b7fd9ed419..d2d1f1262f 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 2c4416ad26..2293c45ffe 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 062dd177d0..2c1ea5e045 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 34bb51689d..5f31bd605a 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 ad2a89f08c..172331cf5f 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 af3fd0dcee..88efd5efe4 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 f1ea8cd5b7..3fa6c38483 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 79e61b3e14..781417760c 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 7e78c08752..f135c5550d 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 9a8c1012c8..415fe880c7 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 cf7446cd0a..585a8fdf99 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 70c9184a85..fa6c09c7a7 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 24785766d1..cb4e7a4a88 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 404d5dcf38..6f45996189 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 a0ed3ea11e..aa415d39ca 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 2a58bb7585..782ecba82e 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 5fcac94117..40829d936b 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 c4e5b3ba13..45d32f09ef 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 0000000000..580d958ee8 --- /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 5a7fc05dd5..9ad0d34d78 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 fb7ab9e839..d6410b2e59 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 2e7083ff86..bdc11f51cb 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 050f108d69..111bda03f2 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 283331f4e1..9a90c3566b 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 6186bc3494..06b07c5abe 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 1d0ef55558..c629719a3f 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 53927987d1..908f5dfb4a 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 7d0f3b12c7..4a8ab09de5 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 3256a17fd8..e293b9d87e 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 218b892688..f33dd0b961 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 2c7624023c..f649a767a3 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 5d592e72f1..3c3e106e70 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 0a5899ba91..86a4ec4475 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 9e66a75923..7de67a8143 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 5842e957d6..2d56c3d24b 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 f7503d345d..7c97c6a6d1 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 5ba836f1a8..472f04183c 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 71eb497607..b251951b30 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 3695c591b6..86aae63f7a 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 4652abd651..a00acfa773 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 fae697225f..4488476f8b 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 f0b2422630..bbc9a31b50 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 62a5ac434b..429166121e 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 42ebab47e9..cb9997852b 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 6cb5b6bd53..add5dbabd3 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 5f5e75012a..81cab05e55 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 e204023d7a..bd5f3facdf 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 e87c06521d..8c6ceadd4a 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 edc3b94576..fac456f5a6 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 7bd37d3b11..18b48460d3 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 d719849914..d553411b9f 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 c82d1b91a8..dfc8a21dc8 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 35f1d749d6..08ced21dc4 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 ac1a1b7ffb..f404d0e49e 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 6bad38c77b..86fa29ef97 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 5653b28e4e..dc5ace9423 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 930167f04f..68eb18dbb8 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 0dfbe3d865..b5b9f1dcc9 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 0000000000..ca998cde89 --- /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 11fe270883..47f34c21f6 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 4f621c0868..c4b992ac19 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 cdaae0d2e4..a3e7354ca9 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 c4912798df..063d911495 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 463525b1bc..f24cc4dac5 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 689a006b9f..c2035dcb2f 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 0000000000..ed54b45270 --- /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 ce3f430145..fdb33d1710 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 faafebdf52..534d0718f1 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 93030b0f92..28e602741c 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 03532ffbce..ef12736e38 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 647f0d62aa..c374d0ae6c 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 6da294625c..d0f9b8a51f 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 a33d124dee..d5f36e395f 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 fa86532f7c..04899c5103 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 cad33f6241..a6ca00e44d 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 6ae390fbce..3b4e951846 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 44c4781ee7..4e517e531a 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 51b048997a..e70db1ebd6 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 0000000000..76ac49d97a --- /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 2ef77344f8..a533a90ec6 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 3a3b1b04fb..2ebf180392 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 f8c6e315d2..8089031020 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 0000000000..d512a0f742 --- /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 150438c41f..be2ca42ce3 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 14e55e261e..798acbb473 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 3e9a16e9a6..79b91b1db3 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 0000000000..944b37241c --- /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 9921e7b94b..b2ea67a00b 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 ccd4c3e2c4..4203045b59 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 1df6ef1d42..47b5681f1a 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 b603c95021..b0de9171e3 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 83f5dc39db..fcfa3b8d7b 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 8cef396210..14ccf54cc9 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 dd964304d5..901bf7e105 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 0f22c1187d..16904c9e41 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 1bb1224052..5a1d7ab70c 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 6e59823b7a..8f224a4078 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 21b2a7b9a3..b38fa6c64f 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 84ad99b7da..8bd69aff13 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 efc47df28b..36b90c8f94 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 35283b83f9..cebb6f2c73 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 31a1c71ad0..98a0bce520 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 4ac86e6802..88dae43c63 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 0000000000..74a8bd9352 --- /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 960730908f..e3964762d7 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 324d748828..fac7885f7b 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 578f9348eb..1d4c5acae1 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 1693a6de14..2a5d43a849 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 d65fb82217..8e8f40d903 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 0000000000..48f829a308 --- /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 97f4327fac..4c995841a6 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 0000000000..776509cbc3 --- /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 2776199662..6cfc2b344d 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 b7bfe21112..70c2b53097 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 716745ab76..340d15056f 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 1f272ee239..ac2bb016fa 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 f34844aedd..b0d5c20877 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 beb88d0de8..6c9ca1ebb6 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 c188a57a40..9207e5500e 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 b429213ee0..ffdeb35956 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 528c2bbf62..00d73a73f0 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 586e545a18..5a6621b4e3 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 52b89c9999..54d55cfb03 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 0ba79e1aab..afcb0cde8d 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 3afe4bc475..5c138c4683 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 1be9cd1ccc..bd9c727f43 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 c10a75b71c..b4ab0b5d0f 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 b496cf6beb..641fd709a0 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 d9df596421..fd0e3332b2 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 05ced94c98..8f780ed07b 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 e42867f33d..71e27caf82 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 70f2a26e1b..fce725328c 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 6a2a42eff1..ccf3c9577a 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 cf2ff03c4a..5eaea98aac 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 2d25b946a5..b2d076dedb 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 23e7fa5fb1..64ec7ed09b 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 b70073e238..7ef03be111 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 1814b113a2..e809f8eba0 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 b6a939b0b8..55855f00c7 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 59170147e8..7f652abc88 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 64985ed1ed..749dad24f7 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 6cf0357002..9ade6b8344 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 0000000000..6c9a85b9ae --- /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 21aaa9f7b0..307409babc 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 b6c914e32d..2090db49aa 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 80542e6153..be0a1a34a8 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 0000000000..2ed3230390 --- /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 91e5540fda..0677df3bd0 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 0000000000..56e939986f --- /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 4e425343e2..4bd82849b0 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 2d3199f48e..57f3e28644 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 328fca30be..4d28dd997e 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 06980db0ef..6724fc7cd5 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 112ad12665..4bed0be43c 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 0000000000..212fc250a8 --- /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 409a729aa4..9e9dfd62aa 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--<script type="text/javascript">alert('yo');</script>' . $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 6b7d74da7b..a5516a9491 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 02115807dd..308fa70a84 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 f7113a619d..0bc84181d1 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 d9b213f45a..09718581e4 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 497d7e7e8d..bebb262ebd 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 163dd45440..f7dcfa2dc5 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 6ef20bc9f0..ebb5e60015 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 43946ba8dc..b5e368df25 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 6fabf4c7ec..80ccd424dd 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 8c2f82af4a..106c09f746 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 b9b86fd6a4..ef2a965c4b 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 b3a616c3dc..d9a9f54fdd 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 3e018ae11c..0a4273d236 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 62ce4a08d6..ff330bd534 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 7e5bebfbf2..f46b893203 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 31a0147c4c..f844ddb936 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 d372baedc2..6cd39aa1a3 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 ef24bb6eee..dd2014e86a 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 bffce7a896..4398882738 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 2e34e069cf..68612c8b20 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 673721a301..b76f10ea7d 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 0000000000..0d1739a220 --- /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 62cdcee36e..9c4f6c2ffe 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 fcd0e0ead9..d55853dbc8 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 dfca6c0d37..3ee85dc35f 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 b2ca2f1031..e68cf66b75 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 97d2ffc2c9..dd3e2286ba 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&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&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&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&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&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 b9c2d66945..0d63cfd04e 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 ea079c488a..57a6d6d71d 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 6ef1a332fe..aff3dc6696 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 a7899a9143..df4c653103 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 0000000000..6752f91065 --- /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 63112b3cd7..2d8fe5081f 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 5cbd583e3c..f534cd6ff9 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 34edf52d53..4cadec6186 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 2dac1a7d1c..8208210e05 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 76a9b1f7bb..152ed043f7 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 053ff32989..fe43b71d6d 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 0ed2d9f130..958f6f60d7 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 524413750b..72931bbccf 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 f8d3e0ad87..fd33926747 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 ec7fb9dc49..2a03880002 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 845c209c0d..0000000000 --- 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 f28e9249f5..005b9ae84c 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 bfe1fa7221..70f7e4e08e 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 0b6cffbe78..d1f0d8cef0 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 0000000000..9e411ba2c4 --- /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 0000000000..a83b1cfb43 --- /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 cc3c4bf282..0a1672b9c7 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 e289fc48ba..57f139442e 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 ab7425a252..b5c0d91789 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 8a6c37db1a..d223feab7b 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 6ab657c6e0..e151df9926 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 c84e0c875d..e25448d6a1 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 396623bec7..2f35f8b7d0 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 03992fd9c9..bb94ae83d7 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 5d91cbd8ee..61f51dc81a 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 18ee774338..c0a0172a8f 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 f698279a56..9fec10ddff 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 6b89794151..20d02777b1 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 7bfd326bc2..dd8f0d3eff 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 c955289fcf..9c142ae0d4 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 f22ae1db22..91984854a3 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 67d6136e15..dbf5af90f9 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 0000000000..45ed519aa4 --- /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 0275fabb56..abcd69fa12 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 0000000000..ea1eaaa0f8 --- /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 d929e48f61..85a99f3c35 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 e48973a39f..fcf770d322 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 c6466ba669..fc477d196b 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 b18c95c0c3..a1e72d23fe 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 b05a7be502..8ad7a98926 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 b4c5a6952e..ad9ba1ac96 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 da578931b3..f79915f18c 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 f1ed747139..b0f0c23ef9 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 9e50d3c92b..25da3d5119 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 bf154ca10f..442379723d 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 0a5fcee9c4..1339f6ef24 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 bc44483ed2..c71a84836c 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 2522a89476..fef5f84024 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 c9010bdcd7..9f94a58da3 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 fc0213793f..57c32baf0b 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 95630123c3..1e2c1e7c60 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 7583848a1e..1cafe065f7 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 6d7951bc97..2cf483611f 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 bc6621b719..de87cce443 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 5ab49683c7..86504ffa59 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 c564a3e17f..2ac0a72f00 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 2fc1f84b3f..d6b7c2f9d7 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 3b4de81d80..89b78dd560 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 d07c425ea5..4bd3e8bbab 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 b97522dee6..70e4cfb32d 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 & 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 & 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 bf70c5522d..027eeb40c3 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 e50b29b344..70c7358bf0 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 89c277ded3..0604fda0b4 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 fe5f2c4d45..77de7e2e4e 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 db334a0fee..4be6220952 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 80cb15d751..53788d4b84 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 b0896b3fc4..1caed3b429 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 6a54511a54..c0b5c28961 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 4e2d49a288..ba24da9008 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 da8facef8d..3eb53af4da 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 8e5cc374e0..594d6075db 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 738c85f9f1..a2cd708226 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 69cea9cae7..dcb0a2ba8b 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 e3affb3e77..5cbdd2b900 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 476a2de79c..9d6c740675 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 0bbf9c024e..10e15a6b71 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 63a3a07cd7..dbaa0508a0 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 4d5a7948a8..033923cf1c 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 2f36f8bf7c..3b37b992ce 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 3b2cd3f646..0561a6665f 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 c26d82301f..0baa5b2c29 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 015280fd1f..6d5bce7b01 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 f00e953cbb..2fded23efd 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 c85061f70b..fbc0002f8a 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 1dbca86662..50cbeabd2c 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 82c89cc324..80372bfd15 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 f74c56ae5e..b135a5ddcf 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 0000000000..a97827f779 --- /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 6a999a6905..ec527f1a11 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 f9c6e0345a..4eb6008dd7 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 f739ad92bb..d3c5598944 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 4e2526a393..310a37567f 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 942e7ca408..3b34f3eb95 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 37296e7e72..d95cde8436 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 0000000000..d0c7d88b1b --- /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 c510ed4584..993229e26e 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; -- GitLab