Exclude and include checks in Macaron
Note
This feature is only available from Macaron 0.8.0
This tutorial will show how you can configure Macaron to:
- exclude checks that you don’t want to run. 
- include only checks that you want to run. 
Note
By default, Macaron will run all of its checks.
Prerequisites
- You are expected to have gone through this tutorial. 
- This tutorial requires a high-level understanding of checks in Macaron and how they depend on each other. Please see this page for more information. 
Motivating example
Let’s say you want to run the analysis on Maven artifact io.micronaut/micronaut-core version 4.3.10.
Normally, this is how you would run Macaron:
./run_macaron.sh analyze --package-url pkg:maven/io.micronaut/micronaut-core@4.3.10
However, there can be checks in Macaron that are not relevant for the io.micronaut/micronaut-core artifact.
For example, the mcn_provenance_witness_level_one_1 check (defined in ProvenanceWitnessL1Check) is not relevant because micronaut-projects/micronaut-core generates and publishes SLSA provenances and no Witness provenances. Therefore, we could exclude this check from running by performing the following steps.
- In your current directory, create a - defaults.iniconfiguration file with the following content.
[analysis.checks]
exclude = mcn_provenance_witness_level_one_1
include = *
In the ini configuration above:
- The - excludeoption contains the check ID- mcn_provenance_witness_level_one_1. The check with this ID will be excluded.
- The - includeoption contains the glob pattern- *. Checks with IDs matching this glob pattern will be included in the analysis. In this case,- *matches all check IDs.
With these two configuration options, all checks except for the excluded mcn_provenance_witness_level_one_1 will run.
- Run Macaron analyze by providing the path to the custom - defaults.iniconfiguration.
./run_macaron.sh --defaults-path ./defaults.ini analyze --package-url pkg:maven/io.micronaut/micronaut-core@4.3.10
This time, the check mcn_provenance_witness_level_one_1 doesn’t run. After the analyze command finishes, we can view the data that Macaron has gathered about the micronaut-projects/micronaut-core repository at v4.3.10 in an HTML report. Note that the result of the excluded check is not recorded in the Macaron HTML reports, JSON reports, or the database).
open output/reports/maven/io_micronaut/micronaut-core/micronaut-core.html
 
Configuring exclude/include checks in ini config
You can configure the exclusion and inclusion of checks through the [analysis.checks] section in the defaults.ini file. These are the defaults values:
[analysis.checks]
# By default, we don't exclude any checks.
exclude =
# By default, we run all checks available.
include = *
The exclude and include options accept a list of strings (terminated by new lines). Each element in that list can either be:
- An ID of a check 
- A glob pattern (similar to patterns used in glob). When a glob pattern is given, all check IDs that match it will be included in the corresponding - excludeor- includelist.
The two lists of exclude and include check IDs obtained from your configuration can be defined as:
- EXPLICIT_EXCLUDE= checks excluded from the user configuration.
- EXPLICIT_INCLUDE= checks included from the user configuration.
Checks in Macaron depend on each other. Therefore, when you want to exclude/include a check, you must be aware of how that will affect its transitive children/parents:
- If a check is excluded, all of the children which can be transitively reached from it will be excluded. 
- If a check is included, all of the parents which can be transitively reached from it will be included. 
We define the list of check IDs after extending to transitive parents/children as:
- EFFECTIVE_INCLUDED=- EXPLICIT_INCLUDEset plus transitive parents
- EFFECTIVE_EXCLUDED=- EXPLICIT_EXCLUDEset plus transitive children
The final list of checks that will run can be defined as:
- FINAL_INCLUDED=- EFFECTIVE_INCLUDEDminus- EFFECTIVE_EXCLUDED
More examples
Not running any check
The following configurations will result in no check running and Macaron will return on error.
[analysis.checks]
exclude = *
include = *
[analysis.checks]
exclude =
include =
Run a subset of checks
[analysis.checks]
exclude =
include =
    mcn_provenance_witness_level_one_1
    mcn_trusted_builder_level_three_1
This will result in mcn_provenance_witness_level_one_1, mcn_trusted_builder_level_three_1, and their transitive parents running.
Disable a subset of checks
[analysis.checks]
exclude =
    mcn_provenance_witness_level_one_1
    mcn_trusted_builder_level_three_1
include = *
This will result in mcn_provenance_witness_level_one_1, mcn_trusted_builder_level_three_1, and their transitive children not running.
Only run checks whose ID starts with mcn_build_*
[analysis.checks]
exclude =
include =
    mcn_build_*