On this page
azurerm_sql_databases resource
Use the azurerm_sql_databases InSpec audit resource to test properties and configuration of Azure SQL Databases.
Azure REST API version
This resource interacts with version 2017-10-01-preview of the Azure Management API. For more information see the Official Azure Documentation.
At the moment, there doesn’t appear to be a way to select the version of the Azure API docs. If you notice a newer version being referenced in the official documentation please open an issue or submit a pull request using the updated version.
Availability
Installation
This resource is available in the inspec-azure resource pack. To use it, add the following to your inspec.yml in your top-level profile:
depends:
  - name: inspec-azure
    git: https://github.com/inspec/inspec-azure.git
You’ll also need to setup your Azure credentials; see the resource pack README.
Version
This resource first became available in 1.2.0 of the inspec-azure resource pack.
Syntax
An azurerm_sql_databases resource block returns all SQL Databases on a SQL Server, within a Rsource Group.
describe azurerm_sql_databases(resource_group: ..., server_name: ...) do
  ...
end
Examples
The following examples show how to use this InSpec audit resource.
Check SQL Databases are present
describe azurerm_sql_databases(resource_group: 'resource-group-1', server_name: 'production') do
  it            { should exist }
  its('names')  { should include 'my-database-name' }
end
Filter Criteria
- azure_sql_databasesresources are filterable on all available properties. Below are some examples.
names
Filters the results to include only those databases that match the given name. This is a string value.
describe azurerm_sql_databases(resource_group: 'rg', server_name: 'server').where{ name.eql?('production-database') } do
  it { should exist }
end
location
Filters the results to include only those resource groups that reside ina given location. This is a string value.
describe azurerm_sql_databases(resource_group: 'rg', server_name: 'server').where{ location.eql?('eastus') } do
  it { should exist }
end
Attributes
- id
- name
- kind
- location
- type
- sku
- properties
ids
Azure resource ID.
names
SQL Database name, e.g. my-sql-database.
its('names') { should include 'my-sql-database' }
kinds
Kind of sql database. This is metadata used for the Azure portal experience.
locations
Resource location, e.g. eastus.
its('locations') { should_not include 'eastus' }
type
The type of Resource, typically Microsoft.Sql/servers/databases.
sku
The name and tier of the SKU.
properties
A collection of additional configuration properties related to the SQL Database, e.g. collation.
Matchers
This InSpec audit resource has the following special matchers. For a full list of available matchers, please visit our Universal Matchers page.
exists
The control will pass if the filter returns at least one result. Use should_not if you expect zero matches.
describe azurerm_sql_databases do
  it { should exist }
end
Azure Permissions
Your Service Principal must be setup with a contributor role on the subscription you wish to test.
© Chef Software, Inc.
Licensed under the Creative Commons Attribution 3.0 Unported License.
The Chef™ Mark and Chef Logo are either registered trademarks/service marks or trademarks/servicemarks of Chef, in the United States and other countries and are used with Chef Inc's permission.
We are not affiliated with, endorsed or sponsored by Chef Inc.
 https://docs.chef.io/inspec/resources/azurerm_sql_databases/