]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - 3rdparty/modules/cinder/spec/classes/cinder_keystone_auth_spec.rb
try again, with puppetforge modules, correctly included now
[dsa-puppet.git] / 3rdparty / modules / cinder / spec / classes / cinder_keystone_auth_spec.rb
diff --git a/3rdparty/modules/cinder/spec/classes/cinder_keystone_auth_spec.rb b/3rdparty/modules/cinder/spec/classes/cinder_keystone_auth_spec.rb
new file mode 100644 (file)
index 0000000..9c3690b
--- /dev/null
@@ -0,0 +1,135 @@
+require 'spec_helper'
+
+describe 'cinder::keystone::auth' do
+
+  let :req_params do
+    {:password => 'pw'}
+  end
+
+  describe 'with only required params' do
+
+    let :params do
+      req_params
+    end
+
+    it 'should contain auth info' do
+
+      should contain_keystone_user('cinder').with(
+        :ensure   => 'present',
+        :password => 'pw',
+        :email    => 'cinder@localhost',
+        :tenant   => 'services'
+      )
+      should contain_keystone_user_role('cinder@services').with(
+        :ensure  => 'present',
+        :roles   => 'admin'
+      )
+      should contain_keystone_service('cinder').with(
+        :ensure      => 'present',
+        :type        => 'volume',
+        :description => 'Cinder Service'
+      )
+      should contain_keystone_service('cinderv2').with(
+        :ensure      => 'present',
+        :type        => 'volumev2',
+        :description => 'Cinder Service v2'
+      )
+
+    end
+    it { should contain_keystone_endpoint('RegionOne/cinder').with(
+      :ensure       => 'present',
+      :public_url   => 'http://127.0.0.1:8776/v1/%(tenant_id)s',
+      :admin_url    => 'http://127.0.0.1:8776/v1/%(tenant_id)s',
+      :internal_url => 'http://127.0.0.1:8776/v1/%(tenant_id)s'
+    ) }
+    it { should contain_keystone_endpoint('RegionOne/cinderv2').with(
+      :ensure       => 'present',
+      :public_url   => 'http://127.0.0.1:8776/v2/%(tenant_id)s',
+      :admin_url    => 'http://127.0.0.1:8776/v2/%(tenant_id)s',
+      :internal_url => 'http://127.0.0.1:8776/v2/%(tenant_id)s'
+    ) }
+
+  end
+
+  context 'when overriding endpoint params' do
+     let :params do
+       req_params.merge(
+        :public_address    => '10.0.42.1',
+        :admin_address     => '10.0.42.2',
+        :internal_address  => '10.0.42.3',
+        :region            => 'RegionThree',
+        :port              => '4242',
+        :admin_protocol    => 'https',
+        :internal_protocol => 'https',
+        :public_protocol   => 'https',
+        :volume_version    => 'v42'
+      )
+     end
+
+    it { should contain_keystone_endpoint('RegionThree/cinder').with(
+      :ensure       => 'present',
+      :public_url   => 'https://10.0.42.1:4242/v42/%(tenant_id)s',
+      :admin_url    => 'https://10.0.42.2:4242/v42/%(tenant_id)s',
+      :internal_url => 'https://10.0.42.3:4242/v42/%(tenant_id)s'
+    )}
+
+    it { should contain_keystone_endpoint('RegionThree/cinderv2').with(
+      :ensure       => 'present',
+      :public_url   => 'https://10.0.42.1:4242/v2/%(tenant_id)s',
+      :admin_url    => 'https://10.0.42.2:4242/v2/%(tenant_id)s',
+      :internal_url => 'https://10.0.42.3:4242/v2/%(tenant_id)s'
+    )}
+  end
+
+
+  describe 'when endpoint should not be configured' do
+    let :params do
+      req_params.merge(
+        :configure_endpoint    => false,
+        :configure_endpoint_v2 => false
+      )
+    end
+    it { should_not contain_keystone_endpoint('RegionOne/cinder') }
+    it { should_not contain_keystone_endpoint('RegionOne/cinderv2') }
+  end
+
+  describe 'when user should not be configured' do
+    let :params do
+      req_params.merge(
+        :configure_user => false
+      )
+    end
+
+    it { should_not contain_keystone_user('cinder') }
+
+    it { should contain_keystone_user_role('cinder@services') }
+
+    it { should contain_keystone_service('cinder').with(
+        :ensure      => 'present',
+        :type        => 'volume',
+        :description => 'Cinder Service'
+    ) }
+
+  end
+
+  describe 'when user and user role should not be configured' do
+    let :params do
+      req_params.merge(
+        :configure_user      => false,
+        :configure_user_role => false
+      )
+    end
+
+    it { should_not contain_keystone_user('cinder') }
+
+    it { should_not contain_keystone_user_role('cinder@services') }
+
+    it { should contain_keystone_service('cinder').with(
+        :ensure      => 'present',
+        :type        => 'volume',
+        :description => 'Cinder Service'
+    ) }
+
+  end
+
+end