Environments: Local
For DDEV docs, please see the CMS Platform's Confluence guide.
The local development environment uses Lando to create and manage the Drupal CMS.
-
Command Description lando start -y
Start the application lando rebuild -y
Rebuild the application and re-run the setup commands lando composer nuke
Destroy the vendor directory so it can be rebuilt properly. lando xdebug-on
/lando xdebug-off
Turns xdebug on or off. lando info
View service URLs and ports Mailhog is an email testing tool that has two main functions:
- captures outgoing email from the application
- provides a web UI for viewing outgoing emails
To access the UI, run
lando info
to see the mailhog URL and visit the service URL.- Sometimes after initial setup or
lando start
, Drush is not found. Runninglando rebuild -y
once or twice usually cures, if not, see: https://github.com/lando/lando/issues/580#issuecomment-354490298 - Email addresses are blanked for existing users as part of normal database sanitization and attempts to send email to them can fail silently (see #6100). Email to new users, or users whose email addresses have been updated, can be sent and will be captured in Mailhog.
- The osxfs file system server has known performance issues. (ref, ref) These issues are exacerbated by the very large number of files present in the application. One workaround is to use an nfs mount instead. To use nfs in your local environment:
-
First, obtain your user account's uid:
id -u
-
Then, edit the
/etc/exports
file (requires root access) and add the following line, replacing '{uid}' with your numeric uid:/System/Volumes/Data -alldirs -mapall={uid}:20 localhost
-
Then, edit the
/etc/nfs.conf
file (requires root access) and add the following line:nfs.server.mount.require_resv_port = 0
-
Next, restart the nfs server:
sudo nfsd restart
-
Now, you will need to update your lando configuration. Edit your
.lando.local.yml
file (create it if it doesn't exist) and add the following lines:services: appserver: overrides: volumes: - "${LANDO_VOLUME}:/app" compose: - .lando.compose.yml
-
Now, you will need to create your local docker compose file. Create the
.lando.compose.yml
file and add these lines:version: '3' volumes: nfsmount: driver: local driver_opts: type: nfs o: addr=host.docker.internal,rw,nolock,hard,nointr,nfsvers=3 device: ":${PWD}"
-
Finally, rebuild the app:
export LANDO_VOLUME='nfsmount' && lando rebuild
(It's worth adding the variable export to your shell config so that you don't have to remember to use it in the future) -
If there are no errors, verify that your app is using nfs: run
lando ssh
and thendf -h /app
. You should see something like:/Users/username/src/va.gov-cms
in the Filesystem column instead ofosxfs
.
-
Sometimes, you will see this output when running git pull:
error: unable to unlink old 'docroot/sites/default/settings.php': Permission denied
This occurs because Drupal checks and hardens file permissions under the settings directory in system_requirements(). To override this default behavior, create (or edit) docroot/sites/default/settings/settings.local.php
and add this line:
$settings['skip_permissions_hardening'] = TRUE;
There are plugins available to provide in-line style checking according to project standards.
There are some scripts created to help with managing the Drupal site locally.
- Copy the database from PROD:
./scripts/sync-db.sh
- This script obtains a recent copy of the PROD database that has been sanitized to protect user data and imports it into the local Drupal site. The db export appears here.dumps/cms-db-latest.sql
. - Copy the files from PROD:
./scripts/sync-files.sh
- This copies the/sites/default/files/*
from PROD down to your local environment
There are a number of helpful composer "scripts" available, located in the composer.json file, in the scripts
section. These scripts get loaded in as composer commands.
Change to the CMS repository directory and run composer
to list all commands, both built in and ones from this repo.
The VA.gov project has the following custom commands.
-
composer set-path
Use
composer set-path
command to print out the needed PATH variable to allow running any command in the./bin
directory just by it's name.For example:
$ composer set-path > # Run the command output below to set your current terminal PATH variable. > # This will allow you to run any command in the ./bin directory without a path. > echo "export PATH=${PATH}" export PATH=/Users/VaDeveloper/Projects/VA/va.gov-cms/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin
Then, copy the last line (with all of the paths) and paste it into your desired terminal, and hit ENTER.
Once the path is set, you can run any of the commands listed in the bin directory directly:
$ phpcs --version PHP_CodeSniffer version 2.9.2 (stable) by Squiz (http://www.squiz.net)
The path will remain in place as you change directories.
-
composer va:proxy:socks
orcomposer va:proxy:socks&
Simply runs the "socks proxy" command which is needed to connect to the VA.gov network. Add the
&
character to run it as a background process. -
composer va:proxy:test
Test the proxy when it is running.
-
composer nuke
Removes all composer installed directories, useful when you manually made changes to any files inside a composer managed directory. e.g. docroot/core, docroot/vendor.
@TODO: Document all of the custom composer commands.
See https://getcomposer.org/doc/articles/scripts.md for more information on how to create and manage scripts.
All Drush commands are run with a Lando prefix. (examples)
lando drush uli
lando drush cr
lando drush sqlq "show tables"
As noted above, these should normally be run with a lando
prefix. Dashes may be substituted for colons.
drush va-gov:get-deploy-mode
-- Indicates whether the CMS is currently in Deploy Mode, which is a precautionary measure used to prevent content changes while content is being deployed.drush va-gov:enable-deploy-mode
-- Sets the Deploy Mode flag to TRUE. This is not normally necessary.drush va-gov:disable-deploy-mode
-- Sets the Deploy Mode flag to FALSE. This is not normally necessary.drush va-gov:build-frontend
-- Adds a request to build the vets-website frontend and deploy content to the queue, but does not perform it. If passed the--dry-run
option, will output the commands that would be executed so they might be run interactively.drush va-gov:build-frontend:process-queue
-- Processes the frontend build queue, executing any currently enqueued jobs.drush va-gov:build-frontend:empty-queue
-- Removes all jobs currently in the frontend build queue.drush va-gov:build-frontend:delete-jobs
-- Delete all enqueued jobs. Note that this use of "enqueued" refers specifically to theadvancedqueue
's internal state. A job is not necessarily in the "enqueued" state just because it's been added to the queue. To completely empty the queue in all situations, use thedrush va-gov:build-frontend:empty-queue
command.drush va-gov:build-frontend:release-jobs
-- Release all enqueued jobs. This refers to releasing the leases that mark a claim on the job so that the jobs might be claimed and executed by a new process. This is not normally necessary.drush va-gov:build-frontend:list-jobs
-- Output a sparsely-formatted list of the current jobs in the queue. This should indicate the job's ID, status, and the commands it would invoke during processing.
See testing.
You can't test with the VA cert locally using Lando but you can use Lando's self-signed cert. If you need to test the actual cert locally contact the DevOps team to help you setup the vagrant build system to get HTTPS working with VA CA.
To test with Lando's self-signed cert you need to tell your system to trust the Lando Certificate Authority. Instructions are here > https://docs.devwithlando.io/config/security.html
TODO, create upstream PR with sudo trust anchor --store ~/.lando/certs/lndo.site.pem
for Arch Linux
Note: I had to still import that same CA into Chrome.
Go to chrome://settings/certificates?search=https
Click "Authorities"
Import .lando\certs\lndo.site.pem
Sometimes your local env may run out of memory when clicking around the Drupal environment. lando restart
will fix
this in the short term. If the problem persists, bumping up your docker ram to 4GB or higher should fix the issue.