User tests: Successful: 0 Unsuccessful: 0
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:
writeRelativeFile
Cypress task are wrapped in a Promise to ensure that they are only resolved when everything is doneconfig_setParameter
Cypress custom command to return a Cypress chainableSefPlugin.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.
npx cypress run --spec tests/System/integration/plugins/system/sef/SefPlugin.cy.js
And once the overall test suite:
npm run cypress:run
scripts/create 52 joomla-cms-44656
Three times the single test spec on:
scripts/test system plugins/system/sef/SefPlugin.cy.js
And once the overall test suite:
scripts/test system
Joomla System Tests require Joomla command line client
Joomla System Tests doesn't require Joomla command line client
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
Status | New | ⇒ | Pending |
Category | ⇒ | JavaScript Unit Tests |
Title |
|
Labels |
Added:
Unit/System Tests
PR-5.2-dev
|
I have tested this item ✅ successfully on 0595b79
Title |
|
Status | Pending | ⇒ | Fixed in Code Base |
Closed_Date | 0000-00-00 00:00:00 | ⇒ | 2025-01-25 08:37:13 |
Closed_By | ⇒ | laoneo |
Thanks!
Hey @heelc29 and @alikon could you please have a look and, if possible, test this? Thanks in advance! 😄