This is the development repository for the Drupal Rector Sandbox. It contains the codebase and an environment to run the site for development.
This is the php7 branch, suitable for use developing upgrade rules for Drupal 8 to Drupal 9.
If you need to switch from php7 to php8 (the php8
branch of the sandbox), follow these steps.
- Checkout the branch you want (e.g.
git checkout main
orgit checkout php8
) rm -rf vendor
ddev restart
ddev . composer install
In preparation for Drupal 10, we will start supporting PHP 7.4 and PHP 8 for development. To do so requires configuring DDEV, and as a result, we encourage you to run all composer
and rector
commands via ddev exec
(alias ddev .
).
Run ddev . composer install
You can view the Rector report by running:
ddev . vendor/bin/rector process web/modules/custom/my-module --dry-run
Rector can update your code by running:
ddev . vendor/bin/rector process web/modules/custom/my-module
Drupal Rector comes with a test module that you can use to confirm rules are working:
ddev . vendor/bin/rector process drupal-rector/rector_examples --dry-run
This command is aliased in the test-rector.sh
script in project root, so you can run this from project root instead:
./test-rector.sh
-
Run
ddev . composer install
orddev . composer update
(it will execute a scriptdevelop-rector.sh
that prepares a development environment underdrupal-project/
directory. -
Add your forked repo inside
drupal-project/
directorycd drupal-rector git remote add upstream [email protected]:<your_github_username>/drupal-rector.git
-
Open a branch for the deprecation you want to create a rule for.
-
Create code samples that will include deprecated code in
drupal-rector/rector_examples
-
Create a new Rector Rule.
-
Run Rector against the examples
ddev . vendor/bin/rector process drupal-rector/rector_examples --dry-run
-
Submit a PR to https://github.com/palantirnet/drupal-rector.
-
Reference the PR in a Drupal.org issue: https://www.drupal.org/project/issues/rector
- Docker
- We recommend installing with homebrew:
brew cask install docker
- We recommend installing with homebrew:
- DDEV
- We recommend installing with homebrew:
brew tap drud/ddev && brew install ddev
- We recommend installing with homebrew:
- NFS
-
Clone the project from github:
git clone [email protected]:palantirnet/drupal-rector-sandbox.git
-
Run the following commands:
ddev restart ddev . composer install ddev . drush si demo_umami -y
-
In your web browser, visit https://drupal-rector-sandbox.ddev.site
You can edit code, update documentation, and run git commands by opening files directly from your host machine.
- Log into docker image (
ddev ssh
) - Run
ddev
to see the available commands.
- Start DDEV,
ddev start
- Enable XDebug on DDEV,
ddev xdebug on
- SSH into DDEV,
ddev ssh
- Put a breakpoint in your IDE like PhpStorm, for example in
drupal-rector/src/Rector/Deprecation/Base/DBBase.php
. - Turn on the listener in your IDE
- Run a command with the
--xdebug
flag such asvendor/rector/rector-prefixed/rector process web/modules/custom/rector_examples/db_delete.php --dry-run --xdebug
- Configure your servers in your IDE so it knows where the files are, see below for PhpStorm.
Go to: Preferences
> Languages & Frameworks
> PHP
> Servers
Add a server:
Name
:drupal-rector-sandbox.ddev.site
Host
:drupal-rector-sandbox.ddev.site
Port
:22
Under the directories, map Project Files
> [local path to where you have this repository]
to /var/www/html
You may need to cancel the Rector process and start another one for these to stick.
Because both Vagrant and DDEV are using NFS, if your project was running with Vagrant before:
- Edit
/etc/exports
file - Comment out the Vagrant line
- Add
/System/Volumes/Data/Users/<username> -alldirs -mapall=501:20 localhost
- Restart NFS service
sudo nfsd restart
- Test that DDEV can mount NFS
ddev debug nfsmount
- Run
ddev restart
This project was built more or less using these steps.
- Create a standard Drupal install with
composer create-project drupal/recommended-project:~8 ../drupal --no-progress
and then move the files into the root. - Create a standard DDEV setup,
ddev config
. - Add
develop-rector.sh
script to side-load Drupal Rector for local development. - Update
composer.json
to use the version side-loaded. - Add
PhpUnit
since it doesn't get installed by default and is needed for some rules. - Add a
docker-compose.env.yaml
file for DDEV to support XDebug - Add
test-rector.sh
script for testing shortcuts.
Copyright 2017-2021 Palantir.net, Inc.