Phpstorm Behat



Behat tests can be initiated right from PHPStorm, saving a lot of hassle, as well as simplifying access to tests for less technical users. Behat v3.3 does come pre-installed via composer and is found at /usr/local/bin/behat. If you wish to use your own version of Behat, you’ll need that path later. PhpStorm is renowned for its zero-configuration Visual Debugger, providing extraordinary insight into what goes on in your application at every step. It works with Xdebug and Zend Debugger, and can be used both locally and remotely. Unit Testing with PHPUnit, BDD with Behat.

Phpstorm behati prinsloo

With PhpStorm, you can practice behaviour-driven development by running scenarios using the Behat framework. Currently PhpStorm supports integration with Behat 3 and Behat 2 versions.

Native support of Behat in PhpStorm includes:

  • Recognition of and coding assistance for feature scenario files and PHP scenario definition files.

  • Gherkin syntax support in feature files: Feature, Scenario, Given, When, Then, And, and But keywords.

  • Recognition of @given, @when, and @then annotations in definition files.

  • Setting correspondence between scenarios and their definitions through regular expressions in accordance with the PCRE standard for Behat 2.4 and PCRE+ for Behat 3.0. Turnip expressions are also welcome.

Atom Material File Icons Custom File and IDE Icons for improved visual grepping This plugin is a port of the Atom. The difficulty is that PhpStorm places /usr/bin at the front of the PATH variable when running an external tool or running command line. The result is that when behat runs, it sets the php default library to /usr/lib and not to the version of PHP that I have set for the project.

Before you start

Make sure the PHP interpreter is configured in PhpStorm on the PHP page, as described in Configure local PHP interpreters and Configure remote PHP interpreters. Note that Behat 3 requires PHP 5.5 and later.

Download and install Behat

Before you start, make sure Composer is installed on your machine and initialized in the current project as described in Composer dependency manager.

Download Behat installation package manually

  • Download behat.phar from the Behat Downloads page and save it on your computer:

    • If you need full coding assistance in addition to the ability of running Behat tests, store behat.phar under the root of the project where Behat will be later used.

    • If you only need to run Behat tests and you do not need any coding assistance, you can save behat.phar outside the project.

Download and install Behat with Composer

  1. Inside composer.json, add the behat/behat dependency record to the require or require-dev section. Press Ctrl+Space to get code completion for the package name and version.

  2. Do one of the following:

    • Click the Install shortcut link on top of the editor panel.

    • If the Non-installed Composer packages inspection is enabled, PhpStorm will highlight the declared dependencies that are not currently installed. Press Alt+Enter and select whether you want to install a specific dependency or all dependencies at once.

Click next to the package record in the composer.json editor gutter to jump to the corresponding Settings/Preferences page and configure Behat manually.

Phpstorm Behat Docker

Learn more about installing Behat from Behat Official website.

Phpstorm Behat

Integrate Behat with PhpStorm in a project

If you use a local PHP interpreter, PhpStorm performs initial Behat configuration automatically. In the case of remote PHP interpreters, manual Behat configuration is required.

Phpstorm

Configure Behat automatically

  1. Store the behat.yml or behat.yml.dist configuration file under the project root.

  2. Install Behat with Composer.

PhpStorm will create the local framework configuration on the Test Frameworks page and the Behat run/debug configuration.

Configure Behat manually

  1. In the Settings/Preferences dialog Ctrl+Alt+S, go to PHP | Test Frameworks.

    On the Test Frameworks page that opens, click in the central pane and choose the configuration type from the list:

    • In local configurations, the default project PHP interpreter is used, see Default project CLI interpreters for details.

    • To use Behat with a remote PHP interpreter, choose one of the configurations in the dialog that opens:

  2. In the Behat Library area, specify the location of the Behat executable file or behat.phar archive.

    Click next to the Path to Behat directory or phar file field. PhpStorm detects the version of Behat and displays it below the field.
  3. In the Test Runner area, appoint the configuration YML file to use for launching and executing scenarios.
    By default, Behat looks for a behat.yml configuration file in the project root folder or in the config folder. You can appoint a custom configuration file.

    • Clear the Default configuration file checkbox to have Behat use the behat.yml configuration file from the project root folder or from the config folder. If no such file is found, test execution fails, therefore it may be more reliable to specify the configuration file explicitly.

    • Select the Default configuration file checkbox to specify your own YML configuration file. This file will be later used as default in all Behat run/debug configurations.

      In the field, specify the location of the configuration file to use. Type the path manually or click and choose the file in the dialog that opens.

Run and debug Behat tests

For information about writing Behat features, refer to the Behat Documentation.

Run or debug Behat tests

  • In the Project tool window, select the feature file to run your tests from and choose Run '<feature file>' or Debug '<feature file>' from the context menu of the selection:

    PhpStorm generates a default run configuration and starts a run/debug test session with it.

Save an automatically generated default configuration

  • After a test session is over, choose Save <default_test_configuration_name> from the context menu of the file or folder.

Create a custom run/debug configuration

  1. In the Project tool window, select the file or folder with the tests to run and choose Create run configuration from the context menu. Alternatively, choose Run | Edit Configurations from the main menu, then click and choose Behat from the list.

  2. In the Behat dialog that opens, specify the scenarios to run, choose the PHP interpreter to use, and customize its behavior by specifying the options and arguments to be passed to the PHP executable.

Phpstorm Behat

Monitor Behat test results

PhpStorm shows the tests execution results in the Test Runner tab of the Run tool window.

The tab is divided into 2 main areas:

  • The left-hand area lets you drill down through all unit tests to see the succeeded and failed ones. You can filter tests, export results, and use the context menu commands to run specific tests or navigate to the source code.

  • The right-hand area displays the raw Behat output.

Run Behat tests automatically

Phpstorm Best Color Themes

You can have PhpStorm re-run tests automatically when the affected code is changed. This option is configured per run/debug configuration and can be applied to a test, a test file, a folder, or a composite selection of tests, depending on the test scope specified in this run/debug configuration.

Phpstorm Behati Prinsloo

  1. Run the tests.

  2. On the Test Runner tab, press the toggle button on the toolbar:

  3. Optionally, click the button and set the time delay for launching the tests upon the changes in the code: