Skip to content

Latest commit

 

History

History
161 lines (105 loc) · 5.51 KB

local-development.md

File metadata and controls

161 lines (105 loc) · 5.51 KB

Local development

Docker setup

Requirements

In order to run local development you need:

MacOS and Docker

If you are using MacOS, you can use the standard "Docker for Mac" app, however there has been developers that have experienced it acting slow.

Alternatively, you can use Orbstack, which is a direct replacement for Docker for Mac, but is optimized to run much faster.

Docker for Mac

If you do end up using Docker for Mac, it is recommended to use VirtioFS on the mounted volumes in docker-compose, to speed up the containers.

OSX preference pane providing access to VirtioFS

Configuration of https

Install mkcert on your host machine and generate and install a root certificate by running mkcert -install on your host machine (one time only).

Mac users can run: brew install mkcert to install mkcert

Then run:

mkcert -install

Mac users should then do (one time only):

$ mkdir -p ~/.local/share && ln -s "$(mkcert -CAROOT)" ~/.local/share

If you are using Dory

Update the ssl_certs_dir as described here:

https://github.com/reload/drupal-apache-fpm?tab=readme-ov-file#using-autogenerated-certificates

Howtos

Enable XDebug

Prerequisites:

For performance reasons XDebug is disabled by default. It can be enabled temporarily through a task:

  1. Run task dev:enable-xdebug
  2. Validate that XDebug is enabled by inspecting http://dpl-cms.docker/admin/reports/status/php. It should contain extended information about XDebug
  3. Debug the application by setting breakpoints, listen for incoming connections in your IDE and activate XDebug from you client/browser
  4. When you are finished, hit enter in the terminal where you enabled XDebug. This will disable XDebug

Download database and files from Lagoon

Retrieve the latest backup of database and files from Lagoon

Prerequisites:

Run the following command to retrieve the latest backup of database and files from a Lagoon project:

LAGOON_PROJECT=<lagoon-project-name> task lagoon:backup:restore

Copy a specific database snapshot from Lagoon environment to local setup

Prerequisites:

  • Login credentials to the Lagoon UI, or an existing database dump

The following describes how to first fetch a database-dump and then import the dump into a running local environment. Be aware that this only gives you the database, not any files from the site.

  1. To retrieve a database-dump from a running site, consult the "How do I download a database dump?" guide in the official Lagoon. Skip this step if you already have a database-dump.
  2. Place the dump in the restore/database directory, be aware that the directory is only allowed to contain a single .sql file.
  3. Start a local environment using task dev:reset
  4. Import the database by running task dev:restore:database

Copy a specific snapshot of files from Lagoon environment to local setup

Prerequisites:

  • Login credentials to the Lagoon UI, or an existing nginx files dump

The following describes how to first fetch a files backup package and then replace the files in a local environment.

If you need to get new backup files from the remote site:

  1. Login to the lagoon administration and navigate to the project/environment.
  2. Select the backup tab:

backup_tab image

  1. Retrieve the files backup you need:

retrieve image 4. Due to a UI bug you need to RELOAD the window and then it should be possible to download the nginx package.

Replace files locally:

  1. Place the files dump in the files-backup directory, be aware that the directory is only allowed to contain a single .tar.gz file.
  2. Start a local environment using task dev:reset
  3. Restore the filesš by running task dev:restore:files

Get a specific release of dpl-react - without using composer install

In a development context it is not very handy only to be able to get the latest version of the main branch of dpl-react.

So a command has been implemented that downloads the specific version of the assets and overwrites the existing library.

You need to specify which branch you need to get the assets from. The latest HEAD of the given branch is automatically build by Github actions so you just need to specify the branch you want.

It is used like this:

BRANCH=[BRANCH_FROM_DPL_REACT_REPOSITORY] task dev:dpl-react:overwrite

Example:

BRANCH=feature/more-releases task dev:dpl-react:overwrite