Platform.sh

Blackfire has built-in support for Platform.sh projects. The integration is made simpler as Blackfire agent and probe are installed and enabled by default on all Platform.sh accounts.

Configuration

Add the blackfire PHP extension to the .platform.app.yaml project file:

1
2
3
runtime:
    extensions:
        - blackfire

Set the Blackfire server credentials as environment variables (run this command from the project root directory or pass the --project flag):

To auto-fill server credentials in the command below, log in first

platform.phar project:variable:set env:BLACKFIRE_SERVER_ID=XXXXplatform.phar project:variable:set env:BLACKFIRE_SERVER_TOKEN=XXXX

Builds Enterprise

Follow these steps to enable Blackfire builds on all your platform's environments each time a branch is deployed (after a push, merge, or redeploy event):

  • Download and install the platform.phar utility;
  • Enable the Blackfire's integration on SymfonyCloud:

To auto-fill token credentials and environment UUID in the command below, log in first

platform.phar integration:add --type=webhook --url='https://TOKEN_USER:TOKEN_PASSWORD@blackfire.io/api/v2/builds/env/ENV_UUID/symfonycloud'

The command asks several questions. Hit enter to accept the default for all of them. If you get a permission error, ask a project admin to upgrade your account or ask someone who is an admin to run this command.

Now, whenever you push to a SymfonyCloud environment, Blackfire will automatically trigger a build for this specific environment. Blackfire scenarios will be ran for all your pull requests.

Github integration

If you are using Github and if you have setup the synchronization between GitHub and Platform.sh, don't forget to configure the Blackfire GitHub notification channel. That way, Blackfire will post a status on your GitHub pull requests.

Develop on GitHub, Deploy to Platform.sh and Test on Blackfire Enterprise

Here is a full video tutorial to get you started with the integration of the three services: