This project is ABANDONNED
The purpose of this repo is to provide Magento 2 extensions developers an easy to setup local environment.
The setup was created using Docker, on top of the following images repository: https://github.com/thecodingmachine/docker-images-php (please check this repo for more info about technology stack, assumptions, etc.).
The setup was created on Ubuntu 18.04 and is tested on this OS, however the plan is to make it OS-agnostic.
In current state the setup includes three Magento versions: 2.1.17, 2.2.8 and 2.3.2. They are all installed with sample data.
Disclaimer: In many places of this README file the following strings are used as placeholders for version numbers:
- For Magento:
<MAGE_VER>
. Please replace it with21
for Magento 2.1.17,22
for Magento 2.2.8 or23
for Magento 2.3.2. - For PHP-CLI:
<PHP_VER>
. Please replace it with71
for PHP 7.1 or72
for PHP 7.2.
In order to setup this environment you need Docker and Docker Compose installed on your machine.
- Clone this repository.
- Copy
.env.sample
file tosrc/mage<MAGE_VER>/.env
. - Customize
.env
files if you need. - CD to
src/mage<MAGE_VER>
and rundocker-compose up
. - Add
127.0.0.1 magento2.local
to your local hosts file (on Ubuntu:/etc/hosts
). - Your Magento frontend will be accessible by the following URL:
https://magento2.local:80<MAGE_VER>
. - Your Magento backend will be accessible by the following URL:
https://magento2.local:80<MAGE_VER>/admin
. Admin credentials can be found in.env
file.
Import docker/app/files/magento2root.pem
root certificate to your browsers so they don't complain about self-signed certificates.
If you need to access Magento URLs not only from your browsers (eg. CURL), import the root certificate to your OS.
- Open Settings.
- Go to "Build, Execution, Deployment" > "Docker".
- Add new Docker server with default config.
- Open Settings.
- Go to "Languages & Frameworks" > "PHP".
- Set "PHP language level" to the version you will be using.
- Create new remote PHP interpreter using Docker:
- Use Docker server created in 4.2.1
- Use
magento2env_phpcli<PHP_VER>:latest
Docker image - Set "Debugger extension":
- for PHP 7.1:
/usr/local/lib/php/extensions/no-debug-non-zts-20160303/xdebug.so
- for PHP 7.2:
/usr/local/lib/php/extensions/no-debug-non-zts-20170718/xdebug.so
- for PHP 7.1:
- Open Settings.
- Go to "Languages & Frameworks" > "PHP" > "Servers".
- Add new server:
- Name it
mage<MAGE_VER>
- Put
magento2.local
as a host - Put
80<MAGE_VER>
as a port - Put
Xdebug
as a debugger - Set path mapping:
src/mage<MAGE_VER>
>/var/www/html
src/modules
>/var/www/modules
- Name it
No configuration needed for debugging browser requests. See: https://www.jetbrains.com/help/phpstorm/zero-configuration-debugging.html
- Open Settings.
- Go to "Languages & Frameworks" > "PHP" > "Test Frameworks".
- Add new config:
- Use CLI interpreter created in 4.2.2
- Use Composer autoloader with following path to script:
/opt/project/src/mage<MAGE_VER>/vendor/autoload.php
- Set Default configuration file to
/opt/project/src/mage<MAGE_VER>/dev/tests/unit/phpunit.xml.dist
No configuration needed. All e-mails sent by Magento are caught by MailHog. Simply open http://127.0.0.1:8125 in your browser to check them.
cd src/mage<MAGE_VER>
docker-compose up
First find mage<MAGE_VER>
container name by running docker ps
. Then run docker exec -it <container name> /bin/bash
, example: docker exec -it magento2env_mage22_1_fcb38b06f0c6 /bin/bash
.
When you're inside, you act as docker
user and you can perform any console command (also with sudo
), eg. bin/magento
.
- GIT clone your extension to
src/modules/<VENDOR>/<Extension>
, eg.src/modules/Orba/Payupl
. - Add your extension as a dependency to Composer, using
src/mage<MAGE_VER>/composer.json
file. Set the same version as in extension'scomposer.json
file. Example:{ ... "require": { ... "orba/magento2-payupl": "2.0.0-dev" } ... }
- Go inside container (see: 5.2).
- Run
composer update
. - Run
bin/magento setup:upgrade
inside container. - If your extension uses template files, you need to set config value "Advanced > Developer > Template Settings > Allow Symlinks" to "Yes".
Disclaimer: composer.json
file is created automatically from a template during first docker-compose up
run.
Watchout: This setup requires that your extension's registration.php
looks like this:
<?php
\Magento\Framework\Component\ComponentRegistrar::register(
\Magento\Framework\Component\ComponentRegistrar::MODULE,
'Vendor_Extension',
isset($file) ? dirname($file) : __DIR__
);
This is a workaround for symbolic links issue.
- Enable Listening for PHP Debug Connections (green icon in toolbar)
- Go inside container (see: 5.2).
- Run
export XDEBUG_CONFIG="idekey=123"
(this is needed only once per session). - Run your PHP script with the following param:
-dxdebug.remote_enable=1
, eg.php -dxdebug.remote_enable=1 bin/magento
.
Please don't hesitate to create an issue if you found any bug.
Also, please suggest your enhancements either via an issue or a pull request.