This project provides a development and testing environment for the WP-CASSIFY plugin - https://wordpress.org/plugins/wp-cassify - with a docker-compose file that sets up
- a WordPress instance with the WP-CASSIFY plugin installed
- a MariaDB database
- an Apereo CAS server
- with an OpenLDAP server
The same docker-compose provides also
- a selenium chrome node
- and a selenium runner that runs the tests
The tests are edited with Selenium IDE. There are currently four tests:
- one that make the install of wordpress and the plugin and a simple configuration of the plugin (wp-cassify)
- one that make the login with CAS on wordpress
- one that make the login with the gateway feature of the CAS protocol
- one that make the logout with the Single Logout feature of the CAS protocol
To launch all the dockers, included the selenium tests, with wordpress (on php8), simply run:
docker compose up
If you want to test with wordpress on php7, use instead :
docker compose -f docker-compose.yml -f docker-compose-php7.yml up
You have to install the last version of docker.
For debian for example, see the official documentation
Ports 80, 8080 and 4444 are exposed on the host machine and must be free.
The WordPress instance is available at http://localhost but to be compliant with selenium tests, it is better to modify the /etc/hosts file to add the following line:
127.0.0.1 cas.example.org wordpress.example.org wordpress1.example.org wordpress2.example.org
With this, you can access the WordPress instance at http://wordpress.example.org and the CAS server at http://cas.example.org:8080.
Selenium Grid is available at http://localhost:4444.
On the WordPress instance, the Selenium Test configured Administrators are users with id joe. So you can login with the following credentials:
username: joe
password: pass
If you want to reset the wordpress instance, after launched docker-compose, you can connect to the mariadb docker instance and remove/recreate the wordpress database.
To list the docker instances:
docker ps
You take the container id of the mariadb instance and connect to it:
docker exec -it <container_id> bash
Then you connect to the mariadb database:
mariadb -ppass
You delete and (re)create the wordpress database:
DROP DATABASE wordpress;
CREATE DATABASE wordpress;
You can relaunch the selenium tests with Selenium IDE :
- docker/selenium-sides/01-wp-cassify-setup.side
- docker/selenium-sides/02-wp-cassify-cas-login.side
- docker/selenium-sides/03-test-gateway-on-and-off.side
- docker/selenium-sides/04-single-sign-on-off.side
... or you can also relaunch the tests via the docker 'selenium-runner' with the following command:
docker up selenium-runner
... or you can also relaunch somes tests via selenium-runner directly with the following command for example:
selenium-side-runner -d -s http://localhost:4444 docker/selenium-sides/03-test-gateway-on-and-off.side
The project is also configured to run the tests on Github Actions.
The workflow is defined in the file .github/workflows/docker-selenium-tests.yml
and .github/workflows/docker-selenium-tests-php7.yml
(to keep compatibility with wordpress on php7)
You can use Eclipse-Php or Visual Studio Code or PhpStorm or VsCode to edit wp-cassify.
The best is to use the docker-compose file with xdebug to debug the plugin.
docker compose -f docker-compose.yml -f docker-compose-xdebug.yml up
With this, you have ./wordpress that is a bind volume to /var/ww/html of the wordpress container.
To edit also the wp-cassify plugin, just make a symbolic link in ./wordpress/wp-content/plugins to the wp-cassify plugin directory.
rm -r ./wordpress/wp-content/plugins/wp-cassify
ln -s $(pwd)/wp-cassify $(pwd)/wordpress/wp-content/plugins/
Next you can open the project with your IDE from the directory ./wordpress.
For XDebug, you have to configure the IDE to listen on port 9003.
This project is licensed under the GPLv2 License - same as WP-Cassify plugin and as WordPress itself.