2017-02-09 16:47:46 +00:00
2017-02-23 12:46:15 +00:00
require 'azure_backend'
2017-02-09 16:47:46 +00:00
require 'uri'
2017-02-20 17:15:40 +00:00
# Class to test the data disks that are attached to the specified VM
#
# @author Russell Seymour
#
# @attr_reader [Array<Hash>] params Array of hashes containing information about all the data disks attached to the machine
2017-02-09 16:47:46 +00:00
class AzureVmDataDisks < Inspec . resource ( 1 )
2017-03-01 17:14:09 +00:00
name 'azure_virtual_machine_datadisks'
2017-02-09 16:47:46 +00:00
desc "
This resource gather information about the data disks attached to a virtual machine
"
example "
describe azure_vm_datadisks ( host : 'example-01' , resource_group : 'MyResourceGroup' ) . where { ( disk == 1 and size > = 10 ) } do
it { should be true }
end
"
attr_reader :params
2017-02-20 17:15:40 +00:00
# Constructor to retrieve all the data disks for the specified machines and populate the params property
#
# @author Russell Seymour
#
# @param [Hash] opts Hashtable of options
# opts[:host] The name of the host in the resource group. NOTE, this is the name as seen in Azure and not the name of the machine in the Operating System
# opts[:resource_group] Name of the resource group in which the host will be found
2017-02-09 16:47:46 +00:00
def initialize ( opts )
@opts = opts
2017-02-17 17:25:30 +00:00
@helpers = Helpers . new
2017-02-09 16:47:46 +00:00
# Get the VM that needs to be interrogated
2017-03-01 17:20:59 +00:00
vm = @helpers . get_vm ( @opts [ :name ] , @opts [ :resource_group ] )
2017-02-09 16:47:46 +00:00
# Parse the data disks
@params = parse_data_disks ( vm . storage_profile . data_disks )
end
2017-02-20 10:05:40 +00:00
# Create a FilterTable which can be used by controls to interogate the data disks
2017-02-09 16:47:46 +00:00
filter = FilterTable . create
filter . add_accessor ( :where )
. add_accessor ( :entries )
2017-02-17 17:06:15 +00:00
. add_accessor ( :count )
. add_accessor ( :has_disks? )
2017-02-09 16:47:46 +00:00
. add ( :disk , field : 'disk' )
. add ( :caching , field : 'caching' )
. add ( :create_option , field : 'create_option' )
. add ( :size , field : 'size' )
. add ( :lun , field : 'lun' )
. add ( :name , field : 'name' )
. add ( :uri , field : 'uri' )
. add ( :storage_account , field : 'storage_account' )
filter . connect ( self , :params )
2017-02-20 10:05:40 +00:00
# Determine how many data disks have been applied to the machine
#
2017-02-20 17:15:40 +00:00
# @return [Integer] Number of data disks attached to the machine
#
2017-02-17 17:06:15 +00:00
def count
entries . length
end
2017-02-20 10:05:40 +00:00
# Determine if any data disks are attached to the machine
#
2017-02-20 17:15:40 +00:00
# @return [Boolean] States if the VM has any disks attached
#
2017-03-02 14:08:33 +00:00
def has_data_disks?
2017-02-20 13:51:41 +00:00
! entries . empty?
2017-02-17 17:06:15 +00:00
end
2017-02-09 16:47:46 +00:00
private
2017-02-20 17:15:40 +00:00
# Parse the data disks and extract the necssary information
#
# @param [Array] data_disks Array of data disk objects
#
# @return [Array<Hash>] Array of hashes providing the information about the data disks attached to the machine
#
2017-02-09 16:47:46 +00:00
def parse_data_disks ( data_disks )
data_disks . each_with_index . map do | disk , index |
parse_data_disk_item ( disk , index )
end . compact
end
2017-02-20 17:15:40 +00:00
# Parses each data disk item and extracts the information to be tested
#
# @return [Hash] Data disk information
#
2017-02-09 16:47:46 +00:00
def parse_data_disk_item ( disk , index )
# Parse the uri of the disk so that the storage account can be retrieved
uri = URI . parse ( disk . vhd . uri )
{
'disk' = > index ,
'caching' = > disk . caching ,
'create_option' = > disk . create_option ,
'size' = > disk . disk_size_gb ,
'lun' = > disk . lun ,
'name' = > disk . name ,
'uri' = > disk . vhd . uri ,
2017-02-17 17:25:30 +00:00
'storage_account' = > uri . host . split ( '.' ) . first ,
2017-02-09 16:47:46 +00:00
}
end
2017-02-17 17:25:30 +00:00
end