diff --git a/CHANGELOG.md b/CHANGELOG.md index 74a14c065..05d2f4747 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,11 +1,31 @@ # Changelog +## [3.0.0-beta5](https://github.com/openeuropa/oe_theme/tree/3.0.0-beta6) (2021-11-08) + +[Full Changelog](https://github.com/openeuropa/oe_theme/compare/3.0.0-beta5...3.0.0-beta6) + +**Merged pull requests:** + +- OEL-60: Drupal 9 Compatibility fixes. [\#880](https://github.com/openeuropa/oe_theme/pull/880) ([escuriola](https://github.com/escuriola)) + +## [3.0.0-beta5](https://github.com/openeuropa/oe_theme/tree/3.0.0-beta5) (2021-10-29) + +[Full Changelog](https://github.com/openeuropa/oe_theme/compare/3.0.0-beta4...3.0.0-beta5) + +**Merged pull requests:** + +- Prepare release 3.0.0-beta5. [\#975](https://github.com/openeuropa/oe_theme/pull/975) ([imanoleguskiza](https://github.com/imanoleguskiza)) +- EWPP-1649: Update ECL version. [\#968](https://github.com/openeuropa/oe_theme/pull/968) ([sergepavle](https://github.com/sergepavle)) +- EWPP-1432: Update field_group module to 3.2. [\#923](https://github.com/openeuropa/oe_theme/pull/923) ([yenyasinn](https://github.com/yenyasinn)) +- EWPP-1579: Update to ECL 3.0.3. [\#953](https://github.com/openeuropa/oe_theme/pull/953) ([22Alexandra](https://github.com/22Alexandra)) + ## [3.0.0-beta4](https://github.com/openeuropa/oe_theme/tree/3.0.0-beta4) (2021-09-27) [Full Changelog](https://github.com/openeuropa/oe_theme/compare/3.0.0-beta3...3.0.0-beta4) **Merged pull requests:** +- Prepare release 3.0.0-beta4. [\#961](https://github.com/openeuropa/oe_theme/pull/961) ([imanoleguskiza](https://github.com/imanoleguskiza)) - Epic ewpp 1360 news v3 [\#957](https://github.com/openeuropa/oe_theme/pull/957) ([22Alexandra](https://github.com/22Alexandra)) - Update epic news [\#956](https://github.com/openeuropa/oe_theme/pull/956) ([22Alexandra](https://github.com/22Alexandra)) - EWPP-1486: Theme publication collection related fields. [\#945](https://github.com/openeuropa/oe_theme/pull/945) ([nagyad](https://github.com/nagyad)) diff --git a/README.md b/README.md index bb2285e04..447aa9a32 100644 --- a/README.md +++ b/README.md @@ -3,7 +3,7 @@ [![Build Status](https://drone.fpfis.eu/api/badges/openeuropa/oe_theme/status.svg?branch=master)](https://drone.fpfis.eu/openeuropa/oe_theme) [![Packagist](https://img.shields.io/packagist/v/openeuropa/oe_theme.svg)](https://packagist.org/packages/openeuropa/oe_theme) -Drupal 8 theme based on the [Europa Component Library][1] (ECL). +Drupal 8 and 9 theme based on the [Europa Component Library][1] (ECL). **Table of contents:** diff --git a/behat.yml.dist b/behat.yml.dist index db97e7617..8028e8bd8 100644 --- a/behat.yml.dist +++ b/behat.yml.dist @@ -2,7 +2,7 @@ default: suites: default: paths: - - %paths.base%/tests/features + - "%paths.base%/tests/features" contexts: - Drupal\DrupalExtension\Context\DrupalContext - Drupal\DrupalExtension\Context\MarkupContext @@ -37,7 +37,7 @@ default: priorities dropdown menu: ".ecl-menu__item:nth-child(3) .ecl-menu__mega" search form: ".ecl-search-form" navigation menu: ".ecl-menu" - site name: ".ecl-menu__site-name" + site name: ".ecl-site-header-standardised__site-name" pages: content management: "/en/admin/content" ECL components overview: "/en/components" diff --git a/composer.json b/composer.json index 1b394ab7f..a466b1d34 100644 --- a/composer.json +++ b/composer.json @@ -7,11 +7,11 @@ "prefer-stable": true, "require": { "php": ">=7.3", - "drupal/core": "^8.9.14", + "drupal/core": "^8.9.14 || ^9.1", "drupal/smart_trim": "^1.2", "drupal/twig_field_value": "^2.0", "drupal/ui_patterns": "^1.0", - "openeuropa/ecl-twig-loader": "^3.0", + "openeuropa/ecl-twig-loader": "^3.1", "openeuropa/oe_time_caching": "~1.0", "ralouphie/mimey": "^2.1" }, @@ -20,7 +20,7 @@ "consolidation/annotated-command": "^2.8.2", "consolidation/robo": "~1.4", "cweagans/composer-patches": "~1.6.7", - "drupal/core-composer-scaffold": "^8.8", + "drupal/core-composer-scaffold": "^8.9 || ^9.1", "drupal/address": "~1.9", "drupal/composite_reference": "~1.0-alpha1", "drupal/config_devel": "~1.2", @@ -32,38 +32,40 @@ "drupal/entity_reference_revisions": "~1.3", "drupal/entity_browser": "^2.5", "drupal/extra_field": "^1.1", - "drupal/field_group": "~3.0", + "drupal/field_group": "~3.2", "drupal/inline_entity_form": "~1.0-rc9", "drupal/json_field": "^1.0.0-rc2", "drupal/renderviz": "^1.0@alpha", - "drupal/styleguide": "~1.0-alpha3", + "drupal/styleguide": "~1.0@beta", + "drush/drush": "~10.3", "drupal/typed_link": "^2.0", - "drush/drush": "~9.0", "easyrdf/easyrdf": "1.0.0 as 0.9.1", "friends-of-behat/service-container-extension": "^1.0", - "guzzlehttp/guzzle": "~6.3", "instaclick/php-webdriver": "^1.4.7", "nikic/php-parser": "~3.0", "openeuropa/behat-transformation-context": "~0.1", - "openeuropa/code-review": "~1.5", - "openeuropa/drupal-core-require-dev": "^8.9.14", + "openeuropa/code-review": "~1.6", + "openeuropa/drupal-core-require-dev": "^8.9 || ^9.1", "openeuropa/oe_content": "dev-EPIC-EWPP-1539-Event-v2", "openeuropa/oe_corporate_blocks": "~4.0", "openeuropa/oe_corporate_countries": "~2.0", "openeuropa/oe_media": "~1.12", "openeuropa/oe_multilingual": "~1.8", "openeuropa/oe_paragraphs": "~1.10", - "openeuropa/oe_search": "~1.0", - "openeuropa/oe_webtools": "~1.10", + "openeuropa/oe_search": "1.x-dev", + "openeuropa/oe_webtools": "~1.12", "openeuropa/oe_contact_forms": "~1.1", "openeuropa/rdf_skos": "~1.0", "openeuropa/task-runner-drupal-project-symlink": "^1.0", - "phpunit/phpunit": "~6.0", - "symfony/dom-crawler": "~3.4" + "phpspec/prophecy-phpunit": "^1 || ^2", + "phpunit/phpunit": "^7.5 || ^8 || ^9" }, "_readme": [ "We explicitly require consolidation/robo to allow lower 'composer update --prefer-lowest' to complete successfully.", - "We explicitly require consolidation/annotated-command to allow lower 'composer update --prefer-lowest' to complete successfully." + "We explicitly require consolidation/annotated-command to allow lower 'composer update --prefer-lowest' to complete successfully.", + "We explicity require drupal/core to allow lower 'composer update --prefer-lowest' to complete successfully.", + "openeuropa/oe_search is used from a branch because of major upgrading is pending. Change again when it released.", + "openeuropa/ecl-twig-loader is used from a branch because it must be upgrade to be D9 compatible. Change again when it released." ], "conflict": { "openeuropa/oe_corporate_blocks": "<3.0.0", @@ -80,7 +82,7 @@ }, "autoload-dev": { "psr-4": { - "Drupal\\Tests\\oe_theme\\": "./tests/", + "Drupal\\Tests\\oe_theme\\": "./tests/src/", "Drupal\\Tests\\oe_content\\": "./build/modules/contrib/oe_content/tests/src/", "Drupal\\Tests\\oe_media\\": "./build/modules/contrib/oe_media/tests/src/" } diff --git a/modules/oe_theme_contact_forms/oe_theme_contact_forms.info.yml b/modules/oe_theme_contact_forms/oe_theme_contact_forms.info.yml index 064891c5d..56efb3311 100644 --- a/modules/oe_theme_contact_forms/oe_theme_contact_forms.info.yml +++ b/modules/oe_theme_contact_forms/oe_theme_contact_forms.info.yml @@ -2,6 +2,6 @@ name: OpenEuropa Theme Contact Forms type: module description: Companion module for the OE Contact Forms module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_contact_forms:oe_contact_forms diff --git a/modules/oe_theme_content_call_proposals/oe_theme_content_call_proposals.info.yml b/modules/oe_theme_content_call_proposals/oe_theme_content_call_proposals.info.yml index 467f9ff3e..0ca4da7d6 100644 --- a/modules/oe_theme_content_call_proposals/oe_theme_content_call_proposals.info.yml +++ b/modules/oe_theme_content_call_proposals/oe_theme_content_call_proposals.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Call for proposals Content type: module description: Companion module for the OE Call for proposals Content module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - field_group:field_group diff --git a/modules/oe_theme_content_call_tenders/oe_theme_content_call_tenders.info.yml b/modules/oe_theme_content_call_tenders/oe_theme_content_call_tenders.info.yml index 495913361..f25a37195 100644 --- a/modules/oe_theme_content_call_tenders/oe_theme_content_call_tenders.info.yml +++ b/modules/oe_theme_content_call_tenders/oe_theme_content_call_tenders.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Call for tenders Content type: module description: Companion module for the OE Call for tenders content module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - field_group:field_group diff --git a/modules/oe_theme_content_consultation/oe_theme_content_consultation.info.yml b/modules/oe_theme_content_consultation/oe_theme_content_consultation.info.yml index 53897c97d..1a5ee251c 100644 --- a/modules/oe_theme_content_consultation/oe_theme_content_consultation.info.yml +++ b/modules/oe_theme_content_consultation/oe_theme_content_consultation.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Consultation Content type: module description: Companion module for the OE Content Consultation module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - drupal:datetime diff --git a/modules/oe_theme_content_entity_contact/oe_theme_content_entity_contact.info.yml b/modules/oe_theme_content_entity_contact/oe_theme_content_entity_contact.info.yml index e68732134..71c0c8c46 100755 --- a/modules/oe_theme_content_entity_contact/oe_theme_content_entity_contact.info.yml +++ b/modules/oe_theme_content_entity_contact/oe_theme_content_entity_contact.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Content Entity Contact description: Companion module for the OE Content Entity Contact module package: OpenEuropa type: module -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_theme:oe_theme_helper diff --git a/modules/oe_theme_content_entity_organisation/oe_theme_content_entity_organisation.info.yml b/modules/oe_theme_content_entity_organisation/oe_theme_content_entity_organisation.info.yml index c841cbefc..7da2c78aa 100644 --- a/modules/oe_theme_content_entity_organisation/oe_theme_content_entity_organisation.info.yml +++ b/modules/oe_theme_content_entity_organisation/oe_theme_content_entity_organisation.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Content Entity Organisation description: Companion module for the OE Content Entity Organisation module package: OpenEuropa type: module -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_theme:oe_theme_helper diff --git a/modules/oe_theme_content_entity_venue/oe_theme_content_entity_venue.info.yml b/modules/oe_theme_content_entity_venue/oe_theme_content_entity_venue.info.yml index 3aa0ad1e0..74e6733b8 100755 --- a/modules/oe_theme_content_entity_venue/oe_theme_content_entity_venue.info.yml +++ b/modules/oe_theme_content_entity_venue/oe_theme_content_entity_venue.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Content Entity Venue description: Companion module for the OE Content Entity Venue module package: OpenEuropa type: module -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_theme:oe_theme_helper diff --git a/modules/oe_theme_content_event/oe_theme_content_event.info.yml b/modules/oe_theme_content_event/oe_theme_content_event.info.yml index 6adacbce2..6e394d01c 100644 --- a/modules/oe_theme_content_event/oe_theme_content_event.info.yml +++ b/modules/oe_theme_content_event/oe_theme_content_event.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Event Content type: module description: Companion module for the OE Content Event module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - oe_content:oe_content_event diff --git a/modules/oe_theme_content_news/oe_theme_content_news.info.yml b/modules/oe_theme_content_news/oe_theme_content_news.info.yml index 01690228c..0c7fa100f 100644 --- a/modules/oe_theme_content_news/oe_theme_content_news.info.yml +++ b/modules/oe_theme_content_news/oe_theme_content_news.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme News Content type: module description: Companion module for the OE Content News module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - oe_content_news:oe_content_news diff --git a/modules/oe_theme_content_organisation/oe_theme_content_organisation.info.yml b/modules/oe_theme_content_organisation/oe_theme_content_organisation.info.yml index 5e84d35f9..8efb3489a 100644 --- a/modules/oe_theme_content_organisation/oe_theme_content_organisation.info.yml +++ b/modules/oe_theme_content_organisation/oe_theme_content_organisation.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Organisation Content type: module description: Companion module for the OE Organisation Content module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_content:oe_content_organisation - oe_content:oe_content_organisation_person_reference diff --git a/modules/oe_theme_content_organisation_reference/oe_theme_content_organisation_reference.info.yml b/modules/oe_theme_content_organisation_reference/oe_theme_content_organisation_reference.info.yml index 81022fd3c..a1f18a5af 100644 --- a/modules/oe_theme_content_organisation_reference/oe_theme_content_organisation_reference.info.yml +++ b/modules/oe_theme_content_organisation_reference/oe_theme_content_organisation_reference.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Organisation Reference type: module description: Companion module for the OE Organisation Reference module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_content:oe_content_organisation_reference diff --git a/modules/oe_theme_content_page/oe_theme_content_page.info.yml b/modules/oe_theme_content_page/oe_theme_content_page.info.yml index b21ebc001..8f7e59f13 100644 --- a/modules/oe_theme_content_page/oe_theme_content_page.info.yml +++ b/modules/oe_theme_content_page/oe_theme_content_page.info.yml @@ -2,6 +2,6 @@ name: OpenEuropa Theme Page Content type: module description: Companion module for the OE Content Page module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_content_page:oe_content_page diff --git a/modules/oe_theme_content_person/oe_theme_content_person.info.yml b/modules/oe_theme_content_person/oe_theme_content_person.info.yml index afa1ca8c1..54068ac4f 100644 --- a/modules/oe_theme_content_person/oe_theme_content_person.info.yml +++ b/modules/oe_theme_content_person/oe_theme_content_person.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Person Content type: module description: Companion module for the OE Content Person module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field diff --git a/modules/oe_theme_content_policy/oe_theme_content_policy.info.yml b/modules/oe_theme_content_policy/oe_theme_content_policy.info.yml index 16cfc753e..91ac6ccc2 100644 --- a/modules/oe_theme_content_policy/oe_theme_content_policy.info.yml +++ b/modules/oe_theme_content_policy/oe_theme_content_policy.info.yml @@ -2,6 +2,6 @@ name: OpenEuropa Theme Policy Content type: module description: Companion module for the OE Content Policy module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_content:oe_content_policy diff --git a/modules/oe_theme_content_project/oe_theme_content_project.info.yml b/modules/oe_theme_content_project/oe_theme_content_project.info.yml index 12176c0ed..49a8a0299 100644 --- a/modules/oe_theme_content_project/oe_theme_content_project.info.yml +++ b/modules/oe_theme_content_project/oe_theme_content_project.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Project Content type: module description: Companion module for the OE Content Project module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - field_group:field_group diff --git a/modules/oe_theme_content_publication/oe_theme_content_publication.info.yml b/modules/oe_theme_content_publication/oe_theme_content_publication.info.yml index fd9c04b03..89021f364 100644 --- a/modules/oe_theme_content_publication/oe_theme_content_publication.info.yml +++ b/modules/oe_theme_content_publication/oe_theme_content_publication.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Publication Content type: module description: Companion module for the OE Content Publication module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - oe_content:oe_content_publication diff --git a/modules/oe_theme_content_sub_entity_document_reference/oe_theme_content_sub_entity_document_reference.info.yml b/modules/oe_theme_content_sub_entity_document_reference/oe_theme_content_sub_entity_document_reference.info.yml index fff13ebb6..c612e69bd 100644 --- a/modules/oe_theme_content_sub_entity_document_reference/oe_theme_content_sub_entity_document_reference.info.yml +++ b/modules/oe_theme_content_sub_entity_document_reference/oe_theme_content_sub_entity_document_reference.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Document reference type: module description: Companion module for the OE Content Entity Document reference module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_content:oe_content_sub_entity_document_reference - oe_theme:oe_theme_content_publication diff --git a/modules/oe_theme_demo/oe_theme_demo.info.yml b/modules/oe_theme_demo/oe_theme_demo.info.yml index 3a8717b9c..345199c65 100644 --- a/modules/oe_theme_demo/oe_theme_demo.info.yml +++ b/modules/oe_theme_demo/oe_theme_demo.info.yml @@ -1,7 +1,7 @@ name: OpenEuropa Theme Demo description: OpenEuropa Theme Demo type: module -core: 8.x +core_version_requirement: ^8.9 || ^9.1 package: OpenEuropa dependencies: - drupal:block diff --git a/modules/oe_theme_helper/oe_theme_helper.info.yml b/modules/oe_theme_helper/oe_theme_helper.info.yml index 94b414f65..a22660015 100644 --- a/modules/oe_theme_helper/oe_theme_helper.info.yml +++ b/modules/oe_theme_helper/oe_theme_helper.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Helper type: module description: OpenEuropa theme helpers and tools. package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - drupal:node - ui_patterns:ui_patterns_library diff --git a/modules/oe_theme_helper/src/TwigExtension/TwigExtension.php b/modules/oe_theme_helper/src/TwigExtension/TwigExtension.php index ec5e241d7..54874f939 100644 --- a/modules/oe_theme_helper/src/TwigExtension/TwigExtension.php +++ b/modules/oe_theme_helper/src/TwigExtension/TwigExtension.php @@ -18,6 +18,10 @@ use Drupal\oe_theme_helper\EuropeanUnionLanguages; use Drupal\smart_trim\Truncate\TruncateHTML; use Drupal\Core\Template\TwigExtension as CoreTwigExtension; +use Twig\Environment; +use Twig\Extension\AbstractExtension; +use Twig\TwigFilter; +use Twig\TwigFunction; /** * Collection of extra Twig extensions as filters and functions. @@ -25,7 +29,7 @@ * We don't enforce any strict type checking on filters' arguments as they are * coming straight from Twig templates. */ -class TwigExtension extends \Twig_Extension { +class TwigExtension extends AbstractExtension { /** * The language manager. @@ -59,22 +63,16 @@ public function __construct(LanguageManagerInterface $languageManager, RendererI */ public function getFilters(): array { return [ - new \Twig_SimpleFilter('format_size', 'format_size'), - new \Twig_SimpleFilter('to_language', [$this, 'toLanguageName']), - new \Twig_SimpleFilter('to_native_language', [ - $this, - 'toNativeLanguageName', - ]), - new \Twig_SimpleFilter('to_internal_language_id', [ - $this, - 'toInternalLanguageId', - ]), - new \Twig_SimpleFilter('to_file_icon', [$this, 'toFileIcon']), - new \Twig_SimpleFilter('to_date_status', [$this, 'toDateStatus']), - new \Twig_SimpleFilter('to_ecl_attributes', [$this, 'toEclAttributes']), - new \Twig_SimpleFilter('smart_trim', [$this, 'smartTrim'], ['needs_environment' => TRUE]), - new \Twig_SimpleFilter('is_external_url', [UrlHelper::class, 'isExternal']), - new \Twig_SimpleFilter('filter_empty', [$this, 'filterEmpty']), + new TwigFilter('format_size', 'format_size'), + new TwigFilter('to_language', [$this, 'toLanguageName']), + new TwigFilter('to_native_language', [$this, 'toNativeLanguageName']), + new TwigFilter('to_internal_language_id', [$this, 'toInternalLanguageId']), + new TwigFilter('to_file_icon', [$this, 'toFileIcon']), + new TwigFilter('to_date_status', [$this, 'toDateStatus']), + new TwigFilter('to_ecl_attributes', [$this, 'toEclAttributes']), + new TwigFilter('smart_trim', [$this, 'smartTrim'], ['needs_environment' => TRUE]), + new TwigFilter('is_external_url', [UrlHelper::class, 'isExternal']), + new TwigFilter('filter_empty', [$this, 'filterEmpty']), ]; } @@ -83,9 +81,9 @@ public function getFilters(): array { */ public function getFunctions(): array { return [ - new \Twig_SimpleFunction('to_ecl_icon', [$this, 'toEclIcon'], ['needs_context' => TRUE]), - new \Twig_SimpleFunction('get_link_icon', [$this, 'getLinkIcon'], ['needs_context' => TRUE]), - new \Twig_SimpleFunction('ecl_footer_links', [$this, 'eclFooterLinks'], ['needs_context' => TRUE]), + new TwigFunction('to_ecl_icon', [$this, 'toEclIcon'], ['needs_context' => TRUE]), + new TwigFunction('get_link_icon', [$this, 'getLinkIcon'], ['needs_context' => TRUE]), + new TwigFunction('ecl_footer_links', [$this, 'eclFooterLinks'], ['needs_context' => TRUE]), ]; } @@ -546,7 +544,7 @@ public function toEclIcon(array $context, $icon, string $size = ''): array { /** * Trim given input using smart_trim module heuristics. * - * @param \Twig_Environment $env + * @param \Twig\Environment $env * Current Twig environment. * @param mixed $input * Input to be trimmed, it can be a string, an object or a render array. @@ -556,7 +554,7 @@ public function toEclIcon(array $context, $icon, string $size = ''): array { * @return mixed * The trimmed output. */ - public function smartTrim(\Twig_Environment $env, $input, $limit) { + public function smartTrim(Environment $env, $input, $limit) { // Bubbles Twig template argument's cacheability & attachment metadata. $this->bubbleArgMetadata($input); $truncate = new TruncateHTML(); diff --git a/modules/oe_theme_helper/tests/modules/oe_theme_inpage_navigation_test/oe_theme_inpage_navigation_test.info.yml b/modules/oe_theme_helper/tests/modules/oe_theme_inpage_navigation_test/oe_theme_inpage_navigation_test.info.yml index 42e562e0d..fc18cb592 100644 --- a/modules/oe_theme_helper/tests/modules/oe_theme_inpage_navigation_test/oe_theme_inpage_navigation_test.info.yml +++ b/modules/oe_theme_helper/tests/modules/oe_theme_inpage_navigation_test/oe_theme_inpage_navigation_test.info.yml @@ -2,6 +2,6 @@ name: 'OpenEuropa Theme In-page Navigation Test' type: module description: 'Module for testing in-page navigation functionality' package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_theme:oe_theme_helper diff --git a/modules/oe_theme_helper/tests/modules/page_header_metadata_test/page_header_metadata_test.info.yml b/modules/oe_theme_helper/tests/modules/page_header_metadata_test/page_header_metadata_test.info.yml index d507800cb..d4b160e8b 100644 --- a/modules/oe_theme_helper/tests/modules/page_header_metadata_test/page_header_metadata_test.info.yml +++ b/modules/oe_theme_helper/tests/modules/page_header_metadata_test/page_header_metadata_test.info.yml @@ -3,4 +3,4 @@ type: module description: 'PageHeaderMetadata test module.' package: Testing version: VERSION -core: 8.x +core_version_requirement: ^8.9 || ^9.1 diff --git a/modules/oe_theme_helper/tests/src/Functional/NodeViewRoutesMetadataTest.php b/modules/oe_theme_helper/tests/src/Functional/NodeViewRoutesMetadataTest.php index 50afe94ee..59bf4065b 100644 --- a/modules/oe_theme_helper/tests/src/Functional/NodeViewRoutesMetadataTest.php +++ b/modules/oe_theme_helper/tests/src/Functional/NodeViewRoutesMetadataTest.php @@ -28,6 +28,11 @@ class NodeViewRoutesMetadataTest extends BrowserTestBase { 'workflows', ]; + /** + * {@inheritdoc} + */ + protected $defaultTheme = 'stark'; + /** * A user with permission to see revisions. * @@ -38,7 +43,7 @@ class NodeViewRoutesMetadataTest extends BrowserTestBase { /** * {@inheritdoc} */ - public function setUp() { + public function setUp(): void { parent::setUp(); // Enable oe_theme and set it as default. diff --git a/modules/oe_theme_helper/tests/src/Functional/PageHeaderBlockTest.php b/modules/oe_theme_helper/tests/src/Functional/PageHeaderBlockTest.php index bb315abfd..4ac5fa226 100644 --- a/modules/oe_theme_helper/tests/src/Functional/PageHeaderBlockTest.php +++ b/modules/oe_theme_helper/tests/src/Functional/PageHeaderBlockTest.php @@ -29,7 +29,12 @@ class PageHeaderBlockTest extends BrowserTestBase { /** * {@inheritdoc} */ - public function setUp() { + protected $defaultTheme = 'stark'; + + /** + * {@inheritdoc} + */ + public function setUp(): void { parent::setUp(); // Enable oe_theme and set it as default. diff --git a/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/InPageNavigationTest.php b/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/InPageNavigationTest.php index 80e64a68d..1bfa0aebd 100644 --- a/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/InPageNavigationTest.php +++ b/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/InPageNavigationTest.php @@ -47,7 +47,12 @@ class InPageNavigationTest extends BrowserTestBase { /** * {@inheritdoc} */ - public function setUp() { + protected $defaultTheme = 'stark'; + + /** + * {@inheritdoc} + */ + public function setUp(): void { parent::setUp(); // Enable and set OpenEuropa Theme as default. @@ -174,25 +179,25 @@ public function testOutput(): void { // Assert first field group. $content_first_group = $content_items[0]->getText(); - $this->assertContains('Field label field_test_0', $content_first_group); - $this->assertContains('100', $content_first_group); - $this->assertContains('Field label field_test_1', $content_first_group); - $this->assertContains('200', $content_first_group); + $this->assertStringContainsString('Field label field_test_0', $content_first_group); + $this->assertStringContainsString('100', $content_first_group); + $this->assertStringContainsString('Field label field_test_1', $content_first_group); + $this->assertStringContainsString('200', $content_first_group); // Assert second field group. $content_second_group = $content_items[1]->getText(); - $this->assertContains('Single text', $content_second_group); - $this->assertContains('Output from SingleTextFieldTest', $content_second_group); - $this->assertContains('Aap', $content_second_group); - $this->assertContains('Noot', $content_second_group); + $this->assertStringContainsString('Single text', $content_second_group); + $this->assertStringContainsString('Output from SingleTextFieldTest', $content_second_group); + $this->assertStringContainsString('Aap', $content_second_group); + $this->assertStringContainsString('Noot', $content_second_group); // Assert third field group. $content_third_group = $content_items[2]->getText(); - $this->assertContains('Field group html_element', $content_third_group); - $this->assertContains('Field label field_test_2', $content_third_group); - $this->assertContains('300', $content_third_group); - $this->assertContains('Field label field_test_3', $content_third_group); - $this->assertContains('400', $content_third_group); + $this->assertStringContainsString('Field group html_element', $content_third_group); + $this->assertStringContainsString('Field label field_test_2', $content_third_group); + $this->assertStringContainsString('300', $content_third_group); + $this->assertStringContainsString('Field label field_test_3', $content_third_group); + $this->assertStringContainsString('400', $content_third_group); // Assert fourth field group - it mustn't exist. $this->assertSession()->elementTextNotContains('css', 'body', 'Field group inpage_nav_item_3'); diff --git a/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/PatternFormatterTest.php b/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/PatternFormatterTest.php index e4a9b2a91..453162fb0 100755 --- a/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/PatternFormatterTest.php +++ b/modules/oe_theme_helper/tests/src/Functional/Plugin/field_group/PatternFormatterTest.php @@ -32,7 +32,12 @@ class PatternFormatterTest extends BrowserTestBase { /** * {@inheritdoc} */ - public function setUp() { + protected $defaultTheme = 'stark'; + + /** + * {@inheritdoc} + */ + public function setUp(): void { parent::setUp(); // Enable oe_theme and set it as default. diff --git a/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationBlockTest.php b/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationBlockTest.php index ef16985ed..5f7fb9e55 100644 --- a/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationBlockTest.php +++ b/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationBlockTest.php @@ -25,12 +25,17 @@ class InPageNavigationBlockTest extends WebDriverTestBase { /** * {@inheritdoc} */ - public function setUp() { + protected $defaultTheme = 'stark'; + + /** + * {@inheritdoc} + */ + public function setUp(): void { parent::setUp(); // Enable and set OpenEuropa Theme as default. $this->container->get('theme_installer')->install(['oe_theme']); - $this->container->get('theme_handler')->setDefault('oe_theme'); + $this->config('system.theme')->set('default', 'oe_theme')->save(); $this->container->set('theme.registry', NULL); // Rebuild the ui_pattern definitions to collect the ones provided by diff --git a/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationLibraryTest.php b/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationLibraryTest.php index 705ff2edb..d96b3d9ab 100644 --- a/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationLibraryTest.php +++ b/modules/oe_theme_helper/tests/src/FunctionalJavascript/InPageNavigationLibraryTest.php @@ -33,12 +33,12 @@ class InPageNavigationLibraryTest extends WebDriverTestBase { /** * {@inheritdoc} */ - public function setUp() { + public function setUp(): void { parent::setUp(); // Enable and set OpenEuropa Theme as default. $this->container->get('theme_installer')->install(['oe_theme']); - $this->container->get('theme_handler')->setDefault('oe_theme'); + $this->config('system.theme')->set('default', 'oe_theme')->save(); $this->container->set('theme.registry', NULL); // Rebuild the ui_pattern definitions to collect the ones provided by diff --git a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaGalleryFormatterTest.php b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaGalleryFormatterTest.php index a00e2b7c1..971c8f1bc 100644 --- a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaGalleryFormatterTest.php +++ b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaGalleryFormatterTest.php @@ -46,7 +46,7 @@ class MediaGalleryFormatterTest extends AbstractKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('entity_test'); $this->installEntitySchema('media'); @@ -210,7 +210,7 @@ public function testFormatter(): void { $this->assertEquals('Alt text for test image.', $image_node->attr('alt')); $this->assertStringEndsWith('/example_1.jpeg', $image_node->attr('src')); $caption = $items->first()->filter('.ecl-gallery__description'); - $this->assertContains('Extra image title', $caption->html()); + $this->assertStringContainsString('Extra image title', $caption->html()); $this->assertEmpty($caption->filter('.ecl-gallery__meta')->html()); // Test the second gallery item. @@ -218,11 +218,14 @@ public function testFormatter(): void { '/media/oembed?url=https%3A//www.youtube.com/watch%3Fv%3D1-g73ty9v04&max_width=576&max_height=400&hash=', $items->eq(1)->filter('.ecl-gallery__item-link')->attr('data-ecl-gallery-item-embed-src') ); + + $expected_thumbnail_name = version_compare(\Drupal::VERSION, '9.2', '>=') ? 'FRPRzhRHyt8zGp5-d-luvJDnIb03oXDJUp5LtL4UeDI.jpg' : 'LQU9BWkA66xEaKfV_f74OO3Uyu1KMVLOsIi9WQYTjSg.jpg'; + $image_node = $items->eq(1)->filter('img'); $this->assertEquals("Energy, let's save it!", $image_node->attr('alt')); - $this->assertStringEndsWith('/oembed_thumbnails/LQU9BWkA66xEaKfV_f74OO3Uyu1KMVLOsIi9WQYTjSg.jpg', $image_node->attr('src')); + $this->assertStringEndsWith('/oembed_thumbnails/' . $expected_thumbnail_name, $image_node->attr('src')); $caption = $items->eq(1)->filter('.ecl-gallery__description'); - $this->assertContains($video_media->label(), $caption->html()); + $this->assertStringContainsString($video_media->label(), $caption->html()); $this->assertEmpty($caption->filter('.ecl-gallery__meta')->html()); // Test the third item. @@ -234,7 +237,7 @@ public function testFormatter(): void { $this->assertEquals('Alt text for test video iframe.', $image_node->attr('alt')); $this->assertStringEndsWith('/placeholder.png', $image_node->attr('src')); $caption = $items->eq(2)->filter('.ecl-gallery__description'); - $this->assertContains('Test video iframe title', $caption->html()); + $this->assertStringContainsString('Test video iframe title', $caption->html()); $this->assertEmpty($caption->filter('.ecl-gallery__meta')->html()); // Test that all the cache tags have present and bubbled up. @@ -271,14 +274,14 @@ public function testFormatter(): void { // Test the contents of the first item. $caption = $items->first()->filter('.ecl-gallery__description'); - $this->assertContains($image_media->label(), $caption->html()); + $this->assertStringContainsString($image_media->label(), $caption->html()); $copyright = $caption->filter('.ecl-gallery__meta'); $this->assertCount(1, $copyright); $this->assertEquals('Copyright for test image ©', $copyright->html()); // Test the second gallery item. $caption = $items->eq(1)->filter('.ecl-gallery__description'); - $this->assertContains($video_media->label(), $caption->html()); + $this->assertStringContainsString($video_media->label(), $caption->html()); $copyright = $caption->filter('.ecl-gallery__meta'); $this->assertCount(1, $copyright); $this->assertEquals('Copyright for test remote video ©', $copyright->html()); @@ -305,9 +308,9 @@ public function testFormatter(): void { // Test the contents of the first item. $image_node = $items->first()->filter('img'); $this->assertEquals('Alt text for test image.', $image_node->attr('alt')); - $this->assertContains('/files/styles/medium/public/example_1.jpeg?itok=', $image_node->attr('src')); + $this->assertStringContainsString('/files/styles/medium/public/example_1.jpeg?itok=', $image_node->attr('src')); $caption = $items->first()->filter('.ecl-gallery__description'); - $this->assertContains($image_media->label(), $caption->html()); + $this->assertStringContainsString($image_media->label(), $caption->html()); // Test the second gallery item. $this->assertStringStartsWith( @@ -316,12 +319,12 @@ public function testFormatter(): void { ); $image_node = $items->eq(1)->filter('img'); $this->assertEquals("Energy, let's save it!", $image_node->attr('alt')); - $this->assertContains( - '/files/styles/medium/public/oembed_thumbnails/LQU9BWkA66xEaKfV_f74OO3Uyu1KMVLOsIi9WQYTjSg.jpg?itok=', + $this->assertStringContainsString( + '/files/styles/medium/public/oembed_thumbnails/' . $expected_thumbnail_name . '?itok=', $image_node->attr('src') ); $caption = $items->eq(1)->filter('.ecl-gallery__description'); - $this->assertContains($video_media->label(), $caption->html()); + $this->assertStringContainsString($video_media->label(), $caption->html()); $this->assertEmpty($caption->filter('.ecl-gallery__meta')->html()); } diff --git a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaThumbnailUrlFormatterTestBase.php b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaThumbnailUrlFormatterTestBase.php index 471ffd9a0..bca6e26cc 100644 --- a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaThumbnailUrlFormatterTestBase.php +++ b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/MediaThumbnailUrlFormatterTestBase.php @@ -32,7 +32,7 @@ class MediaThumbnailUrlFormatterTestBase extends AbstractKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('entity_test'); $this->installEntitySchema('media'); diff --git a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/SocialMediaLinksFormatterTestBase.php b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/SocialMediaLinksFormatterTestBase.php index 79d362c6f..c17d35e54 100644 --- a/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/SocialMediaLinksFormatterTestBase.php +++ b/modules/oe_theme_helper/tests/src/Kernel/Plugin/Field/FieldFormatter/SocialMediaLinksFormatterTestBase.php @@ -31,7 +31,7 @@ class SocialMediaLinksFormatterTestBase extends AbstractKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('entity_test'); } diff --git a/modules/oe_theme_helper/tests/src/Functional/RetinaScaleEffectTest.php b/modules/oe_theme_helper/tests/src/Kernel/RetinaScaleEffectTest.php similarity index 59% rename from modules/oe_theme_helper/tests/src/Functional/RetinaScaleEffectTest.php rename to modules/oe_theme_helper/tests/src/Kernel/RetinaScaleEffectTest.php index 2e06ad553..d6b9510c1 100644 --- a/modules/oe_theme_helper/tests/src/Functional/RetinaScaleEffectTest.php +++ b/modules/oe_theme_helper/tests/src/Kernel/RetinaScaleEffectTest.php @@ -2,23 +2,38 @@ declare(strict_types = 1); -namespace Drupal\Tests\oe_theme_helper\Functional; +namespace Drupal\Tests\oe_theme_helper\Kernel; -use Drupal\FunctionalTests\Image\ToolkitTestBase; +use Drupal\KernelTests\KernelTestBase; +use Drupal\Tests\oe_theme_helper\Traits\ToolkitTestTrait; /** * Tests that the Retina Scale effect upscales images appropriately. * * @group image * - * @group batch3 + * @group batch2 */ -class RetinaScaleEffectTest extends ToolkitTestBase { +class RetinaScaleEffectTest extends KernelTestBase { + + use ToolkitTestTrait; + + /** + * Testing image. + * + * @var \Drupal\Core\Image\ImageInterface + */ + protected $image; /** * {@inheritdoc} */ - public static $modules = ['image', 'oe_theme_helper']; + protected static $modules = [ + 'image', + 'image_test', + 'oe_theme_helper', + 'system', + ]; /** * The image effect manager. @@ -30,16 +45,23 @@ class RetinaScaleEffectTest extends ToolkitTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected $defaultTheme = 'stark'; + + /** + * {@inheritdoc} + */ + protected function setUp(): void { parent::setUp(); $this->manager = $this->container->get('plugin.manager.image.effect'); + $this->image = $this->getImage(); + $this->imageTestReset(); } /** * Test the retina scale effect using a big enough image. */ public function testRetinaScaleEffect(): void { - $this->assertImageEffect('retina_image_scale', [ + $this->assertImageEffect(['scale'], 'retina_image_scale', [ // Set the desired width to be smaller than the image width. 'width' => 10, 'height' => 10, @@ -47,15 +69,15 @@ public function testRetinaScaleEffect(): void { $this->assertToolkitOperationsCalled(['scale']); $calls = $this->imageTestGetAllCalls(); - $this->assertEqual($calls['scale'][0][0], 10, 'Width was passed correctly'); - $this->assertEqual($calls['scale'][0][1], 10, 'Height was based off aspect ratio and passed correctly'); + $this->assertEquals(10, $calls['scale'][0][0]); + $this->assertEquals(10, $calls['scale'][0][1]); } /** * Test the retina scale effect using upscaling. */ public function testScaleEffectDefaultUpscaling(): void { - $this->assertImageEffect('retina_image_scale', [ + $this->assertImageEffect(['scale'], 'retina_image_scale', [ // Set the desired width to be higher than the image width. 'width' => $this->image->getWidth() * 4, 'upscale' => TRUE, @@ -63,28 +85,28 @@ public function testScaleEffectDefaultUpscaling(): void { $this->assertToolkitOperationsCalled(['scale']); $calls = $this->imageTestGetAllCalls(); - $this->assertEqual($calls['scale'][0][0], $this->image->getWidth() * 4, 'Width was passed correctly'); + $this->assertEquals($this->image->getWidth() * 4, $calls['scale'][0][0]); } /** * Test the retina scale effect using an image smaller than desired. */ public function testRetinaScaleEffectForcedUpscaling(): void { - $this->assertImageEffect('retina_image_scale', [ + $this->assertImageEffect(['scale'], 'retina_image_scale', [ // Set the desired width to be higher than the image width. 'width' => $this->image->getWidth() * 10, ]); $this->assertToolkitOperationsCalled(['scale']); $calls = $this->imageTestGetAllCalls(); - $this->assertEqual($calls['scale'][0][0], $this->image->getWidth() * 2, 'Width is double the original size.'); + $this->assertEquals($this->image->getWidth() * 2, $calls['scale'][0][0]); } /** * Test the retina scale effect using a multiplier of 3. */ public function testTripleMultiplierRetinaScaleEffect(): void { - $this->assertImageEffect('retina_image_scale', [ + $this->assertImageEffect(['scale'], 'retina_image_scale', [ // Set the desired width to be higher than the image width. 'width' => $this->image->getWidth() * 10, 'multiplier' => 3, @@ -92,21 +114,25 @@ public function testTripleMultiplierRetinaScaleEffect(): void { $this->assertToolkitOperationsCalled(['scale']); $calls = $this->imageTestGetAllCalls(); - $this->assertEqual($calls['scale'][0][0], $this->image->getWidth() * 3, 'Width is triple the original size.'); + $this->assertEquals($this->image->getWidth() * 3, $calls['scale'][0][0]); } /** * Asserts the effect processing of an image effect plugin. * + * @param array $operations + * Array with the operations to be done. * @param string $effect_name * The name of the image effect to test. * @param array $data * The data to pass to the image effect. + * + * @throws \Drupal\Component\Plugin\Exception\PluginException */ - protected function assertImageEffect($effect_name, array $data): void { + protected function assertImageEffect(array $operations, string $effect_name, array $data): void { /** @var \Drupal\image\ImageEffectInterface $effect */ $effect = $this->manager->createInstance($effect_name, ['data' => $data]); - $this->assertTrue($effect->applyEffect($this->image), 'Function returned the expected value.'); + $this->assertTrue($effect->applyEffect($this->image)); } } diff --git a/modules/oe_theme_helper/tests/src/Kernel/TwigExtensionTest.php b/modules/oe_theme_helper/tests/src/Kernel/TwigExtensionTest.php index 1a094ef11..15fa790e7 100644 --- a/modules/oe_theme_helper/tests/src/Kernel/TwigExtensionTest.php +++ b/modules/oe_theme_helper/tests/src/Kernel/TwigExtensionTest.php @@ -54,10 +54,10 @@ public function testSmartTrimFilter(array $variables, array $assertions, array $ if ($metadata) { /** @var \Drupal\Core\Render\BubbleableMetadata $actual_metadata */ $actual_metadata = $context->pop(); - $this->assertEqual($actual_metadata->getAttachments(), $metadata['attachments']); - $this->assertEqual($actual_metadata->getCacheContexts(), $metadata['contexts']); - $this->assertEqual($actual_metadata->getCacheTags(), $metadata['tags']); - $this->assertEqual($actual_metadata->getCacheMaxAge(), $metadata['max_age']); + $this->assertEquals($metadata['attachments'], $actual_metadata->getAttachments()); + $this->assertEquals($metadata['contexts'], $actual_metadata->getCacheContexts()); + $this->assertEquals($metadata['tags'], $actual_metadata->getCacheTags()); + $this->assertEquals($metadata['max_age'], $actual_metadata->getCacheMaxAge()); } $this->assertRendering($output, $assertions); @@ -202,7 +202,7 @@ public function smartTrimFilterDataProvider(): array { ], 'assertions' => [ 'contains' => [ - '
', + 'Lorem ipsum dolor sit...
', ], ], ], diff --git a/modules/oe_theme_helper/tests/src/Traits/ToolkitTestTrait.php b/modules/oe_theme_helper/tests/src/Traits/ToolkitTestTrait.php new file mode 100644 index 000000000..848f19173 --- /dev/null +++ b/modules/oe_theme_helper/tests/src/Traits/ToolkitTestTrait.php @@ -0,0 +1,134 @@ +=')) { + /** + * Wraps the Drupal 9 ToolkitTestTrait trait. + */ + trait ToolkitTestTrait { + + use \Drupal\Tests\Traits\Core\Image\ToolkitTestTrait; + + } +} +else { + /** + * Provides Drupal 8.9 Toolkit kernel tests backward compatibility layer. + * + * This trait is a copy of \Drupal\Tests\Traits\Core\Image\ToolkitTestTrait + * from Drupal >=9.1. + */ + trait ToolkitTestTrait { + + use TestFileCreationTrait { + getTestFiles as drupalGetTestFiles; + } + + /** + * Resets/initializes the history of calls to the test toolkit functions. + */ + protected function imageTestReset(): void { + \Drupal::state()->delete('image_test.results'); + } + + /** + * Asserts that all of the specified image operations are called once. + * + * @param string[] $expected + * Array containing the operation names, e.g. load, save, crop, etc. + */ + public function assertToolkitOperationsCalled(array $expected): void { + // If one of the image operations is expected, 'apply' should be expected + // as well. + $operations = [ + 'resize', + 'rotate', + 'crop', + 'desaturate', + 'create_new', + 'scale', + 'scale_and_crop', + 'my_operation', + 'convert', + ]; + if (count(array_intersect($expected, $operations)) > 0 && !in_array('apply', $expected)) { + $expected[] = 'apply'; + } + + // Determine which operations were called. + $actual = array_keys(array_filter($this->imageTestGetAllCalls())); + + // Determine if there were any expected that were not called. + $uncalled = array_diff($expected, $actual); + $this->assertEmpty($uncalled); + + // Determine if there were any unexpected calls. If all unexpected calls + // are operations and apply was expected, we do not count it as an error. + $unexpected = array_diff($actual, $expected); + $assert = !(count($unexpected) && (!in_array('apply', $expected) || count(array_intersect($unexpected, $operations)) !== count($unexpected))); + $this->assertTrue($assert); + } + + /** + * Gets an array of calls to the 'test' toolkit. + * + * @return array + * An array keyed by operation name ('parseFile', 'save', 'settings', + * 'resize', 'rotate', 'crop', 'desaturate') with values being arrays of + * parameters passed to each call. + */ + protected function imageTestGetAllCalls(): array { + return \Drupal::state()->get('image_test.results', []); + } + + /** + * Sets up an image with the custom toolkit. + * + * @return \Drupal\Core\Image\ImageInterface + * The image object. + */ + protected function getImage(): ImageInterface { + $image_factory = \Drupal::service('image.factory'); + $file = current($this->drupalGetTestFiles('image')); + $image = $image_factory->get($file->uri, 'test'); + $this->assertTrue($image->isValid()); + return $image; + } + + /** + * Asserts the effect processing of an image effect plugin. + * + * @param string[] $expected_operations + * String array containing the operation names, e.g. load, save, etc. + * @param string $effect_name + * The name of the image effect to test. + * @param array $data + * The data to be passed to the image effect. + */ + protected function assertImageEffect(array $expected_operations, string $effect_name, array $data): void { + $effect = $this->imageEffectPluginManager->createInstance($effect_name, ['data' => $data]); + $image = $this->getImage(); + $this->imageTestReset(); + $this->assertTrue($effect->applyEffect($image)); + $this->assertToolkitOperationsCalled($expected_operations); + } + + } +} diff --git a/modules/oe_theme_helper/tests/src/Unit/TwigExtensionTest.php b/modules/oe_theme_helper/tests/src/Unit/TwigExtensionTest.php index ddd3934df..672a71c2d 100644 --- a/modules/oe_theme_helper/tests/src/Unit/TwigExtensionTest.php +++ b/modules/oe_theme_helper/tests/src/Unit/TwigExtensionTest.php @@ -9,7 +9,10 @@ use Drupal\Core\Render\Renderer; use Drupal\Core\Template\Loader\StringLoader; use Drupal\oe_theme_helper\TwigExtension\TwigExtension; +use Drupal\oe_theme_helper\EuropeanUnionLanguages; use Drupal\Tests\UnitTestCase; +use Twig\Environment; +use Twig\Error\RuntimeError; /** * Tests for the custom Twig filters and functions extension. @@ -53,7 +56,7 @@ class TwigExtensionTest extends UnitTestCase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); // It is expected that some filters will request the list of languages. In @@ -81,7 +84,7 @@ protected function setUp() { // For convenience, make a version of the Twig environment available that // has the tested extension preloaded. $loader = new StringLoader(); - $this->twig = new \Twig_Environment($loader); + $this->twig = new Environment($loader); $this->twig->addExtension($this->extension); } @@ -213,7 +216,7 @@ public function testPassingInvalidLanguageCodesToNativeLanguageName($invalid_lan $this->twig->render("{{ '$invalid_language_code'|to_native_language }}"); $this->fail('The expected exception was not thrown.'); } - catch (\Twig_Error_Runtime $e) { + catch (RuntimeError $e) { // Twig wraps any exception that occurs during rendering with its own // runtime exception. Rethrow the original exception so we can verify that // the correct one is being thrown. @@ -256,7 +259,7 @@ public function invalidLanguageCodesProvider(): array { * names as values. */ protected static function getEuropeanUnionLanguageList(): array { - return TwigExtension::getEuropeanUnionLanguageList(); + return EuropeanUnionLanguages::getLanguageList(); } /** diff --git a/modules/oe_theme_list_pages/oe_theme_list_pages.info.yml b/modules/oe_theme_list_pages/oe_theme_list_pages.info.yml index 16f10cb4d..565b378b1 100644 --- a/modules/oe_theme_list_pages/oe_theme_list_pages.info.yml +++ b/modules/oe_theme_list_pages/oe_theme_list_pages.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme List Pages type: module description: Companion module for the OE List Pages module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - extra_field:extra_field - oe_list_pages:oe_list_page_content_type diff --git a/modules/oe_theme_paragraphs_contact/oe_theme_paragraphs_contact.info.yml b/modules/oe_theme_paragraphs_contact/oe_theme_paragraphs_contact.info.yml index abbc3626a..2015c4a70 100644 --- a/modules/oe_theme_paragraphs_contact/oe_theme_paragraphs_contact.info.yml +++ b/modules/oe_theme_paragraphs_contact/oe_theme_paragraphs_contact.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme Paragraphs Contact type: module description: Companion module for the OE Paragraphs Contact module package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 dependencies: - oe_paragraphs:oe_paragraphs_contact - oe_theme:oe_theme_content_entity_contact diff --git a/modules/oe_theme_test/oe_theme_test.info.yml b/modules/oe_theme_test/oe_theme_test.info.yml index c03391278..386d992d8 100644 --- a/modules/oe_theme_test/oe_theme_test.info.yml +++ b/modules/oe_theme_test/oe_theme_test.info.yml @@ -4,7 +4,7 @@ description: 'OpenEuropa theme test module.' package: OpenEuropa hidden: true version: VERSION -core: 8.x +core_version_requirement: ^8.9 || ^9.1 config_devel: install: diff --git a/oe_theme.info.yml b/oe_theme.info.yml index 3669493bc..14b916870 100644 --- a/oe_theme.info.yml +++ b/oe_theme.info.yml @@ -2,7 +2,7 @@ name: OpenEuropa Theme type: theme description: OpenEuropa base theme. package: OpenEuropa -core: 8.x +core_version_requirement: ^8.9 || ^9.1 base theme: stable diff --git a/oe_theme.theme b/oe_theme.theme index a5a4d7a49..e8ca51f6b 100644 --- a/oe_theme.theme +++ b/oe_theme.theme @@ -440,13 +440,20 @@ function oe_theme_preprocess_field(&$variables, $hook): void { * Generates pagination items for ECL pagination component. */ function oe_theme_preprocess_pager(array &$variables): void { + /** @var \Drupal\Core\Pager\PagerManagerInterface $pager_manager */ + $pager_manager = \Drupal::service('pager.manager'); $element = $variables['pager']['#element']; $parameters = $variables['pager']['#parameters']; $route_name = $variables['pager']['#route_name']; $route_parameters = $variables['pager']['#route_parameters'] ?? []; + $pager = $pager_manager->getPager($element); global $pager_page_array, $pager_total; + // Nothing to do if there is no pager. + if (!isset($pager)) { + return; + } // Maximum page number for this pager. - $pager_max = $pager_total[$element]; + $pager_max = $pager->getTotalPages(); // Nothing to do if there is only one page. if ($pager_max <= 1) { return; @@ -455,7 +462,7 @@ function oe_theme_preprocess_pager(array &$variables): void { // The first and last page links are excluded from this count. $pager_offset = 2; // The page we are currently paged to. - $pager_current = $pager_page_array[$element] + 1; + $pager_current = $pager->getCurrentPage() + 1; // First page of the pagination calculated by offset from current. $pager_first = $pager_offset < $pager_current ? $pager_current - $pager_offset : 1; // Last page of the pagination calculated by offset from current. @@ -490,7 +497,7 @@ function oe_theme_preprocess_pager(array &$variables): void { // Add 'Previous' navigation link. if ($pager_current > 1) { $options = [ - 'query' => pager_query_add_page($parameters, $element, $pager_page_array[$element] - 1), + 'query' => $pager_manager->getUpdatedParameters($parameters, $element, $pager->getCurrentPage() - 1), ]; $nav_link['link']['link'] = [ 'path' => Url::fromRoute($route_name, $route_parameters, $options), @@ -505,7 +512,7 @@ function oe_theme_preprocess_pager(array &$variables): void { // Add first page link. if ($pager_first != $pager_current) { $options = [ - 'query' => pager_query_add_page($parameters, $element, 0), + 'query' => $pager_manager->getUpdatedParameters($parameters, $element, 0), ]; $ecl_items[] = [ 'type' => 'first', @@ -540,7 +547,7 @@ function oe_theme_preprocess_pager(array &$variables): void { continue; } $options = [ - 'query' => pager_query_add_page($parameters, $element, $i - 1), + 'query' => $pager_manager->getUpdatedParameters($parameters, $element, $i - 1), ]; $ecl_items[] = [ 'link' => [ @@ -562,7 +569,7 @@ function oe_theme_preprocess_pager(array &$variables): void { // Add last page link. if ($pager_max != $pager_current) { $options = [ - 'query' => pager_query_add_page($parameters, $element, $pager_max - 1), + 'query' => $pager_manager->getUpdatedParameters($parameters, $element, $pager_max - 1), ]; $ecl_items[] = [ 'type' => 'last', @@ -579,7 +586,7 @@ function oe_theme_preprocess_pager(array &$variables): void { // Add 'Next' navigation link. if ($pager_current < $pager_max) { $options = [ - 'query' => pager_query_add_page($parameters, $element, $pager_page_array[$element] + 1), + 'query' => $pager_manager->getUpdatedParameters($parameters, $element, $pager->getCurrentPage() + 1), ]; $nav_link['link']['link'] = [ 'path' => Url::fromRoute($route_name, $route_parameters, $options), diff --git a/package.json b/package.json index e5762d4c9..55257a0dd 100644 --- a/package.json +++ b/package.json @@ -14,52 +14,52 @@ "prepare": "patch-package" }, "dependencies": { - "@ecl/builder": "3.0.2", - "@ecl/twig-component-accordion": "3.0.2", - "@ecl/twig-component-blockquote": "3.0.2", - "@ecl/twig-component-breadcrumb-core": "3.0.2", - "@ecl/twig-component-breadcrumb-standardised": "3.0.2", - "@ecl/twig-component-button": "3.0.2", - "@ecl/twig-component-card": "3.0.2", - "@ecl/twig-component-description-list": "3.0.2", - "@ecl/twig-component-expandable": "3.0.2", - "@ecl/twig-component-fact-figures": "3.0.2", - "@ecl/twig-component-file": "3.0.2", - "@ecl/twig-component-footer-core": "3.0.2", - "@ecl/twig-component-footer-standardised": "3.0.2", - "@ecl/twig-component-gallery": "3.0.2", - "@ecl/twig-component-hero-banner": "3.0.2", - "@ecl/twig-component-icon": "3.0.2", - "@ecl/twig-component-inpage-navigation": "3.0.2", - "@ecl/twig-component-language-list": "3.0.2", - "@ecl/twig-component-link": "3.0.2", - "@ecl/twig-component-media-container": "3.0.2", - "@ecl/twig-component-menu": "3.0.2", - "@ecl/twig-component-message": "3.0.2", - "@ecl/twig-component-page-banner": "3.0.2", - "@ecl/twig-component-page-header-core": "3.0.2", - "@ecl/twig-component-page-header-standardised": "3.0.2", - "@ecl/twig-component-pagination": "3.0.2", - "@ecl/twig-component-radio": "3.0.2", - "@ecl/twig-component-search-form": "3.0.2", - "@ecl/twig-component-site-header-core": "3.0.2", - "@ecl/twig-component-site-header-standardised": "3.0.2", - "@ecl/twig-component-skip-link": "3.0.2", - "@ecl/twig-component-social-media-follow": "3.0.2", - "@ecl/twig-component-social-media-share": "3.0.2", - "@ecl/twig-component-table": "3.0.2", - "@ecl/twig-component-tag": "3.0.2", - "@ecl/twig-component-text-input": "3.0.2", - "@ecl/twig-component-timeline": "3.0.2", - "@ecl/twig-component-datepicker": "3.0.2", - "@ecl/preset-reset": "3.0.2", - "@ecl/preset-ec": "3.0.2", - "@ecl/preset-eu": "3.0.2", - "@ecl/theme-ec": "3.0.2", - "@ecl/theme-eu": "3.0.2", - "@ecl/vanilla-utility-background": "3.0.2", - "@ecl/vanilla-utility-border": "3.0.2", + "@ecl/builder": "3.1.2", + "@ecl/preset-ec": "3.1.2", + "@ecl/preset-eu": "3.1.2", + "@ecl/preset-reset": "3.1.2", "@ecl/stylelint-config": "0.2.1", + "@ecl/theme-ec": "3.1.2", + "@ecl/theme-eu": "3.1.2", + "@ecl/twig-component-accordion": "3.1.2", + "@ecl/twig-component-blockquote": "3.1.2", + "@ecl/twig-component-breadcrumb-core": "3.1.2", + "@ecl/twig-component-breadcrumb-standardised": "3.1.2", + "@ecl/twig-component-button": "3.1.2", + "@ecl/twig-component-card": "3.1.2", + "@ecl/twig-component-datepicker": "3.1.2", + "@ecl/twig-component-description-list": "3.1.2", + "@ecl/twig-component-expandable": "3.1.2", + "@ecl/twig-component-fact-figures": "3.1.2", + "@ecl/twig-component-file": "3.1.2", + "@ecl/twig-component-footer-core": "3.1.2", + "@ecl/twig-component-footer-standardised": "3.1.2", + "@ecl/twig-component-gallery": "3.1.2", + "@ecl/twig-component-hero-banner": "3.1.2", + "@ecl/twig-component-icon": "3.1.2", + "@ecl/twig-component-inpage-navigation": "3.1.2", + "@ecl/twig-component-language-list": "3.1.2", + "@ecl/twig-component-link": "3.1.2", + "@ecl/twig-component-media-container": "3.1.2", + "@ecl/twig-component-menu": "3.1.2", + "@ecl/twig-component-message": "3.1.2", + "@ecl/twig-component-page-banner": "3.1.2", + "@ecl/twig-component-page-header-core": "3.1.2", + "@ecl/twig-component-page-header-standardised": "3.1.2", + "@ecl/twig-component-pagination": "3.1.2", + "@ecl/twig-component-radio": "3.1.2", + "@ecl/twig-component-search-form": "3.1.2", + "@ecl/twig-component-site-header-core": "3.1.2", + "@ecl/twig-component-site-header-standardised": "3.1.2", + "@ecl/twig-component-skip-link": "3.1.2", + "@ecl/twig-component-social-media-follow": "3.1.2", + "@ecl/twig-component-social-media-share": "3.1.2", + "@ecl/twig-component-table": "3.1.2", + "@ecl/twig-component-tag": "3.1.2", + "@ecl/twig-component-text-input": "3.1.2", + "@ecl/twig-component-timeline": "3.1.2", + "@ecl/vanilla-utility-background": "3.1.2", + "@ecl/vanilla-utility-border": "3.1.2", "chokidar-cli": "1.2.0", "grunt": "^1.4.0", "grunt-contrib-copy": "^1.0.0", diff --git a/patches/@ecl/twig-component-card+3.0.2.patch b/patches/@ecl/twig-component-card+3.1.2.patch similarity index 88% rename from patches/@ecl/twig-component-card+3.0.2.patch rename to patches/@ecl/twig-component-card+3.1.2.patch index 692770ac0..b8298ca68 100644 --- a/patches/@ecl/twig-component-card+3.0.2.patch +++ b/patches/@ecl/twig-component-card+3.1.2.patch @@ -1,9 +1,9 @@ patch-package --- a/node_modules/@ecl/twig-component-card/card.html.twig +++ b/node_modules/@ecl/twig-component-card/card.html.twig -@@ -99,7 +99,7 @@ - -Lorem ipsum dolor sit...
Press contact body text
', trim($crawler->filter('div.ecl-col-12:nth-child(2) div.ecl-u-mb-l div.ecl')->html())); diff --git a/tests/Kernel/Paragraphs/ContentRowTest.php b/tests/src/Kernel/Paragraphs/ContentRowTest.php similarity index 83% rename from tests/Kernel/Paragraphs/ContentRowTest.php rename to tests/src/Kernel/Paragraphs/ContentRowTest.php index 2dde8cfb4..849df1259 100644 --- a/tests/Kernel/Paragraphs/ContentRowTest.php +++ b/tests/src/Kernel/Paragraphs/ContentRowTest.php @@ -97,16 +97,16 @@ public function testRendering(): void { // Verify that there is a full size column rendered. $this->assertCount(1, $crawler->filter('.ecl-row .ecl-col-m-12')); // Do a smoke test that inner paragraphs are rendered. - $this->assertContains('Links block title', $html); - $this->assertContains('List item title', $html); - $this->assertContains('List block title', $html); - $this->assertContains('Rich text without title.', $html); - $this->assertContains('Rich text with title.', $html); + $this->assertStringContainsString('Links block title', $html); + $this->assertStringContainsString('List item title', $html); + $this->assertStringContainsString('List block title', $html); + $this->assertStringContainsString('Rich text without title.', $html); + $this->assertStringContainsString('Rich text with title.', $html); // No page navigation should be shown. $this->assertCount(0, $crawler->filter('.ecl-inpage-navigation')); // Neither the title. - $this->assertNotContains('Page navigation', $html); + $this->assertStringNotContainsString('Page navigation', $html); // Change variant to the inpage navigation. $paragraph->get('oe_paragraphs_variant')->setValue('inpage_navigation'); @@ -121,11 +121,11 @@ public function testRendering(): void { // Verify that the right column still contains all the paragraphs. $right_column_html = $right_column->html(); - $this->assertContains('Links block title', $right_column_html); - $this->assertContains('List item title', $right_column_html); - $this->assertContains('List block title', $right_column_html); - $this->assertContains('Rich text without title.', $right_column_html); - $this->assertContains('Rich text with title.', $right_column_html); + $this->assertStringContainsString('Links block title', $right_column_html); + $this->assertStringContainsString('List item title', $right_column_html); + $this->assertStringContainsString('List block title', $right_column_html); + $this->assertStringContainsString('Rich text without title.', $right_column_html); + $this->assertStringContainsString('Rich text with title.', $right_column_html); // Verify that the inpage navigation title has been rendered. $this->assertEquals('Page navigation', trim($left_column->filter('.ecl-inpage-navigation__title')->text())); @@ -146,7 +146,7 @@ public function testRendering(): void { // Assert that side-menu is correctly rendered with the default title. $left_column = $crawler->filter('.ecl-row .ecl-col-l-3.ecl-u-z-navigation'); - $this->assertContains('Page contents', $left_column->html()); + $this->assertStringContainsString('Page contents', $left_column->html()); } /** @@ -186,16 +186,16 @@ public function testSideMenuTranslation(): void { // Assert that side-menu "English" translation is correctly rendered. $left_column = $crawler->filter('.ecl-row .ecl-col-l-3.ecl-u-z-navigation'); - $this->assertContains('English page navigation', $left_column->html()); - $this->assertContains('English rich text title', $left_column->html()); + $this->assertStringContainsString('English page navigation', $left_column->html()); + $this->assertStringContainsString('English rich text title', $left_column->html()); $html = $this->renderParagraph($paragraph, 'fr'); $crawler = new Crawler($html); // Assert that side-menu "French" translation is correctly rendered. $left_column = $crawler->filter('.ecl-row .ecl-col-l-3.ecl-u-z-navigation'); - $this->assertContains('French page navigation', $left_column->html()); - $this->assertContains('French rich text title', $left_column->html()); + $this->assertStringContainsString('French page navigation', $left_column->html()); + $this->assertStringContainsString('French rich text title', $left_column->html()); } /** @@ -211,7 +211,7 @@ public function testSideMenuTranslation(): void { protected function assertNavigationItem(Crawler $item, string $title, Crawler $content) { $link = $item->filter('a'); $this->assertEquals($title, trim($link->text())); - $this->assertContains($title, $content->filter($link->attr('href'))->html()); + $this->assertStringContainsString($title, $content->filter($link->attr('href'))->html()); } } diff --git a/tests/Kernel/Paragraphs/MediaParagraphsTest.php b/tests/src/Kernel/Paragraphs/MediaParagraphsTest.php similarity index 90% rename from tests/Kernel/Paragraphs/MediaParagraphsTest.php rename to tests/src/Kernel/Paragraphs/MediaParagraphsTest.php index 0bfaa63de..5062b393d 100644 --- a/tests/Kernel/Paragraphs/MediaParagraphsTest.php +++ b/tests/src/Kernel/Paragraphs/MediaParagraphsTest.php @@ -40,7 +40,7 @@ class MediaParagraphsTest extends ParagraphsTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->container->get('module_handler')->loadInclude('oe_paragraphs_media_field_storage', 'install'); @@ -250,7 +250,7 @@ public function testTextWithMedia(): void { 'url' => 'https://www.youtube.com/watch?v=1-g73ty9v04', ], ])->toString(); - $this->assertContains($partial_iframe_url, $video_iframe->attr('src')); + $this->assertStringContainsString($partial_iframe_url, $video_iframe->attr('src')); // Create an avportal video and add it to the paragraph. $media = $media_storage->create([ @@ -451,14 +451,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image.ecl-hero-banner--centered')); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image.ecl-hero-banner--centered div.ecl-hero-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-hero-banner--full-width')); // Render paragraph in Bulgarian. @@ -466,7 +466,7 @@ public function testBanner(): void { $crawler = new Crawler($html); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image.ecl-hero-banner--centered div.ecl-hero-banner__image'); // Bulgarian media should be rendered. - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($bg_file->getFileUri()) . ')', $image_element->attr('style') ); @@ -502,14 +502,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image')); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image div.ecl-hero-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-hero-banner--full-width')); // Variant - image / Modifier - page_center / Full width - No. @@ -521,14 +521,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-page-banner.ecl-page-banner--image.ecl-page-banner--centered')); $image_element = $crawler->filter('section.ecl-page-banner.ecl-page-banner--image.ecl-page-banner--centered div.ecl-page-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-page-banner--full-width')); // Variant - image / Modifier - page_left / Full width - Yes. @@ -542,14 +542,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-page-banner.ecl-page-banner--image.ecl-page-banner--full-width')); $image_element = $crawler->filter('section.ecl-page-banner.ecl-page-banner--image div.ecl-page-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - image-shade / Modifier - hero_center / Full width - Yes. $paragraph->get('oe_paragraphs_variant')->setValue('oe_banner_image_shade'); @@ -561,14 +561,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image-shade.ecl-hero-banner--centered.ecl-hero-banner--full-width')); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image-shade.ecl-hero-banner--centered div.ecl-hero-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - image-shade / Modifier - hero_left / Full width - Yes. $paragraph->get('field_oe_banner_type')->setValue('hero_left'); @@ -580,14 +580,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image-shade.ecl-hero-banner--full-width')); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image-shade div.ecl-hero-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - image-shade / Modifier - page_center / Full width - No. $paragraph->get('field_oe_banner_type')->setValue('page_center'); @@ -599,14 +599,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-page-banner.ecl-page-banner--image-shade.ecl-page-banner--centered')); $image_element = $crawler->filter('section.ecl-page-banner.ecl-page-banner--image-shade.ecl-page-banner--centered div.ecl-page-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-page-banner--full-width')); // Variant - image-shade / Modifier - page_left / Full width - No. @@ -619,14 +619,14 @@ public function testBanner(): void { $this->assertCount(1, $crawler->filter('section.ecl-page-banner.ecl-page-banner--image-shade')); $image_element = $crawler->filter('section.ecl-page-banner.ecl-page-banner--image-shade div.ecl-page-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . file_create_url($en_file->getFileUri()) . ')', $image_element->attr('style') ); $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-page-banner--full-width')); // Variant - default / Modifier - hero_center / Full width - No. @@ -647,7 +647,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-hero-banner--full-width')); // Variant - default / Modifier - hero_left / Full width - Yes. @@ -669,7 +669,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - default / Modifier - page_center / Full width - Yes. $paragraph->get('field_oe_banner_type')->setValue('page_center'); @@ -688,7 +688,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - default / Modifier - page_left / Full width - Yes. $paragraph->get('field_oe_banner_type')->setValue('page_left'); @@ -708,7 +708,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - primary / Modifier - hero_center / Full width - Yes. $paragraph->get('oe_paragraphs_variant')->setValue('oe_banner_primary'); @@ -728,7 +728,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - primary / Modifier - hero_left / Full width - Yes. $paragraph->get('field_oe_banner_type')->setValue('hero_left'); @@ -748,7 +748,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-hero-banner__content div.ecl-hero-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-hero-banner__content p.ecl-hero-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-hero-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - primary / Modifier - page_center / Full width - Yes. $paragraph->get('field_oe_banner_type')->setValue('page_center'); @@ -767,7 +767,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); // Variant - primary / Modifier - page_left / Full width - No. $paragraph->get('field_oe_banner_type')->setValue('page_left'); @@ -788,7 +788,7 @@ public function testBanner(): void { $this->assertEquals('Banner', trim($crawler->filter('div.ecl-page-banner__content div.ecl-page-banner__title')->text())); $this->assertEquals('Description', trim($crawler->filter('div.ecl-page-banner__content p.ecl-page-banner__description')->text())); $this->assertCount(1, $crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after')); - $this->assertContains('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); + $this->assertStringContainsString('Example', trim($crawler->filter('div.ecl-page-banner__content a.ecl-link.ecl-link--cta.ecl-link--icon.ecl-link--icon-after span.ecl-link__label')->text())); $this->assertCount(0, $crawler->filter('.ecl-page-banner--full-width')); // Create a media using AV Portal image and add it to the paragraph. @@ -820,7 +820,7 @@ public function testBanner(): void { $this->assertCount(0, $crawler->filter('div.ecl-page-banner__content a.ecl-link')); $image_element = $crawler->filter('section.ecl-hero-banner.ecl-hero-banner--image.ecl-hero-banner--centered div.ecl-hero-banner__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( 'url(' . (file_create_url('avportal://P-038924/00-15.jpg')) . ')', $image_element->attr('style') ); @@ -861,9 +861,9 @@ public function testIframe(): void { // Assert unpublished media isn't shown. $html = $this->renderParagraph($paragraph); - $this->assertNotContains('figure', $html); - $this->assertNotContains('http://example.com/iframe', $html); - $this->assertNotContains('ecl-u-type-heading-2', $html); + $this->assertStringNotContainsString('figure', $html); + $this->assertStringNotContainsString('http://example.com/iframe', $html); + $this->assertStringNotContainsString('ecl-u-type-heading-2', $html); // Publish media. $media->setPublished()->save(); @@ -873,22 +873,22 @@ public function testIframe(): void { $html = $this->renderParagraph($paragraph); $crawler = new Crawler($html); $iframe = $crawler->filter('figure.ecl-media-container.ecl-media-container--custom-ratio div.ecl-media-container__media.ecl-media-container__media--ratio-custom iframe'); - $this->assertContains('http://example.com/iframe', $iframe->attr('src')); - $this->assertNotContains('ecl-u-type-heading-2', $html); + $this->assertStringContainsString('http://example.com/iframe', $iframe->attr('src')); + $this->assertStringNotContainsString('ecl-u-type-heading-2', $html); // Assert "Full width" field. $paragraph->set('field_oe_iframe_media_full_width', TRUE)->save(); $html = $this->renderParagraph($paragraph); $crawler = new Crawler($html); $iframe = $crawler->filter('figure.ecl-media-container.ecl-media-container--fullwidth.ecl-media-container--custom-ratio div.ecl-media-container__media.ecl-media-container__media--ratio-custom iframe'); - $this->assertContains('http://example.com/iframe', $iframe->attr('src')); + $this->assertStringContainsString('http://example.com/iframe', $iframe->attr('src')); // Assert ratio. $media->set('oe_media_iframe_ratio', '1_1')->save(); $html = $this->renderParagraph($paragraph); $crawler = new Crawler($html); $iframe = $crawler->filter('figure.ecl-media-container.ecl-media-container--fullwidth div.ecl-media-container__media.ecl-media-container__media--ratio-1-1 iframe'); - $this->assertContains('http://example.com/iframe', $iframe->attr('src')); + $this->assertStringContainsString('http://example.com/iframe', $iframe->attr('src')); // Assert title and full width. $paragraph->set('field_oe_title', 'Iframe paragraph title'); @@ -896,9 +896,9 @@ public function testIframe(): void { $html = $this->renderParagraph($paragraph); $crawler = new Crawler($html); $title = $crawler->filter('h2.ecl-u-type-heading-2', $html); - $this->assertContains('Iframe paragraph title', $title->text()); + $this->assertStringContainsString('Iframe paragraph title', $title->text()); $iframe = $crawler->filter('figure.ecl-media-container div.ecl-media-container__media.ecl-media-container__media--ratio-1-1 iframe'); - $this->assertContains('http://example.com/iframe', $iframe->attr('src')); + $this->assertStringContainsString('http://example.com/iframe', $iframe->attr('src')); // Translate the media to Bulgarian. $media_bg = $media->addTranslation('bg', [ @@ -914,9 +914,9 @@ public function testIframe(): void { $html = $this->renderParagraph($paragraph, 'bg'); $crawler = new Crawler($html); $title = $crawler->filter('h2.ecl-u-type-heading-2', $html); - $this->assertContains('Iframe paragraph title bg', $title->text()); + $this->assertStringContainsString('Iframe paragraph title bg', $title->text()); $iframe = $crawler->filter('figure.ecl-media-container div.ecl-media-container__media.ecl-media-container__media--ratio-1-1 iframe'); - $this->assertContains('http://example.com/iframe_bg', $iframe->attr('src')); + $this->assertStringContainsString('http://example.com/iframe_bg', $iframe->attr('src')); } } diff --git a/tests/Kernel/Paragraphs/ParagraphsTest.php b/tests/src/Kernel/Paragraphs/ParagraphsTest.php similarity index 98% rename from tests/Kernel/Paragraphs/ParagraphsTest.php rename to tests/src/Kernel/Paragraphs/ParagraphsTest.php index 7050d302a..47ce5e18a 100644 --- a/tests/Kernel/Paragraphs/ParagraphsTest.php +++ b/tests/src/Kernel/Paragraphs/ParagraphsTest.php @@ -130,10 +130,10 @@ public function testQuote(array $data, array $expected): void { $crawler = new Crawler($html); - $actual = $crawler->filter('blockquote.ecl-blockquote .ecl-blockquote__body')->html(); + $actual = $crawler->filter('figure.ecl-blockquote .ecl-blockquote__body blockquote.ecl-blockquote__quote p.ecl-blockquote__citation')->html(); $this->assertEquals($expected['body'], trim($actual)); - $actual = $crawler->filter('blockquote.ecl-blockquote footer.ecl-blockquote__attribution cite.ecl-blockquote__author')->text(); + $actual = $crawler->filter('figure.ecl-blockquote footer.ecl-blockquote__attribution cite.ecl-blockquote__author')->text(); $this->assertEquals($expected['attribution'], trim($actual)); } @@ -216,7 +216,7 @@ public function testListItem(): void { $image_element = $crawler->filter('article.ecl-card div.ecl-card__image'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( file_url_transform_relative(file_create_url($image->getFileUri())), $image_element->attr('style') ); @@ -269,7 +269,7 @@ public function testListItem(): void { $this->assertCount(0, $crawler->filter('article.ecl-content-item > div.ecl-content-item__image__after')); $image_element = $crawler->filter('article.ecl-content-item > div[role="img"].ecl-u-d-l-block'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( file_url_transform_relative(file_create_url($image->getFileUri())), $image_element->attr('style') ); @@ -303,7 +303,7 @@ public function testListItem(): void { $this->assertCount(1, $crawler->filter('article.ecl-content-item > div.ecl-content-item__image__after')); $image_element = $crawler->filter('article.ecl-content-item > div[role="img"].ecl-u-d-l-block'); $this->assertCount(1, $image_element); - $this->assertContains( + $this->assertStringContainsString( file_url_transform_relative(file_create_url($image->getFileUri())), $image_element->attr('style') ); diff --git a/tests/Kernel/Paragraphs/ParagraphsTestBase.php b/tests/src/Kernel/Paragraphs/ParagraphsTestBase.php similarity index 98% rename from tests/Kernel/Paragraphs/ParagraphsTestBase.php rename to tests/src/Kernel/Paragraphs/ParagraphsTestBase.php index 34c44dae4..7ed34efc8 100644 --- a/tests/Kernel/Paragraphs/ParagraphsTestBase.php +++ b/tests/src/Kernel/Paragraphs/ParagraphsTestBase.php @@ -41,7 +41,7 @@ abstract class ParagraphsTestBase extends AbstractKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('paragraph'); diff --git a/tests/Kernel/Paragraphs/SocialMediaFollowTest.php b/tests/src/Kernel/Paragraphs/SocialMediaFollowTest.php similarity index 86% rename from tests/Kernel/Paragraphs/SocialMediaFollowTest.php rename to tests/src/Kernel/Paragraphs/SocialMediaFollowTest.php index c4b301718..066531bde 100644 --- a/tests/Kernel/Paragraphs/SocialMediaFollowTest.php +++ b/tests/src/Kernel/Paragraphs/SocialMediaFollowTest.php @@ -53,34 +53,34 @@ public function testRendering(): void { // Verify that the paragraph contains all the links. $links_html = $links->html(); - $this->assertContains('Email', $links_html); + $this->assertStringContainsString('Email', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 5) = \'#email\']')); // Assert that the Facebook link is rendered but not the Facebook icon, as // this link has no type associated. - $this->assertContains('Facebook', $links_html); + $this->assertStringContainsString('Facebook', $links_html); $this->assertCount(0, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 8) = \'#facebook\']')); - $this->assertContains('Flickr', $links_html); + $this->assertStringContainsString('Flickr', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 6) = \'#flickr\']')); - $this->assertContains('Google+', $links_html); + $this->assertStringContainsString('Google+', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 6) = \'#google\']')); - $this->assertContains('Instagram', $links_html); + $this->assertStringContainsString('Instagram', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 9) = \'#instagram\']')); - $this->assertContains('LinkedIn', $links_html); + $this->assertStringContainsString('LinkedIn', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 8) = \'#linkedin\']')); - $this->assertContains('Pinterest', $links_html); + $this->assertStringContainsString('Pinterest', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 9) = \'#pinterest\']')); - $this->assertContains('RSS', $links_html); + $this->assertStringContainsString('RSS', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 3) = \'#rss\']')); - $this->assertContains('Storify', $links_html); + $this->assertStringContainsString('Storify', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 7) = \'#storify\']')); - $this->assertContains('1st Twitter', $links_html); - $this->assertContains('2nd Twitter', $links_html); + $this->assertStringContainsString('1st Twitter', $links_html); + $this->assertStringContainsString('2nd Twitter', $links_html); $this->assertCount(2, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 7) = \'#twitter\']')); - $this->assertContains('Yammer', $links_html); + $this->assertStringContainsString('Yammer', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 6) = \'#yammer\']')); - $this->assertContains('Youtube', $links_html); + $this->assertStringContainsString('Youtube', $links_html); $this->assertCount(1, $crawler->filterXPath('//*[name()=\'use\' and substring(@*, string-length(@*) - 7) = \'#youtube\']')); - $this->assertContains('Other social networks', $links_html); + $this->assertStringContainsString('Other social networks', $links_html); // Fix the Facebook link type. $paragraph->get('field_oe_social_media_links')->get(1)->set('link_type', 'facebook'); diff --git a/tests/Kernel/Paragraphs/TimelineParagraphTest.php b/tests/src/Kernel/Paragraphs/TimelineParagraphTest.php similarity index 99% rename from tests/Kernel/Paragraphs/TimelineParagraphTest.php rename to tests/src/Kernel/Paragraphs/TimelineParagraphTest.php index ff957d007..ae3ddaf35 100644 --- a/tests/Kernel/Paragraphs/TimelineParagraphTest.php +++ b/tests/src/Kernel/Paragraphs/TimelineParagraphTest.php @@ -27,7 +27,7 @@ class TimelineParagraphTest extends ParagraphsTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installConfig([ diff --git a/tests/Kernel/Patterns/DateBlockPatternRenderingTest.php b/tests/src/Kernel/Patterns/DateBlockPatternRenderingTest.php similarity index 100% rename from tests/Kernel/Patterns/DateBlockPatternRenderingTest.php rename to tests/src/Kernel/Patterns/DateBlockPatternRenderingTest.php diff --git a/tests/Kernel/Patterns/FilePatternRenderingTest.php b/tests/src/Kernel/Patterns/FilePatternRenderingTest.php similarity index 97% rename from tests/Kernel/Patterns/FilePatternRenderingTest.php rename to tests/src/Kernel/Patterns/FilePatternRenderingTest.php index 28a7dbd57..1277bbcf7 100644 --- a/tests/Kernel/Patterns/FilePatternRenderingTest.php +++ b/tests/src/Kernel/Patterns/FilePatternRenderingTest.php @@ -26,7 +26,7 @@ class FilePatternRenderingTest extends AbstractKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('file'); $this->installSchema('file', ['file_usage']); diff --git a/tests/Kernel/Patterns/LinkPatternRenderingTest.php b/tests/src/Kernel/Patterns/LinkPatternRenderingTest.php similarity index 100% rename from tests/Kernel/Patterns/LinkPatternRenderingTest.php rename to tests/src/Kernel/Patterns/LinkPatternRenderingTest.php diff --git a/tests/Kernel/Patterns/OrganisationTeaserPatternRenderingTest.php b/tests/src/Kernel/Patterns/OrganisationTeaserPatternRenderingTest.php similarity index 100% rename from tests/Kernel/Patterns/OrganisationTeaserPatternRenderingTest.php rename to tests/src/Kernel/Patterns/OrganisationTeaserPatternRenderingTest.php diff --git a/tests/Kernel/Patterns/PageHeaderRenderingTest.php b/tests/src/Kernel/Patterns/PageHeaderRenderingTest.php similarity index 100% rename from tests/Kernel/Patterns/PageHeaderRenderingTest.php rename to tests/src/Kernel/Patterns/PageHeaderRenderingTest.php diff --git a/tests/Kernel/PersonRenderTest.php b/tests/src/Kernel/PersonRenderTest.php similarity index 99% rename from tests/Kernel/PersonRenderTest.php rename to tests/src/Kernel/PersonRenderTest.php index 42931b384..b06ae2621 100644 --- a/tests/Kernel/PersonRenderTest.php +++ b/tests/src/Kernel/PersonRenderTest.php @@ -39,11 +39,13 @@ class PersonRenderTest extends ContentRenderTestBase { 'oe_content_organisation', 'oe_content_organisation_reference', 'oe_content_social_media_links_field', + 'oe_content_sub_entity', 'oe_content_sub_entity_document_reference', 'oe_theme_content_organisation', 'oe_theme_content_organisation_reference', 'oe_theme_content_person', 'description_list_field', + 'oe_content_sub_entity', ]; /** diff --git a/tests/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php b/tests/src/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php similarity index 80% rename from tests/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php rename to tests/src/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php index 26b168406..9403e10c0 100644 --- a/tests/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php +++ b/tests/src/Kernel/Plugin/Condition/CurrentComponentLibraryConditionTest.php @@ -30,9 +30,9 @@ public function testCondition(): void { 'negate' => TRUE, ]); - $this->assertEqual($condition->summary(), new FormattableMarkup('The current component library is @component_library', ['@component_library' => 'ec'])); - $this->assertEqual($condition_empty->summary(), new FormattableMarkup('The current component library can be set to anything', [])); - $this->assertEqual($condition_negated->summary(), new FormattableMarkup('The current component library is not @component_library', ['@component_library' => 'ec'])); + $this->assertEquals(new FormattableMarkup('The current component library is @component_library', ['@component_library' => 'ec']), $condition->summary()); + $this->assertEquals(new FormattableMarkup('The current component library can be set to anything', []), $condition_empty->summary()); + $this->assertEquals(new FormattableMarkup('The current component library is not @component_library', ['@component_library' => 'ec']), $condition_negated->summary()); // Assert condition values, by default the component library set to "ec". $this->assertTrue($condition->execute(), 'Condition asserting that component library is "ec" should be true.'); diff --git a/tests/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php b/tests/src/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php similarity index 81% rename from tests/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php rename to tests/src/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php index c800a6505..2dc7cd540 100644 --- a/tests/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php +++ b/tests/src/Kernel/Plugin/Condition/CurrentEclBrandingConditionTest.php @@ -30,9 +30,9 @@ public function testCondition(): void { 'negate' => TRUE, ]); - $this->assertEqual($condition->summary(), new FormattableMarkup('The current ECL branding is @branding', ['@branding' => 'standardised'])); - $this->assertEqual($condition_empty->summary(), new FormattableMarkup('The current ECL branding can be set to anything', [])); - $this->assertEqual($condition_negated->summary(), new FormattableMarkup('The current ECL branding is not @branding', ['@branding' => 'standardised'])); + $this->assertEquals(new FormattableMarkup('The current ECL branding is @branding', ['@branding' => 'standardised']), $condition->summary()); + $this->assertEquals(new FormattableMarkup('The current ECL branding can be set to anything', []), $condition_empty->summary()); + $this->assertEquals(new FormattableMarkup('The current ECL branding is not @branding', ['@branding' => 'standardised']), $condition_negated->summary()); // Assert condition values, by default ECL branding set to "Standardised". $this->assertFalse($condition->execute(), 'Condition asserting that ECL branding is "standardised" should be false.'); diff --git a/tests/Kernel/ProjectRenderTest.php b/tests/src/Kernel/ProjectRenderTest.php similarity index 100% rename from tests/Kernel/ProjectRenderTest.php rename to tests/src/Kernel/ProjectRenderTest.php diff --git a/tests/Kernel/PublicationRenderTest.php b/tests/src/Kernel/PublicationRenderTest.php similarity index 100% rename from tests/Kernel/PublicationRenderTest.php rename to tests/src/Kernel/PublicationRenderTest.php diff --git a/tests/Kernel/RenderingTest.php b/tests/src/Kernel/RenderingTest.php similarity index 98% rename from tests/Kernel/RenderingTest.php rename to tests/src/Kernel/RenderingTest.php index 1ff01f05f..3e724aa13 100644 --- a/tests/Kernel/RenderingTest.php +++ b/tests/src/Kernel/RenderingTest.php @@ -28,7 +28,7 @@ class RenderingTest extends AbstractKernelTestBase implements FormInterface { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installConfig('filter'); } diff --git a/tests/Kernel/SearchFormBlockTest.php b/tests/src/Kernel/SearchFormBlockTest.php similarity index 100% rename from tests/Kernel/SearchFormBlockTest.php rename to tests/src/Kernel/SearchFormBlockTest.php diff --git a/tests/Kernel/StatusMessagesTest.php b/tests/src/Kernel/StatusMessagesTest.php similarity index 99% rename from tests/Kernel/StatusMessagesTest.php rename to tests/src/Kernel/StatusMessagesTest.php index 7ebb0954c..eda4f4655 100644 --- a/tests/Kernel/StatusMessagesTest.php +++ b/tests/src/Kernel/StatusMessagesTest.php @@ -89,7 +89,7 @@ public function testStatusMessages(array $data): void { $wrapper, sprintf('No messages of type "%s" were expected, but %d found.', $type, $wrapper->count()) ); - $this->assertNotContains( + $this->assertStringNotContainsString( $info['heading'], $html, 'No messages of type "%s" are present, but the related heading "%s" was found.', $type, $info['heading'] diff --git a/tests/Kernel/TablesTest.php b/tests/src/Kernel/TablesTest.php similarity index 100% rename from tests/Kernel/TablesTest.php rename to tests/src/Kernel/TablesTest.php diff --git a/tests/Kernel/TimelineTest.php b/tests/src/Kernel/TimelineTest.php similarity index 95% rename from tests/Kernel/TimelineTest.php rename to tests/src/Kernel/TimelineTest.php index 548ea9db0..3b13a2048 100644 --- a/tests/Kernel/TimelineTest.php +++ b/tests/src/Kernel/TimelineTest.php @@ -84,7 +84,7 @@ protected function setUp(): void { $this->installEntitySchema('skos_concept_scheme'); $this->container->get('theme_installer')->install(['oe_theme']); - $this->container->get('theme_handler')->setDefault('oe_theme'); + $this->config('system.theme')->set('default', 'oe_theme')->save(); $this->container->set('theme.registry', NULL); // Create content type. @@ -199,8 +199,8 @@ public function testTimelineRender(): void { $build = $display->build($node); $output = $this->renderRoot($build); - $this->assertNotContains('.ecl-timeline__item--toggle', (string) $output); - $this->assertNotContains('.ecl-timeline__item--collapsed', (string) $output); + $this->assertStringNotContainsString('.ecl-timeline__item--toggle', (string) $output); + $this->assertStringNotContainsString('.ecl-timeline__item--collapsed', (string) $output); } } diff --git a/tests/Kernel/ValueObject/DateTimeRangeTest.php b/tests/src/Kernel/ValueObject/DateTimeRangeTest.php similarity index 98% rename from tests/Kernel/ValueObject/DateTimeRangeTest.php rename to tests/src/Kernel/ValueObject/DateTimeRangeTest.php index ce7705a59..ff1e37d60 100644 --- a/tests/Kernel/ValueObject/DateTimeRangeTest.php +++ b/tests/src/Kernel/ValueObject/DateTimeRangeTest.php @@ -37,7 +37,7 @@ class DateTimeRangeTest extends DateTimeTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); // Add a datetime range field. diff --git a/tests/Kernel/ValueObject/DateTimeTest.php b/tests/src/Kernel/ValueObject/DateTimeTest.php similarity index 98% rename from tests/Kernel/ValueObject/DateTimeTest.php rename to tests/src/Kernel/ValueObject/DateTimeTest.php index f1bd1038d..42943701b 100644 --- a/tests/Kernel/ValueObject/DateTimeTest.php +++ b/tests/src/Kernel/ValueObject/DateTimeTest.php @@ -37,7 +37,7 @@ class DateTimeTest extends DateTimeTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); // Create a field with settings to validate. diff --git a/tests/Kernel/ValueObject/DateTimeTestBase.php b/tests/src/Kernel/ValueObject/DateTimeTestBase.php similarity index 95% rename from tests/Kernel/ValueObject/DateTimeTestBase.php rename to tests/src/Kernel/ValueObject/DateTimeTestBase.php index b154307b0..8db40d322 100644 --- a/tests/Kernel/ValueObject/DateTimeTestBase.php +++ b/tests/src/Kernel/ValueObject/DateTimeTestBase.php @@ -31,11 +31,11 @@ abstract class DateTimeTestBase extends FieldKernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->container->get('theme_installer')->install(['oe_theme']); - $this->container->get('theme_handler')->setDefault('oe_theme'); + $this->config('system.theme')->set('default', 'oe_theme')->save(); $this->container->set('theme.registry', NULL); $this->installConfig(['image', 'responsive_image']); } diff --git a/tests/Kernel/ValueObject/ImageTest.php b/tests/src/Kernel/ValueObject/ImageTest.php similarity index 85% rename from tests/Kernel/ValueObject/ImageTest.php rename to tests/src/Kernel/ValueObject/ImageTest.php index a2cc9bf8f..d6286839a 100644 --- a/tests/Kernel/ValueObject/ImageTest.php +++ b/tests/src/Kernel/ValueObject/ImageTest.php @@ -32,7 +32,7 @@ class ImageTest extends KernelTestBase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->installEntitySchema('file'); @@ -55,7 +55,7 @@ protected function setUp() { ])->save(); // Copy file in public files to use it for styling. - \Drupal::service('file_system')->copy(__DIR__ . '/../../fixtures/example_1.jpeg', 'public://example_1.jpg'); + \Drupal::service('file_system')->copy(__DIR__ . '/../../../fixtures/example_1.jpeg', 'public://example_1.jpg'); } /** @@ -89,10 +89,10 @@ public function testFromStyledImageItem() { $object = ImageValueObject::fromStyledImageItem($entity->get('field_image')->first(), $style->getName()); $this->assertEquals($title, $object->getName()); $this->assertEquals($alt, $object->getAlt()); - $this->assertContains('/styles/main_style/public/example_1.jpg', $object->getSource()); + $this->assertStringContainsString('/styles/main_style/public/example_1.jpg', $object->getSource()); $invalid_image_style = $this->randomMachineName(); - $this->setExpectedException(\InvalidArgumentException::class, sprintf('Could not load image style with name "%s".', $invalid_image_style)); + $this->expectExceptionObject(new \InvalidArgumentException(sprintf('Could not load image style with name "%s".', $invalid_image_style))); ImageValueObject::fromStyledImageItem($entity->get('field_image')->first(), $invalid_image_style); } diff --git a/tests/Kernel/Webtools/SocialShareTest.php b/tests/src/Kernel/Webtools/SocialShareTest.php similarity index 93% rename from tests/Kernel/Webtools/SocialShareTest.php rename to tests/src/Kernel/Webtools/SocialShareTest.php index 6cecbc1d9..3b6a92970 100644 --- a/tests/Kernel/Webtools/SocialShareTest.php +++ b/tests/src/Kernel/Webtools/SocialShareTest.php @@ -42,7 +42,7 @@ public function testSocialShareBlockRendering(): void { // Make sure that social media share block is correctly rendered. $custom_footer = $crawler->filter('p.ecl-social-media-share__description'); - $this->assertContains('Share this page', $custom_footer->html()); + $this->assertStringContainsString('Share this page', $custom_footer->html()); $this->assertCount(1, $custom_footer); } diff --git a/tests/Kernel/fixtures/patterns/date_block_pattern_rendering.yml b/tests/src/Kernel/fixtures/patterns/date_block_pattern_rendering.yml similarity index 100% rename from tests/Kernel/fixtures/patterns/date_block_pattern_rendering.yml rename to tests/src/Kernel/fixtures/patterns/date_block_pattern_rendering.yml diff --git a/tests/Kernel/fixtures/patterns/file_pattern_rendering.yml b/tests/src/Kernel/fixtures/patterns/file_pattern_rendering.yml similarity index 100% rename from tests/Kernel/fixtures/patterns/file_pattern_rendering.yml rename to tests/src/Kernel/fixtures/patterns/file_pattern_rendering.yml diff --git a/tests/Kernel/fixtures/patterns/organisation_teaser_rendering.yml b/tests/src/Kernel/fixtures/patterns/organisation_teaser_rendering.yml similarity index 100% rename from tests/Kernel/fixtures/patterns/organisation_teaser_rendering.yml rename to tests/src/Kernel/fixtures/patterns/organisation_teaser_rendering.yml diff --git a/tests/Kernel/fixtures/patterns/page_header_rendering.yml b/tests/src/Kernel/fixtures/patterns/page_header_rendering.yml similarity index 100% rename from tests/Kernel/fixtures/patterns/page_header_rendering.yml rename to tests/src/Kernel/fixtures/patterns/page_header_rendering.yml diff --git a/tests/Kernel/fixtures/rendering.yml b/tests/src/Kernel/fixtures/rendering.yml similarity index 99% rename from tests/Kernel/fixtures/rendering.yml rename to tests/src/Kernel/fixtures/rendering.yml index a187b2a56..3f5d23ebb 100644 --- a/tests/Kernel/fixtures/rendering.yml +++ b/tests/src/Kernel/fixtures/rendering.yml @@ -1715,7 +1715,7 @@ assertions: equals: '.ecl-blockquote__author': "Quote author" - '.ecl-blockquote__body': "Quote text" + '.ecl-blockquote__citation': "Quote text" - array: '#type': pattern '#id': context_nav @@ -2029,7 +2029,7 @@ length: 25 assertions: equals: - 'div.ecl-card__description': '' + 'div.ecl-card__description': '' - array: '#type': pattern '#id': featured_item @@ -2620,7 +2620,6 @@ assertions: contains: '.ecl-menu__open': "Menu" - '.ecl-menu__site-name': "Site name" '.ecl-menu__inner-header button.ecl-menu__close .ecl-button__label': "Close" '.ecl-menu__inner-header button.ecl-menu__back .ecl-button__label': "Back" 'li.ecl-menu__item:nth-child(1) a.ecl-menu__link': "Parent 1" diff --git a/tests/Kernel/fixtures/table_rendering.yml b/tests/src/Kernel/fixtures/table_rendering.yml similarity index 100% rename from tests/Kernel/fixtures/table_rendering.yml rename to tests/src/Kernel/fixtures/table_rendering.yml diff --git a/tests/PatternAssertions/BasePatternAssert.php b/tests/src/PatternAssertions/BasePatternAssert.php similarity index 98% rename from tests/PatternAssertions/BasePatternAssert.php rename to tests/src/PatternAssertions/BasePatternAssert.php index 1a7236b1d..f024991e9 100644 --- a/tests/PatternAssertions/BasePatternAssert.php +++ b/tests/src/PatternAssertions/BasePatternAssert.php @@ -195,7 +195,7 @@ protected function assertImage(?array $expected_image, string $selector, Crawler $this->assertElementExists($selector, $crawler); $element = $crawler->filter($selector); self::assertEquals($expected_image['alt'], $element->attr('alt')); - self::assertContains($expected_image['src'], $element->attr('src')); + self::assertStringContainsString($expected_image['src'], $element->attr('src')); } } diff --git a/tests/PatternAssertions/FeaturedItemAssert.php b/tests/src/PatternAssertions/FeaturedItemAssert.php similarity index 95% rename from tests/PatternAssertions/FeaturedItemAssert.php rename to tests/src/PatternAssertions/FeaturedItemAssert.php index 5b50d145e..1d47b7fa5 100644 --- a/tests/PatternAssertions/FeaturedItemAssert.php +++ b/tests/src/PatternAssertions/FeaturedItemAssert.php @@ -70,7 +70,7 @@ protected function assertFeaturedItemImage($expected_image, string $variant, Cra } $image_div = $crawler->filter($image_div_selector); self::assertEquals($expected_image['alt'], $image_div->attr('aria-label')); - self::assertContains($expected_image['src'], $image_div->attr('style')); + self::assertStringContainsString($expected_image['src'], $image_div->attr('style')); } /** @@ -108,7 +108,7 @@ protected function assertFooterItems($expected_info_items, Crawler $crawler): vo foreach ($expected_info_items as $index => $expected_info_item) { $info_element = $info_elements->eq($index); $icon_element = $info_element->filter('svg.ecl-icon.ecl-icon--xs use'); - $this::assertContains('#' . $expected_info_item['icon'], $icon_element->attr('xlink:href')); + $this::assertStringContainsString('#' . $expected_info_item['icon'], $icon_element->attr('xlink:href')); $this->assertElementText($expected_info_item['text'], 'span.ecl-card__info-label', $info_element); } } diff --git a/tests/PatternAssertions/FieldListAssert.php b/tests/src/PatternAssertions/FieldListAssert.php similarity index 100% rename from tests/PatternAssertions/FieldListAssert.php rename to tests/src/PatternAssertions/FieldListAssert.php diff --git a/tests/PatternAssertions/FileAssert.php b/tests/src/PatternAssertions/FileAssert.php similarity index 95% rename from tests/PatternAssertions/FileAssert.php rename to tests/src/PatternAssertions/FileAssert.php index 6b8e1242e..cb5cc5057 100644 --- a/tests/PatternAssertions/FileAssert.php +++ b/tests/src/PatternAssertions/FileAssert.php @@ -52,7 +52,7 @@ protected function assertFile(array $expected_file, Crawler $crawler): void { // Assert icon. $icon = $crawler->filter('div.ecl-file div.ecl-file__container svg.ecl-file__icon use'); - self::assertContains($expected_file['icon'], $icon->attr('xlink:href')); + self::assertStringContainsString($expected_file['icon'], $icon->attr('xlink:href')); } } diff --git a/tests/PatternAssertions/FileTeaserAssert.php b/tests/src/PatternAssertions/FileTeaserAssert.php similarity index 100% rename from tests/PatternAssertions/FileTeaserAssert.php rename to tests/src/PatternAssertions/FileTeaserAssert.php diff --git a/tests/PatternAssertions/FileTranslationAssert.php b/tests/src/PatternAssertions/FileTranslationAssert.php similarity index 100% rename from tests/PatternAssertions/FileTranslationAssert.php rename to tests/src/PatternAssertions/FileTranslationAssert.php diff --git a/tests/PatternAssertions/IconsTextAssert.php b/tests/src/PatternAssertions/IconsTextAssert.php similarity index 93% rename from tests/PatternAssertions/IconsTextAssert.php rename to tests/src/PatternAssertions/IconsTextAssert.php index 6cce85159..ec7544729 100644 --- a/tests/PatternAssertions/IconsTextAssert.php +++ b/tests/src/PatternAssertions/IconsTextAssert.php @@ -48,7 +48,7 @@ protected function assertItems(array $expected_items, Crawler $crawler): void { $list_element = $list_elements->eq($index); self::assertEquals($expected_item['text'], trim($list_element->text())); $icon_element = $list_element->filter('svg.ecl-icon.ecl-icon--m.ecl-u-mr-s use'); - $this::assertContains($expected_item['icon'], $icon_element->attr('xlink:href')); + $this::assertStringContainsString($expected_item['icon'], $icon_element->attr('xlink:href')); } } diff --git a/tests/PatternAssertions/InPageNavigationAssert.php b/tests/src/PatternAssertions/InPageNavigationAssert.php similarity index 100% rename from tests/PatternAssertions/InPageNavigationAssert.php rename to tests/src/PatternAssertions/InPageNavigationAssert.php diff --git a/tests/PatternAssertions/LinkBlockAssert.php b/tests/src/PatternAssertions/LinkBlockAssert.php similarity index 100% rename from tests/PatternAssertions/LinkBlockAssert.php rename to tests/src/PatternAssertions/LinkBlockAssert.php diff --git a/tests/PatternAssertions/ListItemAssert.php b/tests/src/PatternAssertions/ListItemAssert.php similarity index 98% rename from tests/PatternAssertions/ListItemAssert.php rename to tests/src/PatternAssertions/ListItemAssert.php index 778991374..2a5fa0164 100644 --- a/tests/PatternAssertions/ListItemAssert.php +++ b/tests/src/PatternAssertions/ListItemAssert.php @@ -193,7 +193,7 @@ protected function assertThumbnailImage($expected_image, string $variant, Crawle $this->assertElementExists($image_div_selector, $crawler); $image_div = $crawler->filter($image_div_selector); self::assertEquals($expected_image['alt'], $image_div->attr('aria-label')); - self::assertContains($expected_image['src'], $image_div->attr('style')); + self::assertStringContainsString($expected_image['src'], $image_div->attr('style')); } /** @@ -209,7 +209,7 @@ protected function assertThumbnailImage($expected_image, string $variant, Crawle protected function assertHighlightImage($expected_image, string $variant, Crawler $crawler): void { $image_div = $crawler->filter('article.ecl-card header.ecl-card__header div.ecl-card__image'); self::assertEquals($expected_image['alt'], $image_div->attr('aria-label')); - self::assertContains($expected_image['src'], $image_div->attr('style')); + self::assertStringContainsString($expected_image['src'], $image_div->attr('style')); } /** diff --git a/tests/PatternAssertions/PatternAssertInterface.php b/tests/src/PatternAssertions/PatternAssertInterface.php similarity index 100% rename from tests/PatternAssertions/PatternAssertInterface.php rename to tests/src/PatternAssertions/PatternAssertInterface.php diff --git a/tests/PatternAssertions/PatternAssertState.php b/tests/src/PatternAssertions/PatternAssertState.php similarity index 100% rename from tests/PatternAssertions/PatternAssertState.php rename to tests/src/PatternAssertions/PatternAssertState.php diff --git a/tests/PatternAssertions/PatternAssertStateInterface.php b/tests/src/PatternAssertions/PatternAssertStateInterface.php similarity index 100% rename from tests/PatternAssertions/PatternAssertStateInterface.php rename to tests/src/PatternAssertions/PatternAssertStateInterface.php diff --git a/tests/PatternAssertions/PatternPageHeaderAssert.php b/tests/src/PatternAssertions/PatternPageHeaderAssert.php similarity index 100% rename from tests/PatternAssertions/PatternPageHeaderAssert.php rename to tests/src/PatternAssertions/PatternPageHeaderAssert.php diff --git a/tests/PatternAssertions/SocialMediaLinksAssert.php b/tests/src/PatternAssertions/SocialMediaLinksAssert.php similarity index 93% rename from tests/PatternAssertions/SocialMediaLinksAssert.php rename to tests/src/PatternAssertions/SocialMediaLinksAssert.php index 7b52d9f83..ca9147b0d 100644 --- a/tests/PatternAssertions/SocialMediaLinksAssert.php +++ b/tests/src/PatternAssertions/SocialMediaLinksAssert.php @@ -94,9 +94,9 @@ protected function assertLinks(array $expected_items, Crawler $crawler): void { $link_element = $li_item->filter('a.ecl-link.ecl-link--standalone.ecl-link--icon.ecl-link--icon-before.ecl-social-media-follow__link'); $label_element = $link_element->filter('span.ecl-link__label'); $svg = $link_element->filter('svg.ecl-icon.ecl-icon--xl.ecl-link__icon.ecl-social-media-follow__icon use'); - self::assertContains('icons-social.svg#' . $expected_item['service'], $svg->attr('xlink:href')); + self::assertStringContainsString('icons-social.svg#' . $expected_item['service'], $svg->attr('xlink:href')); $svg_hover = $link_element->filter('svg.ecl-icon.ecl-icon--xl.ecl-link__icon.ecl-social-media-follow__icon-hover use'); - self::assertContains('icons-social.svg#' . $expected_item['service'] . '_hover', $svg_hover->attr('xlink:href')); + self::assertStringContainsString('icons-social.svg#' . $expected_item['service'] . '_hover', $svg_hover->attr('xlink:href')); } self::assertEquals($expected_item['label'], trim($label_element->text())); diff --git a/tests/PatternAssertions/TextFeaturedMediaAssert.php b/tests/src/PatternAssertions/TextFeaturedMediaAssert.php similarity index 97% rename from tests/PatternAssertions/TextFeaturedMediaAssert.php rename to tests/src/PatternAssertions/TextFeaturedMediaAssert.php index b7543e676..4ed7cee20 100644 --- a/tests/PatternAssertions/TextFeaturedMediaAssert.php +++ b/tests/src/PatternAssertions/TextFeaturedMediaAssert.php @@ -98,7 +98,7 @@ protected function assertLink(array $expected_link, Crawler $crawler): void { self::assertEquals($expected_link['label'], $label_element->text()); $svg = $link_element->filter('svg.ecl-icon.ecl-icon--s.ecl-icon--primary.ecl-link__icon use'); - self::assertContains('icons.svg#' . $expected_link['icon'], $svg->attr('xlink:href')); + self::assertStringContainsString('icons.svg#' . $expected_link['icon'], $svg->attr('xlink:href')); } /** diff --git a/tests/Traits/RenderTrait.php b/tests/src/Traits/RenderTrait.php similarity index 97% rename from tests/Traits/RenderTrait.php rename to tests/src/Traits/RenderTrait.php index 617a5d14b..5b7cb8b2e 100644 --- a/tests/Traits/RenderTrait.php +++ b/tests/src/Traits/RenderTrait.php @@ -48,7 +48,7 @@ protected function assertRendering(string $html, array $assertions): void { if (isset($assertions['contains'])) { foreach ($assertions['contains'] as $string) { $message = "String '{$string}' not found in:" . PHP_EOL . $html; - $this->assertContains($string, $html, $message); + $this->assertStringContainsString($string, $html, $message); } } diff --git a/tests/Traits/RequestTrait.php b/tests/src/Traits/RequestTrait.php similarity index 100% rename from tests/Traits/RequestTrait.php rename to tests/src/Traits/RequestTrait.php diff --git a/tests/Unit/AbstractUnitTestBase.php b/tests/src/Unit/AbstractUnitTestBase.php similarity index 100% rename from tests/Unit/AbstractUnitTestBase.php rename to tests/src/Unit/AbstractUnitTestBase.php diff --git a/tests/Unit/ValueObject/DateValueObjectTest.php b/tests/src/Unit/ValueObject/DateValueObjectTest.php similarity index 100% rename from tests/Unit/ValueObject/DateValueObjectTest.php rename to tests/src/Unit/ValueObject/DateValueObjectTest.php diff --git a/tests/Unit/ValueObject/FileValueObjectTest.php b/tests/src/Unit/ValueObject/FileValueObjectTest.php similarity index 100% rename from tests/Unit/ValueObject/FileValueObjectTest.php rename to tests/src/Unit/ValueObject/FileValueObjectTest.php diff --git a/tests/Unit/ValueObject/GalleryItemValueObjectTest.php b/tests/src/Unit/ValueObject/GalleryItemValueObjectTest.php similarity index 100% rename from tests/Unit/ValueObject/GalleryItemValueObjectTest.php rename to tests/src/Unit/ValueObject/GalleryItemValueObjectTest.php diff --git a/tests/Unit/ValueObject/ImageValueObjectTest.php b/tests/src/Unit/ValueObject/ImageValueObjectTest.php similarity index 89% rename from tests/Unit/ValueObject/ImageValueObjectTest.php rename to tests/src/Unit/ValueObject/ImageValueObjectTest.php index c6d07c300..01ce4a9ff 100644 --- a/tests/Unit/ValueObject/ImageValueObjectTest.php +++ b/tests/src/Unit/ValueObject/ImageValueObjectTest.php @@ -57,7 +57,7 @@ class ImageValueObjectTest extends UnitTestCase { /** * {@inheritdoc} */ - protected function setUp() { + protected function setUp(): void { parent::setUp(); $this->imageUri = $this->prophesize(FieldItemList::class); @@ -118,28 +118,6 @@ public function testFromImageItem() { } -/** - * Temporary mock for file_create_url(). - * - * @see https://www.drupal.org/project/drupal/issues/2669074 - */ -if (!function_exists('Drupal\Tests\oe_theme\Unit\Patterns\file_create_url')) { - - /** - * Mock for file_create_url(). - * - * @param string $uri - * Uri to be processed. - * - * @return string - * Process url. - */ - function file_create_url($uri): string { - return $uri; - } - -} - /** * Mocking file_create_url(). * @@ -161,7 +139,7 @@ function file_create_url($uri): string { * Processed url. */ function file_create_url($uri): string { - return \Drupal\Tests\oe_theme\Unit\Patterns\file_create_url($uri); + return $uri; } } diff --git a/tests/Unit/fixtures/value_object/date_value_object.yml b/tests/src/Unit/fixtures/value_object/date_value_object.yml similarity index 100% rename from tests/Unit/fixtures/value_object/date_value_object.yml rename to tests/src/Unit/fixtures/value_object/date_value_object.ymlLorem ipsum dolor sit...