Skip to content


Statix has its own test format. These tests can help to debug your specification and isolate issues. In this section, we explain the format and the output of such tests.

Test Format

Statix tests should reside in *.stxtest files, and look as follows:

resolve $Constraint


At the top level, the resolve keyword indicates this is a test file. After this keyword, the constraint that should be solved when executing the test is provided. Finally, any section that can be found in a regular module can be added to a test.

A test can be executed using the traditional or the concurrent solver with the Spoofax > Evaluate > Evaluate Test or Spoofax > Evaluate > Evaluate Test (Concurrent) menu, respectively.

Test Output

When a test is executed, a .stxresult file with the test result will open. This file contains three sections.

First, under the substitution header, a mapping from the top-level existentially quantified variables to their values is provided. Due to the normalization Statix applies, there are sometimes additional entries for wildcards and return values of functional predicates.

Secondly, under analysis and scope graph, the scope graph that models the test constraint is shown. A scope graph consists of a list of scope terms, which look as follows

$ScopeName {
  relations {
    $RelationID : $Term+
  edges {
    $LabelID: $Scope+

That is, for each label and relation for which entries exists in a scope, a list of associated scopes/data is shown.

Empty Scopes

Note that no entry for an empty scope will be present.

Finally, under the errors, warnings and notes headers, the appropriate messages of these types are shown. The message value is equal to the top line of a regular Statix message, but no traces are displayed. Terms in templates are formatted three levels deep.

Last update: 2021-11-15
Back to top