We suggest using a software package manager for installing the development dependencies such as Homebrew on MacOS:
brew install php composer node docker docker-compose
or Chocolatey for Windows:
choco install php composer node nodejs docker-compose
Clone the plugin repository.
Setup the development environment and tools using Node.js and Composer:
npm install
Note that both Node.js and PHP 7.2 or later are required on your computer for running the npm
scripts. Use npm run docker -- npm install
to run the installer inside a Docker container if you don't have the required version of PHP installed locally.
This repository includes a WordPress development environment based on Docker that can be run on your computer or inside a Vagrant and VirtualBox wrapper for network isolation and simple .local
domain names.
To use the Vagrant based environment, run:
vagrant up
which will make it available at block-scaffolding-wp.local.
Use the included wrapper command for running scripts inside the Docker container running inside Vagrant:
npm run vagrant -- npm run test:php
where npm run test:php
is any of the scripts you would like to run.
Visit block-scaffolding-wp.local:8025 to check all emails sent by WordPress.
To use the Docker based environment with the Docker engine running on your host, run:
docker-compose up -d
which will make it available at localhost. Ensure that no other Docker containers or services are using port 80 on your machine.
Use the included wrapper command for running scripts inside the Docker container:
npm run docker -- npm run test:php
where npm run test:php
is any of the scripts you would like to run.
Visit localhost:8025 to check all emails sent by WordPress.
We use npm
as the canonical task runner for the project. Some of the PHP related scripts are defined in composer.json
.
All of these commands can be run inside the Docker or Vagrant environments by prefixing the scripts with npm run docker --
for Docker or with npm run vagrant --
for Vagrant.
npm run build
to build the plugin JS and CSS assets. Use npm run dev
to watch and re-build as you work.
npm run lint:js
to lint JavaScript files with eslint.
npm run lint:php
to lint PHP files with phpcs.
npm run test:php
to run PHPUnit tests without generating a coverage report.
npm run test:php:coverage
to run PHPUnit tests and generate a coverage report in both XML Clover and HTML format.