Skip to content

Latest commit

 

History

History
403 lines (220 loc) · 15.7 KB

CHANGELOG.md

File metadata and controls

403 lines (220 loc) · 15.7 KB

Unreleased

Enhancements

  • Add a WP_ENV_MULTISITE environment variable to override the multisite option (#68792).

10.16.0 (2025-01-15)

10.15.0 (2025-01-02)

Enhancements

  • Add support for WordPress multisite installations. Enabled via the new multisite environment config (#67845).

Internal

  • Refactored the code to use new API introduced together with @inquirer/prompts instead of legacy inquirer package (#67877).

10.14.0 (2024-12-11)

Enhancements

  • Add phpMyAdmin as an optional service. Enabled via the new phpmyadminPort environment config, as well as env vars WP_ENV_PHPMYADMIN_PORT and WP_ENV_TESTS_PHPMYADMIN_PORT (#67588).

Internal

  • The bundled rimraf dependency has been updated from ^3.0.2 to ^5.0.10 (#67708).

10.13.0 (2024-11-27)

10.12.0 (2024-11-16)

10.11.0 (2024-10-30)

10.10.0 (2024-10-16)

10.9.0 (2024-10-03)

10.8.0 (2024-09-19)

10.7.0 (2024-09-05)

10.6.0 (2024-08-21)

10.5.0 (2024-08-07)

10.4.0 (2024-07-24)

10.3.0 (2024-07-10)

Bug Fixes

  • Remove version field from docker-compose config generated by env package #63099. Docker has starting throwing a warning that this property is obsolete and should be removed.

10.2.0 (2024-06-26)

Enhancements

  • Ignore $schema key in environment config parsing (#62626).

10.1.0 (2024-06-15)

10.0.0 (2024-05-31)

Breaking Changes

  • Increase the minimum required Node.js version to v18.12.0 matching long-term support releases (#31270). Learn more about Node.js releases.

9.10.0 (2024-05-16)

9.9.0 (2024-05-02)

9.8.0 (2024-04-19)

9.7.0 (2024-04-03)

9.6.0 (2024-03-21)

9.5.0 (2024-03-06)

9.4.0 (2024-02-21)

Bug Fixes

  • Fix mariadb version to LTS #59237

9.3.0 (2024-02-09)

9.2.0 (2024-01-24)

9.1.0 (2024-01-10)

9.0.0 (2023-12-13)

Breaking Changes

  • Update Docker usage to docker compose V2 following deprecation of docker-compose V1.

8.13.0 (2023-11-29)

8.12.0 (2023-11-16)

8.11.0 (2023-11-02)

Enhancements

  • wp-env now works offline after the environment has been created. Note that many wp-env configuration changes involve internet connectivity and may not work in offline mode. #53547

8.10.0 (2023-10-18)

Bug Fixes

  • Corrected PATH to include the host user's Composer bin directory.
  • Replaced yoast/phpunit-polyfills with phpunit/phpunit to install the required PHPUnit version, avoiding the need for project-specific polyfills.

8.9.0 (2023-10-05)

8.8.0 (2023-09-20)

8.7.0 (2023-08-31)

8.6.0 (2023-08-16)

8.5.0 (2023-08-10)

8.4.0 (2023-07-20)

8.3.0 (2023-07-05)

8.2.0 (2023-06-23)

8.1.1 (2023-06-17)

Bug Fixes

  • Address issue where a missing file in the underlying Docker image caused wp-env to crash. #51513

8.1.0 (2023-06-07)

New Features

  • Execute the local package's wp-env instead of the globally installed version if one is available.

Bug Fixes

  • Run useradd with -l option to prevent excessive Docker image sizes.

8.0.0 (2023-05-24)

Breaking Changes

  • Remove afterSetup option from .wp-env.json and the WP_ENV_AFTER_SETUP environment variable in favor of more granular lifecycle scripts.

New Features

  • Add afterStart, afterClean, and afterDestroy lifecycle scripts to a new lifecycleScripts key in .wp-env.json.
  • Add a series of WP_ENV_LIFECYCLE_SCRIPT_ environment variables for the various lifecycle scripts.
  • Rework run command to resolve bugs with non-quoted commands. As a consequence it is no longer possible to pass your entire command to wp-env wrapped in double-quotes. While npx wp-env run cli wp help will still work, npx wp-env run cli "wp help" will not. If you are currently escaping any quotes you will need to review those commands and ensure they are compatible with this update.

Enhancements

  • Support using double dashes in wp-env run ... to pass arguments that would otherwise be consumed by wp-env. For example, while normally --help would provide the wp-env help text, if you use npx wp-env run cli php -- --help you will see the PHP help text.
  • Validate whether or not config options exist to prevent accidentally including ones that don't.

Bug Fixes

  • Support Windows without requiring the use of WSL.

7.0.0 (2023-05-10)

Breaking Changes

  • Docker containers now run as the host user. This should resolve problems with permissions arising from different owners between the host, web container, and cli container. If you still encounter permissions issues, try running npx wp-env destroy so that the environment can be recreated with the correct permissions.
  • Remove the composer and phpunit Docker containers. If you are currently using the run composer or run phpunit command you can migrate to run cli composer or run tests-cli phpunit respectively. Note that with composer, you will need to use the --env-cwd option to navigate to your plugin's directory as it is no longer the default working directory.

New Features

  • Create an afterSetup option in .wp-env.json files for setting arbitrary commands to run after setting up WordPress when using npx wp-env start and npx wp-env clean.
  • Add a WP_ENV_AFTER_SETUP environment variable to override the afterSetup option.
  • Execute the afterSetup command on npx wp-env start after the environment is set up. This can happen when your config changes, WordPress updates, or you pass the --update flag.
  • Execute the afterSetup command on npx wp-env clean.
  • Globally install composer and the correct version of phpunit in all of the Docker containers.

Bug Fixes

  • Ensure wordpress, tests-wordpress, cli, and tests-cli always build the correct Docker image.
  • Fix Xdebug while using PHP 7.2x.

Enhancements

  • wp-env run ... now uses docker-compose exec instead of docker-compose run. As a result, it is much faster, since commands are executed against existing services, rather than creating them from scratch each time.
  • Increase the maximum upload size to 1GB.

6.0.0 (2023-04-26)

Breaking Changes

  • Use test environment's WP_SITEURL instead of WP_TESTS_DOMAIN as the WordPress URL.
  • Automatically add the environment's port to WP_TESTS_DOMAIN.
  • run command now has a --env-cwd option to set the working directory in the container for the command to execute from.

5.16.0 (2023-04-12)

5.15.0 (2023-03-29)

5.14.0 (2023-03-15)

5.13.0 (2023-03-01)

5.12.0 (2023-02-15)

5.11.0 (2023-02-01)

Bug Fixes

  • PHP 7.3 and 7.4 must use PHPUnit 9.

Enhancements

  • It's now possible to run PHPUnit tests on PHP 8.1 and 8.2.

5.10.0 (2023-01-11)

5.9.0 (2023-01-02)

5.8.0 (2022-12-14)

5.7.0 (2022-11-16)

5.6.0 (2022-11-02)

5.5.0 (2022-10-19)

5.4.0 (2022-10-05)

5.3.0 (2022-09-21)

5.2.0 (2022-08-16)

Enhancements

  • Query parameters can now be used in .zip source URLs.

5.1.1 (2022-08-16)

Bug Fixes

  • Fix a crash when "core" was set to null in a .wp-env.json file. We now use the latest stable WordPress version in that case. This also restores the previous behavior of "core": null in .wp-env.override.json, which was to use the latest stable WordPress version.

5.1.0 (2022-08-10)

Enhancements

  • Previously, wp-env used the WordPress version provided by Docker in the WordPress image for installations which don't specify a WordPress version. Now, wp-env will find the latest stable version on WordPress.org and check out the https://github.com/WordPress/WordPress repository at the tag matching that version. In most cases, this will match what Docker provides. The benefit is that wp-env (and WordPress.org) now controls the default WordPress version rather than Docker.

Bug Fixes

  • Downloading a default WordPress version also resolves a bug where the wrong WordPress test files were used if no core source was specified in wp-env.json. The current trunk test files were downloaded rather than the stable version. Now, the test files will match the default stable version.

5.0.0 (2022-07-27)

Breaking Changes

  • Removed the WP_PHPUNIT__TESTS_CONFIG environment variable from the phpunit container. This removes automatic support for the wp-phpunit/wp-phpunit Composer package. To continue using the package, set the following two environment variables in your phpunit.xml file or similar: WP_TESTS_DIR="" and WP_PHPUNIT__TESTS_CONFIG="/wordpress-phpunit/wp-tests-config.php".
  • Removed the generated /var/www/html/phpunit-wp-config.php file from the environment.

Enhancements

  • Read WordPress' version and include the corresponding PHPUnit test files in the environment.
  • Set the WP_TESTS_DIR environment variable in all containers to point at the PHPUnit test files.

Bug Fixes

  • Restrict WP_TESTS_DOMAIN constant to just hostname rather than an entire URL (e.g. it now excludes scheme, port, etc.) (#41039).

4.8.0 (2022-06-01)

Enhancements

  • Removed the need for quotation marks when passing options to wp-env run.
  • Setting a config key to null will prevent adding the constant to wp-config.php even if a default value is defined by wp-env.

4.7.0 (2022-05-18)

Enhancements

  • Added SSH protocol support for git sources

4.2.0 (2022-01-27)

Enhancements

  • Added command wp-env install-path to list the directory used for the environment.
  • The help entry is now shown when no subcommand is passed to wp-env.

Bug Fixes

4.1.3 (2021-11-07)

Bug Fixes

  • Fix Xdebug installation code to ensure it would fail gracefully

4.0.3 (2021-04-29)

Bug Fixes

  • wp-env destroy will now work in environments which don't include the grep or awk commands, such as Windows PowerShell.
  • Fix several permissions issues related to wp-config.php and wp-content files.
  • Fix crash which happened when the path to wp-env's home directory contained a space.
  • Disable Xdebug 3 for PHP versions less than 7.2 to resolve startup crash.

4.0.0 (2021-03-17)

Breaking Changes

  • Migrate from nodegit to simple-git. This change now requires you to have a git binary installed locally to utilize the git sources feature of wp-env.json.

Bug Fixes

  • "mappings" sources are now downloaded if they contain non-local sources.

3.0.0 (2020-12-17)

Breaking Changes

  • wp-env start is now the only command which writes to the docker configuration files. Previously, running any command would also parse the config and then write it to the correct location. Now, other commands still parse the config, but they will not overwrite the configuration which was set by wp-env start. This allows parameters to be passed to wp-env start which can affect the configuration.

Enhancements

  • Update nodegit dependency to 0.27.0, the earlier version does not have pre-built binaries for Node 14.15.0 LTS. Upgrading provides support without requiring building nodegit locally.
  • Allow WP_HOME wp-config value to be set to a custom port other than the default for the docker instance.
  • Append the instance URL to output of wp-env start.

New Features

  • Add support for setting the PHP version used for the WordPress instance. For example, test PHP 8 with "phpVersion": 8.0 in wp-env.json.
  • Add Xdebug 3 to the development environment. You can enable Xdebug with wp-env start --xdebug (for debug mode) or wp-env start --xdebug=develop,coverage for custom modes.

Bug Fixes

  • ZIP-based plugin sources are now downloaded to a directory using the basename of the URL instead of the full URL path. This prevents HTML encoded characters in the URL (like "/") from being improperly encoded into the filesystem. This fixes the issue where many .zip sources broke because files with these badly formatted characters were not loaded as assets.

2.0.0 (2020-09-03)

Breaking Changes

  • The config and mappings options in .wp-env.json are now merged with any overrides instead of being overwritten.
  • The first listed theme is no longer activated when running wp-env start, since this overwrote whatever theme the user manually activated.
  • wp-env start no longer stops the WordPress instance if it was already started unless it needs to configure WordPress.
  • wp-env start no longer updates remote sources after first install if the configuration is the same. Use wp-env start --update to update sources.

New Features

  • You may now specify specific configuration for different environments using env.tests or env.development in .wp-env.json.
  • wp-env start is significantly faster after first install.

1.6.0-rc.0 (2020-06-24)

Bug Fixes

  • wp-env destroy now removes dangling docker volumes and networks associated with the WordPress environment.

1.4.0 (2020-05-28)

New Features

  • Add support for running interactive commands. Examples: wp-env run cli wp shell and wp-env run cli bash.
  • View php and WordPress log output with the new wp-env logs command.
  • Clean up your local environment with the new wp-env destroy command.
  • Expose Docker service for running phpunit commands.
  • You may now mount local directories to any location within the WordPress install. For example, you may specify "wp-content/mu-plugins": "./path/to/mu-plugins" to add mu-plugins.

1.1.0 (2020-04-01)

New Features

  • URLs for ZIP files are now supported as core, plugin, and theme sources.
  • The .wp-env.json coniguration file now accepts a config object for setting wp-config.php values.
  • A .wp-env.override.json configuration file can now be used to override fields from .wp-env.json.
  • You may now override the directory in which wp-env creates generated files with the WP_ENV_HOME environment variable. The default directory is ~/.wp-env/ (or ~/wp-env/ on Linux).
  • The .wp-env.json coniguration file now accepts port and testsPort options which can be used to set the ports on which the docker instance is mounted.

1.0.0 (2020-02-10)

Breaking Changes

  • wp-env start no longer accepts a WordPress branch or tag reference as its argument. Instead, create a .wp-env.json file and specify a "core" field.
  • wp-env start will now download WordPress into a hidden directory located in ~/.wp-env. You may delete your {projectName}-wordpress and {projectName}-tests-wordpress directories.

New Features

  • A .wp-env.json configuration file can now be used to specify the WordPress installation, plugins, and themes to use in the local development environment.

0.4.0 (2020-02-04)

Bug Fixes

  • When running scripts using wp-env run, the output will not be formatted if not written to terminal display, resolving an issue where piped or redirected output could be unintentionally padded with newlines.