azure_subnets Resource
Use the azure_subnets
InSpec audit resource to test the properties related to subnets of a virtual network.
Azure REST API Version, Endpoint, and HTTP Client Parameters
This resource interacts with API versions supported by the resource provider.
The api_version
can be defined as a resource parameter.
If not provided, this resource uses the latest version.
For more information, refer to the azure_generic_resource
document.
Unless defined, this resource uses the azure_cloud
global endpoint and default values for the HTTP client.
For more information, refer to the resource pack README.
Install
This resource is available in the Chef InSpec Azure resource pack.
For information on configuring your Azure environment for Chef InSpec and creating an InSpec profile that uses the InSpec Azure resource pack, see the Chef InSpec documentation for the Azure cloud platform.
Syntax
The resource_group
and vnet
are required parameters.
describe azure_subnets(resource_group: 'RESOURCE_GROUP', vnet: 'VNET_NAME') do
#...
end
Parameters
resource_group
- Azure resource group where the targeted resource resides.
vnet
- The virtual network where the subnet you wish to test is a part of.
Properties
ids
- A list of the unique resource IDs.
Field:
id
names
- A list of all the resources being interrogated.
Field:
name
etags
- A list of etags defined on the resources.
Field:
etag
Note
Examples
Exists if any subnets exist for a specified virtual network in the resource group
describe azure_subnets(resource_group: 'RESOURCE_GROUP', vnet: 'VNET_NAME') do
it { should exist }
end
Filters the results to only those that match the specified name
describe azure_subnets(resource_group: 'RESOURCE_GROUP', vnet: 'VNET_NAME')
.where(name: 'MySubnet') do
it { should exist }
end
Matchers
For a full list of available matchers, see our Universal Matchers page.This resource has the following special matchers.
exists
# Should not exist if no subnets are in the virtual network.
describe azure_subnets(resource_group: 'RESOURCE_GROUP', vnet: 'VNET_NAME') do
it { should_not exist }
end
Azure Permissions
Your Service Principal must be set up with at least a contributor
role on the subscription you wish to test.