8.4 KiB
title | date | excerpt | tags | promoted | ||||||
---|---|---|---|---|---|---|---|---|---|---|
How to run Drupal 8 PHPUnit Tests within Docksal from PhpStorm | 2018-07-19 | How to configure PhpStorm to run automated tests within Docksal. |
|
true |
I’ve recently re-watched A Clean PHPUnit Workflow in PHPStorm on Laracasts, where Jeffrey configures PhpStorm to run tests from within the IDE. With Drupal 8 using PHPUnit too, I decided to try and do the same with a local D8 site.
Though because I’m using Docksal for my local development environment which, at least on a Mac, runs Docker containers within a virtual machine, there were some additional steps needed to achieve this and to have the tests run within the Docksal virtual machine and using the correct containers.
In this post, I’ll be using my Drupal Testing Workshop codebase as an example, which is based on the Drupal Composer project with some pre-configured Docksal configuration.
This post is separated into a few different sections:
- Allow PhpStorm to connect to the CLI container
- Add a new deployment server
- Configure PHP interpreter
- Set up PHPUnit in PhpStorm
- Running tests
Allow PhpStorm to connect to the CLI container
The first thing to do is to allow PhpStorm to connect to Docksal’s CLI container to allow it to run the tests. We can do this by exposing the container’s SSH port so that it’s available to the host machine and PhpStorm.
As this is going to be unique to my environment, I’m going to add this to
.docksal/docksal-local.yml
which I have in .gitignore
, rather than
committing it into the repository and enforcing the same port number for
everyone else and potentially causing conflicts.
In this case I’ll expose port 22 in the container to port 2225 locally.
version: '2.1'
services:
cli:
ports:
- '2225:22'
Once added, run fin start
to rebuild the project’s containers.
You can verify the change by running fin ps
and you should see something like
0.0.0.0:2225->22/tcp
under Ports for the CLI container.
Add a new Deployment server
Now PhpStorm can connect to Docksal, I can configure it to do so by adding a new deployment server.
- Open PhpStorm’s preferences, and go to 'Build, Execution, Deployment' and 'Deployment'.
- Click 'Add' to configure a new deployment server.
- Enter a name like 'Docksal', and select SFTP as the server type.
Connection settings
On the Connection tab:
- Enter your domain name - e.g.
drupaltest.docksal
as the SFTP host. This will resolve to the correct local IP address. - Enter the exposed port for the CLI container that was entered in the previous step.
- Enter "docker" as both the username and password.
You should now be able to click "Test SFTP connection" and get a successfully connected confirmation message.
Mapping settings
On the Mappings tab, add /var/www
as the deployment path so that PhpStorm is
looking in the correct place for the project code.
Configuring the PHP Interpreter
In Preferences, search for 'PHP' within 'Languages & Frameworks', and add a new CLI interpreter.
In this case I’ve called it 'Docksal PHP 7.1', used the Docksal deployment
configuration, and set the path to the PHP executable to /usr/local/bin/php
(the same path that we would get if we ran fin run which php
). You should see
both the deployment host URL displayed as well as the remote PHP version and
configuration filenames.
This can now be selected as the CLI interpreter for this project.
Set up PHPUnit in PhpStorm
In Preferences, search for 'Test Frameworks' and add a new framework.
Select 'PHPUnit by Remote Interpreter' and then the 'Docksal PHP 7.1' that we created in the last step.
Select 'Use Composer autoloader' for the PHPUnit library setting so that
PhpStorm uses the version required by Drupal core, and set the path to
/var/www/vendor/autoload.php
.
Also specify the path to the default (phpunit.xml) configuration file. This will
depend on how your project is structured, in this case it’s at
/var/www/web/core/phpunit.xml
.
Running tests
With PHPUnit configured, next to each test class and method, you can see a green circle (or a red one if the test failed the last run). You can click the circle and select to run that test class or method. You can also right-click directories in the project sidebar to run all of the tests within that directory.
When the tests start running, a new tool window will open that shows you all of the selected tests, how long each test took to run and whether it passed or failed. You can also see the CLI output from PHPUnit itself next to it.
From here, you also have the ability to re-run all of the tests, as well as a single test method or a specific test class.
Any test failures are shown here too, and for some failures like differences between two arrays you can use PhpStorm’s internal comparison tools to view the difference rather than needing to do so on the command line.
Keyboard shortcuts
As per the video, I’ve also added some keyboard shortcuts to my keymap, so I can press ⌘T to run the current test method or class that I’m in, and ⇧⌘T to re-run the last test.
Database issues
When running functional tests that require a database, I was getting a database error like the one below:
Drupal\Core\Installer\Exception\InstallerException : Resolve all issues below to continue the installation. For help configuring your database server, see the installation handbook, or contact your hosting provider.
In settings.php
, I check for the presence of /.dockerenv
to ensure that
we’re inside a Docker container, as well as the presence of a
docksal.settings.yml
file. The latter contains the database credentials for
Drupal to connect to the MySQL database.
if (file_exists('/.dockerenv') && file_exists(__DIR__ . '/docksal.settings.php')) {
include __DIR__ . '/docksal.settings.php';
}
In order to get the tests to run, I had to prevent this file from being loaded
during the tests. I can do this by checking that SIMPLETEST_DB
, an environment
variable set in phpunit.xml is not present.
// settings.php
if (file_exists('/.dockerenv') && file_exists(__DIR__ . '/docksal.settings.php') && !getenv('SIMPLETEST_DB')) {
include __DIR__ . '/docksal.settings.php';
}
With this extra condition, the database credentials are loaded correctly and the functional tests run properly.
Happy testing!