Test your IaC files
Overview
With Snyk Infrastructure as Code, you can test your configuration files with the CLI. This page provides detailed information on how to use certain options for the snyk iac test command.  For information about all of the options see the snyk iac test command help. For details about testing the various configuration files, see the following pages:
In the examples that follow, you can replace the sample file names with the names of your own files, like deployment.yaml.
Test for an issue in specified files
When you provide no arguments, the snyk iac test command recursively traverses the current working directory and scans every file it finds:
snyk iac testYou can scan specific files under the current working directory. If you provide one or more file paths, the command scans only those files:
snyk iac test file-1.tf dir/file-2.tfThe command returns an error if you provide file paths outside the current working directory. For example, this is not a valid invocation of the command:
snyk iac test ../main.tfTest for an issue in a directory of files
When you provide no arguments, the command recursively traverses the current working directory and scans every file it finds:
snyk iac testYou can restrict the scan to a specific directory:
snyk iac test my-folderYou can limit the depth of the directories that are traversed. The current working directory has a depth of one; directories under the current working directory have a depth of two, and so on. For example, if you want to restrict the search to the current working directory and two more levels of directories, you can invoke the command like this:
snyk iac test --detection-depth=3The command returns an error if you provide directory paths outside the current working directory. For example, this is not a valid invocation of the command:
snyk iac test ../my-folderOutput the test format as JSON
Use the following command to receive output in the JSON file format:
snyk iac test  --jsonThis can be helpful if you want to store a snapshot of the results locally or process the results in another tool for reporting and further analysis.
Example:
snyk iac test main.tf --jsonOutput the test format as SARIF
SARIF is an open standard for the output of static analysis tools. You can view and save the results of your tests as a SARIF file for analysis in another tool.
Use the following command to receive output in the SARIF file format
snyk iac test main.tf --sarifTo save this to a file output, you can run the following command:
snyk iac test main.tf --sarif-file-output=snyk.sarifDisplay issues only above a specific severity level
Use the following command to limit results displayed to issues above a specified severity.
snyk iac test  --severity-threshold=mediumExample:
snyk iac test main.tf --severity-threshold=mediumThis displays only results that have a severity value of medium or higher.
Target a specific Snyk Organization
You can control the severity settings of your security rules at the Organization level in the Snyk UI. By targeting a specific Organization in your CLI tests, you can determine which rules should be run and their severity.
Use the following command to specify the Organization:
snyk iac test  --org=infrastructureExample:
snyk iac test main.tf --org=infrastructureYou can also set the org flag in snyk config, so you do not need to use the --org option each time you want to specify the Organization.
snyk config set org=infrastructureExample Test Output
Snyk Infrastructure as Code
✔ Test completed.
Issues
Low Severity Issues: 1
  [Low] API Gateway access logging disabled
  Info:    Amazon Api Gateway access logging is not enabled. Audit records may not be available during investigation
  Rule:    https://security.snyk.io/rules/cloud/SNYK-CC-TF-118
  Path:    resource > aws_api_gateway_stage[denied] > access_log_settings
  File:    aws_api_gateway_stage_logging.tf
  Resolve: Set `access_log_settings` attribute
-------------------------------------------------------
Test Summary
  Organization: demo-org
✔ Files without issues: 0
✗ Files with issues: 1
  Invalid files: 0
  Ignored issues: 0
  Total issues: 1 [ 0 critical, 0 high, 0 medium, 1 low ]Last updated
Was this helpful?

