This is a fairly simple docker container to facilitate development of WordPress plugins.
Mac users:
Warning
Do not clone to your documents folder as this will cause permission issues.
- OrbStack includes everything you need.
Windows WSL2: Running this setup from WSL is the preferd way.
- Rancher Desktop see the Rancher-win.md guide on how to switch.
- GitExtensions includes some unix tools we need.
- optional GSudo allows shell scripts to use sudo command on windows
Windows install:
- Friendly dns names (e.g. basic.wordpress.test) will not work out of the box
possible fix: make the
c:\windows\system32\drivers\etc\hosts
write and change for users, before running ./setup.sh script from WSL after running the .setup.sh this can be removed again - Ssl trust will not work out of the box add the config/certs/wordpress.text.crt to the trusted list in windows it self(NOT WSL)
- First copy the cert to the Windows file system.
cp config/certs/wordpress.test.crt /mnt/c/Users/WindowsUserName/Desktop
- Then add the ssl cert to the Windows certificate store. Start a PowerShell prompt and execute
Import-Certificate -FilePath ".\Desktop\wordpress.test.crt" -CertStoreLocation Cert:\CurrentUser\Root
- First copy the cert to the Windows file system.
This will configure your host-file and create the necessary config files first. You will likely need to enter your sudo password as this will add basic.wordpress.test etc to your hosts file. (see note above for windows)
This will create and start your containers. You can visit your environment by visiting https://basic.wordpress.test
. Note that starting other containers, like woocommerce or multisite, will have different domains associated.
You can always run ./clean.sh
to delete all persistent data of your WordPresss environment and start again from scratch. If you run ./clean.sh --all
you will also remove configuration files.
By default ./start.sh
will start the basic wordpress container. Alternatively you can call ./start.sh $CONTAINER_NAMES
to start other containers.
The following are available:
- basic-wordpress: The basic image that's started by default. Can be accessed via basic.wordpress.test.
- standalone-wordpress: The basic image without anything installed. Has a separate plugins folder named
sa-plugins
in order to not interfere with other containers. Useful for testing a second version of a plugin. - woocommerce-wordpress: A WooCommerce installation. Can be accessed via woocommerce.wordpress.test.
- multisite-wordpress: A multisite installation using subdirectories. Can be accessed via multisite.wordpress.test.
- multisitedomain-wordpress: A multisite installation using subdomains. Can be accessed via multisite.wordpress.test.
- nightly-wordpress: A nightly installation using subdomains. Can be accessed via nightly.wordpress.test.
For example, calling ./start.sh woocommerce-wordpress
will start only the WooCommerce container. Calling ./start.sh basic-wordpress multisite-wordpress
will start both the basic WordPress and multisite containers.
If you need WordPress trunk, a beta or a release candidate, there are two ways of going about that:
-
Switch using WP CLI:
./wp.sh core update --version=nightly
Note that you'll have to repeat this daily if you want to be on the latest nightly. If you want to switch back, do, note the --force
because you're downgrading:
./wp.sh core update --version=5.4 --force
./wp.sh core update --version=5.4 --force
- Install and use the WordPress beta tester plugin.
Run ./plugins.sh
- this will install default plugins to your container for easier debugging and developing.
Simply clone, extract or download any plugins you want available in your environment into the plugins
directory. They will be immediately visible inside your WordPress installation. Don't forget to activate them!
You can run ./wp.sh
to run WP CLI commands. By default this will execute the command in the first running WordPress container ( created from this project ). However if the first argument is the name of a container it will specifically run in that container.
For example: ./wp.sh shell
will run wp shell
in the first active WordPress installation. ./wp.sh woocommerce-wordpress cache flush
will run wp cache flush
in the woocommerce-wordpresss installation.
Mailhog is a local catch-all for mails that are sent from local environments. To use it, use WordPress like you would normally. For example, create a new user and have the installation send an e-mail to the user. This will deliver the mail to your local Mailhog instance. To see this mail, open a new browsertab and navigate to http://localhost:8025/. Here you will find all mails that are sent by the application.
Remember that Mailhogs' memory is non-persistent. Closing down the container will wipe all stored e-mails.
The local WordPress site won't be updated automatically. You have a few options to update your installation, with some pros and cons.
- The simplest way to update your WordPress installation is to click the update button in the WP admin. This process makes sure that you keep your data (like posts, plugins etc).
- A bit more forced way of updating (and resetting your database) can be accomplished with the following commands:
./clean.sh &&
./start.sh
- If one of the methods fails, please contact the DevOps team. We can help you with updating specific docker images.
You might add the specific container argument after the ./start.sh
command.
The docker environments come preconfigured with WordPress debugging on. If you want to enable Yoast debugging specifically, you can add the parameter yoastdebug
to your URL. This will trigger the yoast debugging constants and show debugging logs on sitemaps and pretty print json-ld and such.
This container is already preconfigured with XDebug. The only thing left to do is to configure your IDE and browser. See the following 2 headers.
If you are using PHPStorm follow these instructions:
- Open up
Preferences -> Languages & Frameworks -> PHP -> Servers
- Click the
+
icon - Name: Give it a recognizeable name or use the following Host.
- Host:
<domain name here>
(default for this docker:basic.wordpress.test
) - Port: 80
- File/Directory
plugins/<your-plugin-name>
maps to the absoulte path/mnt/plugins/<your-plugin-name>
. - File/Directory
wordpress
maps to the absoulte path/var/www/html
. - Apply
In PHPStorm you can also add the wordpress
directory to provide full WordPress indexation.
If you are using VSCode simply copy/paste the following launch.json
( don't forget to edit <your-plugin-name
) which you can edit by running Debug: open launch.json
:
{
"version": "0.2.0",
"configurations": [
{
"name": "Listen for XDebug",
"type": "php",
"request": "launch",
"port": 9000,
"pathMappings": {
"/var/www/html/wp-content/plugins/<your-plugin-name>": "${workspaceRoot}",
"/var/www/html": "${workspaceRoot}/../../wordpress",
},
}
]
}
This assumes your plugin is the root of your opened VSCode project.
Also make sure you have the XDebug extension installed!
For Firefox you'll want to install the Firefox XDebug helper. For Chrome you'll want to install the Chrome XDebug helper.
Both of these do exactly the same. They add an icon to your URL bar where you can choose the XDebug settings for your request:
- Setting it to
Debug
will make PHP pause on any breakpoints you've configured in your IDE ( provided you're listening to Debug connections ). - Setting it to
Profile
will make PHP time every function call and output a cachegrind file. These will be located in thedata/xdebug
directory.- These can be opened with a tool called KCachegrind / QCachegrind. On Mac you can install it using
brew install qcachegrind
. On Linux you can usually install it usingsudo apt install kcachegrind
.
- These can be opened with a tool called KCachegrind / QCachegrind. On Mac you can install it using
- Setting it to
Trace
will make PHP output a full trace of every function call. These will also be located in thedata/xdebug
directory.- By default parameters and return values are not included in traces. You can change these settings by changing your
config/php.ini
. For documentation on which values to change see the XDebug documentation. - For viewing these files with a GUI you could use xdebug-trace-tree. Cloning that project in the
wordpress
directory and visitinghttp://local.wordpress.test/xdebug-trace-tree
should get you up and running.
- By default parameters and return values are not included in traces. You can change these settings by changing your
All database ports are forwarded to localhost to make them easily accessible from various tools. You'll want to enter the following configuration:
Property | Value |
---|---|
Host | 127.0.0.1 |
Username | wordpress |
Password | wordpress |
Database | wordpress |
The port differs based on the installation you're running.
Site | Port |
---|---|
basic-wordpress | 1987 |
woocommerce-wordpress | 1988 |
multisite-wordpress | 1989 |
standalone-wordpress | 1990 |
multisitedomain-wordpress | 1991 |
nightly-wordpress | 1992 |
The first run after a make can fail. Quit all docker containers with docker-compose down
and run bash start.sh
again.
Issue: #11