Support for Dell EMC Unity Cinder Driver
authorrajinir <rajini_ram@dell.com>
Wed, 26 Jul 2017 19:56:08 +0000 (14:56 -0500)
committerrajinir <rajini_ram@dell.com>
Sat, 29 Jul 2017 00:57:10 +0000 (19:57 -0500)
This changes adds Dell EMC Unity backend as composable service
and matches the tripleo-heat-templates.

Change-Id: I015f7dfec4bedf72332d91b91cda3ef1dc8caf8c

manifests/profile/base/cinder/volume.pp
manifests/profile/base/cinder/volume/dellemc_unity.pp [new file with mode: 0644]
spec/classes/tripleo_profile_base_cinder_unity_spec.rb [new file with mode: 0644]

index bdfdd17..252bae1 100644 (file)
 #   (Optional) Whether to enable the delsc backend
 #   Defaults to false
 #
+# [*cinder_enable_dellemc_unity_backend*]
+#   (Optional) Whether to enable the unity backend
+#   Defaults to false
+#
 # [*cinder_enable_hpelefthand_backend*]
 #   (Optional) Whether to enable the hpelefthand backend
 #   Defaults to false
 #   Defaults to hiera('step')
 #
 class tripleo::profile::base::cinder::volume (
-  $cinder_enable_pure_backend        = false,
-  $cinder_enable_dellsc_backend      = false,
-  $cinder_enable_hpelefthand_backend = false,
-  $cinder_enable_dellps_backend      = false,
-  $cinder_enable_iscsi_backend       = true,
-  $cinder_enable_netapp_backend      = false,
-  $cinder_enable_nfs_backend         = false,
-  $cinder_enable_rbd_backend         = false,
-  $cinder_enable_scaleio_backend     = false,
-  $cinder_enable_vrts_hs_backend     = false,
-  $cinder_user_enabled_backends      = hiera('cinder_user_enabled_backends', undef),
-  $step                              = Integer(hiera('step')),
+  $cinder_enable_pure_backend          = false,
+  $cinder_enable_dellsc_backend        = false,
+  $cinder_enable_dellemc_unity_backend = false,
+  $cinder_enable_hpelefthand_backend   = false,
+  $cinder_enable_dellps_backend        = false,
+  $cinder_enable_iscsi_backend         = true,
+  $cinder_enable_netapp_backend        = false,
+  $cinder_enable_nfs_backend           = false,
+  $cinder_enable_rbd_backend           = false,
+  $cinder_enable_scaleio_backend       = false,
+  $cinder_enable_vrts_hs_backend       = false,
+  $cinder_user_enabled_backends        = hiera('cinder_user_enabled_backends', undef),
+  $step                                = Integer(hiera('step')),
 ) {
   include ::tripleo::profile::base::cinder
 
@@ -100,6 +105,13 @@ class tripleo::profile::base::cinder::volume (
       $cinder_dellsc_backend_name = undef
     }
 
+    if $cinder_enable_dellemc_unity_backend {
+      include ::tripleo::profile::base::cinder::volume::dellemc_unity
+      $cinder_dellemc_unity_backend_name = hiera('cinder::backend::dellemc_unity::volume_backend_name', 'tripleo_dellemc_unity')
+    } else {
+      $cinder_dellemc_unity_backend_name = undef
+    }
+
     if $cinder_enable_hpelefthand_backend {
       include ::tripleo::profile::base::cinder::volume::hpelefthand
       $cinder_hpelefthand_backend_name = hiera('cinder::backend::hpelefthand_iscsi::volume_backend_name', 'tripleo_hpelefthand')
@@ -161,6 +173,7 @@ class tripleo::profile::base::cinder::volume (
                                       $cinder_pure_backend_name,
                                       $cinder_dellps_backend_name,
                                       $cinder_dellsc_backend_name,
+                                      $cinder_dellemc_unity_backend_name,
                                       $cinder_hpelefthand_backend_name,
                                       $cinder_netapp_backend_name,
                                       $cinder_nfs_backend_name,
diff --git a/manifests/profile/base/cinder/volume/dellemc_unity.pp b/manifests/profile/base/cinder/volume/dellemc_unity.pp
new file mode 100644 (file)
index 0000000..fb9c36f
--- /dev/null
@@ -0,0 +1,47 @@
+# Copyright (c) 2016-2017 Dell Inc, or its subsidiaries.
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+# == Class: tripleo::profile::base::cinder::volume::dellemc_unity
+#
+# Cinder Volume dellemc_unity profile for tripleo
+#
+# === Parameters
+#
+# [*backend_name*]
+#   (Optional) Name given to the Cinder backend stanza
+#   Defaults to 'tripleo_dellemc_unity'
+#
+# [*step*]
+#   (Optional) The current step in deployment. See tripleo-heat-templates
+#   for more details.
+#   Defaults to hiera('step')
+#
+class tripleo::profile::base::cinder::volume::dellemc_unity (
+  $backend_name = hiera('cinder::backend::dellemc_unity::volume_backend_name', 'tripleo_dellemc_unity'),
+  $step         = Integer(hiera('step')),
+) {
+  include ::tripleo::profile::base::cinder::volume
+
+  if $step >= 4 {
+    cinder::backend::dellemc_unity { $backend_name :
+      san_ip                   => hiera('cinder::backend::dellemc_unity::san_ip', undef),
+      san_login                => hiera('cinder::backend::dellemc_unity::san_login', undef),
+      san_password             => hiera('cinder::backend::dellemc_unity::san_password', undef),
+      storage_protocol         => hiera('cinder::backend::dellemc_unity::storage_protocol', undef),
+      unity_io_ports           => hiera('cinder::backend::dellemc_unity::unity_io_ports', undef),
+      unity_storage_pool_names => hiera('cinder::backend::dellemc_unity::unity_storage_pool_names', undef),
+    }
+  }
+
+}
diff --git a/spec/classes/tripleo_profile_base_cinder_unity_spec.rb b/spec/classes/tripleo_profile_base_cinder_unity_spec.rb
new file mode 100644 (file)
index 0000000..38f362b
--- /dev/null
@@ -0,0 +1,57 @@
+# Copyright (c) 2016-2017 Dell Inc, or its subsidiaries
+#
+# Licensed under the Apache License, Version 2.0 (the "License"); you may
+# not use this file except in compliance with the License. You may obtain
+# a copy of the License at
+#
+#      http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+# License for the specific language governing permissions and limitations
+# under the License.
+#
+
+require 'spec_helper'
+
+describe 'tripleo::profile::base::cinder::volume::dellemc_unity' do
+  shared_examples_for 'tripleo::profile::base::cinder::volume::dellemc_unity' do
+    before :each do
+      facts.merge!({ :step => params[:step] })
+    end
+
+    context 'with step less than 4' do
+      let(:params) { { :step => 3 } }
+
+      it 'should do nothing' do
+        is_expected.to contain_class('tripleo::profile::base::cinder::volume::dellemc_unity')
+        is_expected.to contain_class('tripleo::profile::base::cinder::volume')
+        is_expected.to contain_class('tripleo::profile::base::cinder')
+        is_expected.to_not contain_cinder__backend__dellemc_unity('tripleo_dellemc_unity')
+      end
+    end
+
+    context 'with step 4' do
+      let(:params) { {
+        :step => 4,
+      } }
+
+      it 'should trigger complete configuration' do
+        # TODO(aschultz): check hiera parameters
+        is_expected.to contain_cinder__backend__dellemc_unity('tripleo_dellemc_unity')
+      end
+    end
+  end
+
+
+  on_supported_os.each do |os, facts|
+    context "on #{os}" do
+      let(:facts) do
+        facts.merge({ :hostname => 'node.example.com' })
+      end
+
+      it_behaves_like 'tripleo::profile::base::cinder::volume::dellemc_unity'
+    end
+  end
+end