Empirical uses a JSON configuration file, which is located at empiricalrc.json, to describe the test to run. This configuration is declarative, in the sense that you define what you want to test, and Empirical will internally implement the expected behavior.

Configuration reference

The empiricalrc.json configuration file has two high-level properties:

Code editor integration

Your code editor can give you auto-completions and detect linting errors for this configuration file. This uses a JSON Schema definition which is hosted by Empirical.

There are two ways to configure the schema definition.

$schema property

Use the $schema property in the configuration file to specify the JSON schema URL.

empiricalrc.json
{
  "$schema": "https://assets.empirical.run/config/schema/v1.14.json",
  "runs": [
    // ...
  ],
  "dataset": {
    // ...
  }
}

Visual Studio Code

Add the json.schemas property to your VS Code configuration (user or workspace). This maps the empiricalrc.json file to use the JSON schema.

settings.json
{
  "json.schemas": [
    {
      "fileMatch": [
        "empiricalrc.json"
      ],
      "url": "https://assets.empirical.run/config/schema/v1.14.json"
    }
  ]
}