Unit/System Tests PR-5.2-dev Pending

User tests: Successful: 0 Unsuccessful: 0

avatar muhme
muhme
22 Dec 2024

Summary of Changes

Refactoring of the Cypress test for SEF to replace the dependency on the Joomla command line client tool with Cypress custom commands.

With the SefPlugin.cy.js Cypress test, the Joomla command line client tool was added to the Joomla System Tests for the first time. This is an additional complexity and dependency. Especially if the test environment is containerised and Cypress container has no PHP installed. And PHP version needs to be 8.1 and additional modules like php-simplexml are needed. And with the Docker access rights, configuration.php must be opened for writing (chmod 644). And then there is the locally running Cypress GUI to be configured...

Therefore switched from using the Joomla command line client tool to using the existing config_setParameter Cypress custom command. The original creator of 44253 could not know as it is not documented (will be solved with another PR #44660, together with the description for configuring the now required enable mod_rewrite and AllowOverride All).

Since sometimes the first SEF test failed when the entire Joomla System Tests was performed after refactoring, the following was implemented:

  • The operations of the writeRelativeFile Cypress task are wrapped in a Promise to ensure that they are only resolved when everything is done
  • The config_setParameter Cypress custom command to return a Cypress chainable
  • Chaining has been used everywhere in SefPlugin.cy.js

The Cypress best practice of using beforeEach is used to ensure that the tests can be run independently (this is still needed for other places in the Joomla system tests - another PR).

As a small side effect the SEF test spec with 9 tests runs faster, e.g. 3 instead of 18 seconds before.

Testing Instructions

  1. Tested with own target Joomla 5.2-dev three times the single test spec on:
  • Intel macOS 15.2 using Apache/MariaDB
  • Apple Silicon macOS 15.2 using Apache/MariaDB
  • Windows 11 24H2 using Laragon/Apache/MySQL
npx cypress run --spec tests/System/integration/plugins/system/sef/SefPlugin.cy.js

And once the overall test suite:

npm run cypress:run
  1. Tested with JBT in creating Joomla 5.2-dev instance with this PR:
scripts/create 52 joomla-cms-44656

Three times the single test spec on:

  • Intel macOS 15.2
  • Apple Silicon macOS 15.2
  • Windows 11 24H2 WSL2 Ubuntu
scripts/test system plugins/system/sef/SefPlugin.cy.js

And once the overall test suite:

scripts/test system

Actual result BEFORE applying this Pull Request

Joomla System Tests require Joomla command line client

Expected result AFTER applying this Pull Request

Joomla System Tests doesn't require Joomla command line client

Link to documentations

Please select:

  • Documentation link for docs.joomla.org:

  • No documentation changes for docs.joomla.org needed

  • Pull Request link for manual.joomla.org:

  • No documentation changes for manual.joomla.org needed

  • Related PR for adopting Joomla System Tests GitHub will follow

avatar muhme muhme - open - 22 Dec 2024
avatar muhme muhme - change - 22 Dec 2024
Status New Pending
avatar joomla-cms-bot joomla-cms-bot - change - 22 Dec 2024
Category JavaScript Unit Tests
avatar muhme muhme - change - 22 Dec 2024
The description was changed
avatar muhme muhme - edited - 22 Dec 2024
avatar muhme
muhme - comment - 22 Dec 2024

Hey @heelc29 and @alikon could you please have a look and, if possible, test this? Thanks in advance! 😄

avatar muhme muhme - change - 22 Dec 2024
Title
[Cypress] Remove Joomla command line dependency
[Cypress] Remove Joomla command line client tool dependency
avatar muhme muhme - edited - 22 Dec 2024
avatar muhme muhme - change - 23 Dec 2024
The description was changed
avatar muhme muhme - edited - 23 Dec 2024
avatar laoneo laoneo - change - 23 Dec 2024
Labels Added: Unit/System Tests PR-5.2-dev
avatar alikon alikon - test_item - 3 Jan 2025 - Tested successfully
avatar alikon
alikon - comment - 3 Jan 2025

I have tested this item ✅ successfully on 0595b79


This comment was created with the J!Tracker Application at issues.joomla.org/tracker/joomla-cms/44656.

avatar heelc29
heelc29 - comment - 3 Jan 2025

replace the dependency on the Joomla command line client tool

Testing the CLI application is also not a bad idea ... now there is also a PR for it #44683

avatar muhme
muhme - comment - 4 Jan 2025

replace the dependency on the Joomla command line client tool

Testing the CLI application is also not a bad idea ... now there is also a PR for it #44683

Yes and can we implement this outside Joomla System Tests?

avatar laoneo
laoneo - comment - 9 Jan 2025

@muhme please resolve the discussions when done.

avatar muhme muhme - change - 23 Jan 2025
Title
[Cypress] Remove Joomla command line client tool dependency
[Cypress] Refactoring SEF Test to Avoid Using the Joomla Command-Line Client Tool
avatar muhme muhme - edited - 23 Jan 2025
avatar laoneo laoneo - close - 25 Jan 2025
avatar laoneo laoneo - merge - 25 Jan 2025
avatar laoneo laoneo - change - 25 Jan 2025
Status Pending Fixed in Code Base
Closed_Date 0000-00-00 00:00:00 2025-01-25 08:37:13
Closed_By laoneo
avatar laoneo
laoneo - comment - 25 Jan 2025

Thanks!

Add a Comment

Login with GitHub to post a comment