Merge "Support for PowerFlex cinder backend"
This commit is contained in:
commit
b9fcb5ac46
151
manifests/backend/dellemc_powerflex.pp
Normal file
151
manifests/backend/dellemc_powerflex.pp
Normal file
@ -0,0 +1,151 @@
|
||||
# == define: cinder::backend::dellemc_powerflex
|
||||
#
|
||||
# Configures Cinder to use the Dell EMC PowerFlex Block Storage driver
|
||||
# Compatible for multiple backends
|
||||
#
|
||||
# === Parameters
|
||||
#
|
||||
# [*san_login*]
|
||||
# (required) Administrative user account name used to access the storage
|
||||
# system or proxy server.
|
||||
#
|
||||
# [*san_password*]
|
||||
# (required) Password for the administrative user account specified in the
|
||||
# san_login option.
|
||||
#
|
||||
# [*san_ip*]
|
||||
# (required) The hostname (or IP address) for the storage system or proxy
|
||||
# server.
|
||||
#
|
||||
# [*powerflex_storage_pools*]
|
||||
# (String) (required) Storage Pools. Comma separated list of storage pools used to provide volumes.
|
||||
# Each pool should be specified as a protection_domain_name:storage_pool_name value
|
||||
#
|
||||
# [*volume_backend_name*]
|
||||
# (optional) The name of the cinder::backend::dellemc_powerflex ressource
|
||||
# Defaults to $name.
|
||||
#
|
||||
# [*backend_availability_zone*]
|
||||
# (optional) Availability zone for this volume backend.
|
||||
# If not set, the storage_availability_zone option value
|
||||
# is used as the default for all backends.
|
||||
# Defaults to $::os_service_default.
|
||||
#
|
||||
# [*powerflex_allow_migration_during_rebuild*]
|
||||
# (optional) (Boolean) Allow volume migration during rebuild.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*powerflex_allow_non_padded_volumes*]
|
||||
# (optional) (Boolean) Allow volumes to be created in Storage Pools
|
||||
# when zero padding is disabled.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*powerflex_max_over_subscription_ratio*]
|
||||
# (optional) (Floating point) max_over_subscription_ratio setting for the driver.
|
||||
# Maximum value allowed is 10.0.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*powerflex_rest_server_port*]
|
||||
# (optional) (String) The TCP port to use for communication with the storage
|
||||
# system or proxy.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*powerflex_round_volume_capacity*]
|
||||
# (optional) (Boolean) Round volume sizes up to 8GB boundaries. PowerFlex/ScaleIO
|
||||
# requires volumes to be sized in multiples of 8GB. If set to False,
|
||||
# volume creation will fail for volumes not sized properly
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*powerflex_server_api_version*]
|
||||
# (optional) (String) PowerFlex/ScaleIO API version. This value should be left as the
|
||||
# default value unless otherwise instructed by technical support.
|
||||
#
|
||||
# [*powerflex_unmap_volume_before_deletion*]
|
||||
# (optional) (Boolean) Unmap volumes before deletion.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*san_thin_provision*]
|
||||
# (optional) (Boolean) Wheater to use thin provisioning or not.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*driver_ssl_cert_verify*]
|
||||
# (optional) Verify the server certificate
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*driver_ssl_cert_path*]
|
||||
# (optional) Server certificate path.
|
||||
# Defaults to $::os_service_default
|
||||
#
|
||||
# [*manage_volume_type*]
|
||||
# (optional) Whether or not manage Cinder Volume type.
|
||||
# If set to true, a Cinder Volume type will be created
|
||||
# with volume_backend_name=$volume_backend_name key/value.
|
||||
# Defaults to false.
|
||||
#
|
||||
# [*extra_options*]
|
||||
# (optional) Hash of extra options to pass to the backend stanza
|
||||
# Defaults to: {}
|
||||
# Example :
|
||||
# { 'powerflex_backend/param1' => { 'value' => value1 } }
|
||||
#
|
||||
# === Examples
|
||||
#
|
||||
# cinder::backend::dellemc_powerflex { 'myBackend':
|
||||
# san_login => 'admin',
|
||||
# san_password => 'password',
|
||||
# san_ip => 'powerflex_.mycorp.com',
|
||||
# powerflex_storage_pools => 'domain1:pool1',
|
||||
# }
|
||||
#
|
||||
define cinder::backend::dellemc_powerflex(
|
||||
$san_login,
|
||||
$san_password,
|
||||
$san_ip,
|
||||
$powerflex_storage_pools,
|
||||
$volume_backend_name = $name,
|
||||
$backend_availability_zone = $::os_service_default,
|
||||
$powerflex_allow_migration_during_rebuild = $::os_service_default,
|
||||
$powerflex_allow_non_padded_volumes = $::os_service_default,
|
||||
$powerflex_max_over_subscription_ratio = $::os_service_default,
|
||||
$powerflex_rest_server_port = $::os_service_default,
|
||||
$powerflex_round_volume_capacity = $::os_service_default,
|
||||
$powerflex_server_api_version = $::os_service_default,
|
||||
$powerflex_unmap_volume_before_deletion = $::os_service_default,
|
||||
$san_thin_provision = $::os_service_default,
|
||||
$driver_ssl_cert_verify = $::os_service_default,
|
||||
$driver_ssl_cert_path = $::os_service_default,
|
||||
$manage_volume_type = false,
|
||||
$extra_options = {},
|
||||
) {
|
||||
|
||||
include cinder::deps
|
||||
|
||||
cinder_config {
|
||||
"${name}/volume_driver": value => 'cinder.volume.drivers.dell_emc.powerflex.driver.PowerFlexDriver';
|
||||
"${name}/san_login": value => $san_login;
|
||||
"${name}/san_password": value => $san_password, secret => true;
|
||||
"${name}/san_ip": value => $san_ip;
|
||||
"${name}/powerflex_storage_pools": value => $powerflex_storage_pools;
|
||||
"${name}/volume_backend_name": value => $volume_backend_name;
|
||||
"${name}/backend_availability_zone": value => $backend_availability_zone;
|
||||
"${name}/powerflex_allow_migration_during_rebuild": value => $powerflex_allow_migration_during_rebuild;
|
||||
"${name}/powerflex_allow_non_padded_volumes": value => $powerflex_allow_non_padded_volumes;
|
||||
"${name}/powerflex_max_over_subscription_ratio": value => $powerflex_max_over_subscription_ratio;
|
||||
"${name}/powerflex_rest_server_port": value => $powerflex_rest_server_port;
|
||||
"${name}/powerflex_round_volume_capacity": value => $powerflex_round_volume_capacity;
|
||||
"${name}/powerflex_server_api_version": value => $powerflex_server_api_version;
|
||||
"${name}/powerflex_unmap_volume_before_deletion": value => $powerflex_unmap_volume_before_deletion;
|
||||
"${name}/san_thin_provision": value => $san_thin_provision;
|
||||
"${name}/driver_ssl_cert_verify": value => $driver_ssl_cert_verify;
|
||||
"${name}/driver_ssl_cert_path": value => $driver_ssl_cert_path;
|
||||
}
|
||||
if $manage_volume_type {
|
||||
cinder_type { $name:
|
||||
ensure => present,
|
||||
properties => ["volume_backend_name=${name}"],
|
||||
}
|
||||
}
|
||||
|
||||
create_resources('cinder_config', $extra_options)
|
||||
|
||||
}
|
@ -0,0 +1,3 @@
|
||||
---
|
||||
features:
|
||||
- Adding support for PowerFlex cinder driver.
|
89
spec/defines/cinder_backend_dellemc_powerflex_spec.rb
Normal file
89
spec/defines/cinder_backend_dellemc_powerflex_spec.rb
Normal file
@ -0,0 +1,89 @@
|
||||
require 'spec_helper'
|
||||
|
||||
describe 'cinder::backend::dellemc_powerflex' do
|
||||
let (:title) { 'powerflex' }
|
||||
|
||||
let :params1 do
|
||||
{
|
||||
:san_login => 'admin',
|
||||
:san_password => 'password',
|
||||
:san_ip => 'powerflex.example.com',
|
||||
:powerflex_rest_server_port => '443',
|
||||
:manage_volume_type => true,
|
||||
:san_thin_provision => false,
|
||||
}
|
||||
end
|
||||
|
||||
let :params2 do
|
||||
{
|
||||
:backend_availability_zone => 'my_zone',
|
||||
:powerflex_allow_migration_during_rebuild => 'true',
|
||||
:powerflex_allow_non_padded_volumes => 'false',
|
||||
:powerflex_max_over_subscription_ratio => '6.0',
|
||||
:powerflex_round_volume_capacity => true,
|
||||
:powerflex_server_api_version => '3.5',
|
||||
:powerflex_storage_pools => 'domain1:pool1,domain2:pool2',
|
||||
:powerflex_unmap_volume_before_deletion => false,
|
||||
:driver_ssl_cert_path => '/path/cert.pem',
|
||||
:driver_ssl_cert_verify => true,
|
||||
}
|
||||
end
|
||||
|
||||
let :params do
|
||||
params1.merge(params2)
|
||||
end
|
||||
|
||||
shared_examples 'cinder::backend::dellemc_powerflex' do
|
||||
context 'powerflex volume driver' do
|
||||
it { is_expected.to contain_cinder_config("#{title}/volume_driver").with(
|
||||
:value => 'cinder.volume.drivers.dell_emc.powerflex.driver.PowerFlexDriver'
|
||||
)}
|
||||
|
||||
it {
|
||||
is_expected.to contain_cinder_config("#{title}/san_login").with_value('admin')
|
||||
is_expected.to contain_cinder_config("#{title}/san_ip").with_value('powerflex.example.com')
|
||||
is_expected.to contain_cinder_config("#{title}/san_thin_provision").with_value('false')
|
||||
is_expected.to contain_cinder_config("#{title}/powerflex_rest_server_port").with_value('443')
|
||||
}
|
||||
|
||||
it {
|
||||
params2.each_pair do |config,value|
|
||||
is_expected.to contain_cinder_config("#{title}/#{config}").with_value(value)
|
||||
end
|
||||
}
|
||||
|
||||
it { is_expected.to contain_cinder_config("#{title}/san_password").with_secret(true) }
|
||||
end
|
||||
|
||||
context 'powerflex backend with additional configuration' do
|
||||
before :each do
|
||||
params.merge!( :extra_options => {"#{title}/param1" => {'value' => 'value1'}} )
|
||||
end
|
||||
|
||||
it { is_expected.to contain_cinder_config("#{title}/param1").with_value('value1') }
|
||||
end
|
||||
|
||||
context 'powerflex backend with cinder type' do
|
||||
before :each do
|
||||
params.merge!( :manage_volume_type => true )
|
||||
end
|
||||
|
||||
it { is_expected.to contain_cinder_type("#{title}").with(
|
||||
:ensure => 'present',
|
||||
:properties => ["volume_backend_name=#{title}"]
|
||||
)}
|
||||
end
|
||||
end
|
||||
|
||||
on_supported_os({
|
||||
:supported_os => OSDefaults.get_supported_os
|
||||
}).each do |os,facts|
|
||||
context "on #{os}" do
|
||||
let (:facts) do
|
||||
facts.merge!(OSDefaults.get_facts())
|
||||
end
|
||||
|
||||
it_behaves_like 'cinder::backend::dellemc_powerflex'
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue
Block a user