Skip to content

Latest commit

 

History

History
138 lines (91 loc) · 3.74 KB

azurerm_sql_databases.md

File metadata and controls

138 lines (91 loc) · 3.74 KB
title platform
About the azurerm_sql_databases Resource
azure

azurerm_sql_databases

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_databases resources 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

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.