]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - 3rdparty/modules/glance/spec/classes/glance_api_spec.rb
try again, with puppetforge modules, correctly included now
[dsa-puppet.git] / 3rdparty / modules / glance / spec / classes / glance_api_spec.rb
diff --git a/3rdparty/modules/glance/spec/classes/glance_api_spec.rb b/3rdparty/modules/glance/spec/classes/glance_api_spec.rb
new file mode 100644 (file)
index 0000000..ffb2655
--- /dev/null
@@ -0,0 +1,429 @@
+require 'spec_helper'
+
+describe 'glance::api' do
+
+  let :facts do
+    {
+      :osfamily => 'Debian',
+      :processorcount => '7',
+    }
+  end
+
+  let :default_params do
+    {
+      :verbose                  => false,
+      :debug                    => false,
+      :bind_host                => '0.0.0.0',
+      :bind_port                => '9292',
+      :registry_host            => '0.0.0.0',
+      :registry_port            => '9191',
+      :registry_client_protocol => 'http',
+      :log_file                 => '/var/log/glance/api.log',
+      :log_dir                  => '/var/log/glance',
+      :auth_type                => 'keystone',
+      :enabled                  => true,
+      :manage_service           => true,
+      :backlog                  => '4096',
+      :workers                  => '7',
+      :auth_host                => '127.0.0.1',
+      :auth_port                => '35357',
+      :auth_protocol            => 'http',
+      :auth_uri                 => 'http://127.0.0.1:5000/',
+      :keystone_tenant          => 'services',
+      :keystone_user            => 'glance',
+      :keystone_password        => 'ChangeMe',
+      :database_idle_timeout    => '3600',
+      :database_connection      => 'sqlite:///var/lib/glance/glance.sqlite',
+      :show_image_direct_url    => false,
+      :purge_config             => false,
+      :known_stores             => false,
+      :image_cache_dir          => '/var/lib/glance/image-cache',
+      :os_region_name           => 'RegionOne',
+    }
+  end
+
+  [{:keystone_password => 'ChangeMe'},
+   {
+      :verbose                  => true,
+      :debug                    => true,
+      :bind_host                => '127.0.0.1',
+      :bind_port                => '9222',
+      :registry_host            => '127.0.0.1',
+      :registry_port            => '9111',
+      :registry_client_protocol => 'https',
+      :auth_type                => 'not_keystone',
+      :enabled                  => false,
+      :backlog                  => '4095',
+      :workers                  => '5',
+      :auth_host                => '127.0.0.2',
+      :auth_port                => '35358',
+      :auth_protocol            => 'https',
+      :auth_uri                 => 'https://127.0.0.2:5000/v2.0/',
+      :keystone_tenant          => 'admin2',
+      :keystone_user            => 'admin2',
+      :keystone_password        => 'ChangeMe2',
+      :database_idle_timeout    => '36002',
+      :database_connection      => 'mysql:///var:lib@glance/glance',
+      :show_image_direct_url    => true,
+      :image_cache_dir          => '/tmp/glance',
+      :os_region_name           => 'RegionOne2',
+    }
+  ].each do |param_set|
+
+    describe "when #{param_set == {:keystone_password => 'ChangeMe'} ? "using default" : "specifying"} class parameters" do
+
+      let :param_hash do
+        default_params.merge(param_set)
+      end
+
+      let :params do
+        param_set
+      end
+
+      it { should contain_class 'glance' }
+      it { should contain_class 'glance::policy' }
+
+      it { should contain_service('glance-api').with(
+        'ensure'     => (param_hash[:manage_service] && param_hash[:enabled]) ? 'running': 'stopped',
+        'enable'     => param_hash[:enabled],
+        'hasstatus'  => true,
+        'hasrestart' => true
+      ) }
+
+      it { should_not contain_exec('validate_nova_api') }
+
+      it 'should lay down default api config' do
+        [
+          'verbose',
+          'debug',
+          'bind_host',
+          'bind_port',
+          'registry_host',
+          'registry_port',
+          'registry_client_protocol',
+          'show_image_direct_url',
+          'os_region_name',
+        ].each do |config|
+          should contain_glance_api_config("DEFAULT/#{config}").with_value(param_hash[config.intern])
+        end
+      end
+
+      it 'should lay down default cache config' do
+        [
+          'verbose',
+          'debug',
+          'registry_host',
+          'registry_port',
+          'os_region_name',
+        ].each do |config|
+          should contain_glance_cache_config("DEFAULT/#{config}").with_value(param_hash[config.intern])
+        end
+      end
+
+      it 'should config db' do
+        should contain_glance_api_config('database/connection').with_value(param_hash[:database_connection])
+        should contain_glance_api_config('database/connection').with_value(param_hash[:database_connection]).with_secret(true)
+        should contain_glance_api_config('database/idle_timeout').with_value(param_hash[:database_idle_timeout])
+      end
+
+      it 'should have  no ssl options' do
+        should contain_glance_api_config('DEFAULT/ca_file').with_ensure('absent')
+        should contain_glance_api_config('DEFAULT/cert_file').with_ensure('absent')
+        should contain_glance_api_config('DEFAULT/key_file').with_ensure('absent')
+      end
+
+      it 'should lay down default auth config' do
+        [
+          'auth_host',
+          'auth_port',
+          'auth_protocol'
+        ].each do |config|
+          should contain_glance_api_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
+        end
+      end
+      it { should contain_glance_api_config('keystone_authtoken/auth_admin_prefix').with_ensure('absent') }
+
+      it 'should configure itself for keystone if that is the auth_type' do
+        if params[:auth_type] == 'keystone'
+          should contain('paste_deploy/flavor').with_value('keystone+cachemanagement')
+
+          ['admin_tenant_name', 'admin_user', 'admin_password'].each do |config|
+            should contain_glance_api_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
+          end
+          should contain_glance_api_config('keystone_authtoken/admin_password').with_value(param_hash[:keystone_password]).with_secret(true)
+
+          ['admin_tenant_name', 'admin_user', 'admin_password'].each do |config|
+            should contain_glance_cache_config("keystone_authtoken/#{config}").with_value(param_hash[config.intern])
+          end
+          should contain_glance_cache_config('keystone_authtoken/admin_password').with_value(param_hash[:keystone_password]).with_secret(true)
+        end
+      end
+    end
+
+  end
+
+  describe 'with disabled service managing' do
+    let :params do
+      {
+        :keystone_password => 'ChangeMe',
+        :manage_service => false,
+        :enabled        => false,
+      }
+    end
+
+    it { should contain_service('glance-api').with(
+        'ensure'     => nil,
+        'enable'     => false,
+        'hasstatus'  => true,
+        'hasrestart' => true
+      ) }
+  end
+
+  describe 'with overridden pipeline' do
+    let :params do
+      {
+        :keystone_password => 'ChangeMe',
+        :pipeline          => 'keystone',
+      }
+    end
+
+    it { should contain_glance_api_config('paste_deploy/flavor').with_value('keystone') }
+  end
+
+  describe 'with blank pipeline' do
+    let :params do
+      {
+        :keystone_password => 'ChangeMe',
+        :pipeline          => '',
+      }
+    end
+
+    it { should contain_glance_api_config('paste_deploy/flavor').with_ensure('absent') }
+  end
+
+  [
+    'keystone/',
+    'keystone+',
+    '+keystone',
+    'keystone+cachemanagement+',
+    '+'
+  ].each do |pipeline|
+    describe "with pipeline incorrect value #{pipeline}" do
+      let :params do
+        {
+          :keystone_password => 'ChangeMe',
+          :pipeline          => pipeline
+        }
+      end
+
+      it { expect { should contain_glance_api_config('filter:paste_deploy/flavor') }.to\
+        raise_error(Puppet::Error, /validate_re\(\): .* does not match/) }
+    end
+  end
+
+  describe 'with overriden auth_admin_prefix' do
+    let :params do
+      {
+        :keystone_password => 'ChangeMe',
+        :auth_admin_prefix => '/keystone/main'
+      }
+    end
+
+    it { should contain_glance_api_config('keystone_authtoken/auth_admin_prefix').with_value('/keystone/main') }
+  end
+
+  [
+    '/keystone/',
+    'keystone/',
+    'keystone',
+    '/keystone/admin/',
+    'keystone/admin/',
+    'keystone/admin'
+  ].each do |auth_admin_prefix|
+    describe "with auth_admin_prefix_containing incorrect value #{auth_admin_prefix}" do
+      let :params do
+        {
+          :keystone_password => 'ChangeMe',
+          :auth_admin_prefix => auth_admin_prefix
+        }
+      end
+
+      it { expect { should contain_glance_api_config('filter:authtoken/auth_admin_prefix') }.to\
+        raise_error(Puppet::Error, /validate_re\(\): "#{auth_admin_prefix}" does not match/) }
+    end
+  end
+
+  describe 'with syslog disabled by default' do
+    let :params do
+      default_params
+    end
+
+    it { should contain_glance_api_config('DEFAULT/use_syslog').with_value(false) }
+    it { should_not contain_glance_api_config('DEFAULT/syslog_log_facility') }
+  end
+
+  describe 'with syslog enabled' do
+    let :params do
+      default_params.merge({
+        :use_syslog   => 'true',
+      })
+    end
+
+    it { should contain_glance_api_config('DEFAULT/use_syslog').with_value(true) }
+    it { should contain_glance_api_config('DEFAULT/syslog_log_facility').with_value('LOG_USER') }
+  end
+
+  describe 'with syslog enabled and custom settings' do
+    let :params do
+      default_params.merge({
+        :use_syslog   => 'true',
+        :log_facility => 'LOG_LOCAL0'
+     })
+    end
+
+    it { should contain_glance_api_config('DEFAULT/use_syslog').with_value(true) }
+    it { should contain_glance_api_config('DEFAULT/syslog_log_facility').with_value('LOG_LOCAL0') }
+  end
+
+  describe 'with log_file enabled by default' do
+    let(:params) { default_params }
+
+    it { should contain_glance_api_config('DEFAULT/log_file').with_value(default_params[:log_file]) }
+
+    context 'with log_file disabled' do
+      let(:params) { default_params.merge!({ :log_file => false }) }
+      it { should contain_glance_api_config('DEFAULT/log_file').with_ensure('absent') }
+    end
+  end
+
+  describe 'with log_dir enabled by default' do
+    let(:params) { default_params }
+
+    it { should contain_glance_api_config('DEFAULT/log_dir').with_value(default_params[:log_dir]) }
+
+    context 'with log_dir disabled' do
+      let(:params) { default_params.merge!({ :log_dir => false }) }
+      it { should contain_glance_api_config('DEFAULT/log_dir').with_ensure('absent') }
+    end
+  end
+
+  describe 'with ssl options' do
+    let :params do
+      default_params.merge({
+        :ca_file     => '/tmp/ca_file',
+        :cert_file   => '/tmp/cert_file',
+        :key_file    => '/tmp/key_file'
+      })
+    end
+
+    context 'with ssl options' do
+      it { should contain_glance_api_config('DEFAULT/ca_file').with_value('/tmp/ca_file') }
+      it { should contain_glance_api_config('DEFAULT/cert_file').with_value('/tmp/cert_file') }
+      it { should contain_glance_api_config('DEFAULT/key_file').with_value('/tmp/key_file') }
+    end
+  end
+  describe 'with known_stores by default' do
+    let :params do
+      default_params
+    end
+
+    it { should_not contain_glance_api_config('glance_store/stores').with_value('false') }
+  end
+
+  describe 'with known_stores override' do
+    let :params do
+      default_params.merge({
+        :known_stores   => ['glance.store.filesystem.Store','glance.store.http.Store'],
+      })
+    end
+
+    it { should contain_glance_api_config('glance_store/stores').with_value("glance.store.filesystem.Store,glance.store.http.Store") }
+  end
+
+  describe 'with deprecated sql parameters' do
+    let :params do
+      default_params.merge({
+        :sql_connection   => 'mysql://user:pass@db/db',
+        :sql_idle_timeout => '30'
+      })
+    end
+
+    it 'configures database' do
+      should contain_glance_api_config('database/connection').with_value('mysql://user:pass@db/db')
+      should contain_glance_api_config('database/idle_timeout').with_value('30')
+    end
+  end
+
+  describe 'while validating the service with default command' do
+    let :params do
+      default_params.merge({
+        :validate => true,
+      })
+    end
+    it { should contain_exec('execute glance-api validation').with(
+      :path        => '/usr/bin:/bin:/usr/sbin:/sbin',
+      :provider    => 'shell',
+      :tries       => '10',
+      :try_sleep   => '2',
+      :command     => 'glance --os-auth-url http://localhost:5000/v2.0 --os-tenant-name services --os-username glance --os-password ChangeMe image-list',
+    )}
+
+    it { should contain_anchor('create glance-api anchor').with(
+      :require => 'Exec[execute glance-api validation]',
+    )}
+  end
+
+  describe 'while validating the service with custom command' do
+    let :params do
+      default_params.merge({
+        :validate            => true,
+        :validation_options  => { 'glance-api' => { 'command' => 'my-script' } }
+      })
+    end
+    it { should contain_exec('execute glance-api validation').with(
+      :path        => '/usr/bin:/bin:/usr/sbin:/sbin',
+      :provider    => 'shell',
+      :tries       => '10',
+      :try_sleep   => '2',
+      :command     => 'my-script',
+    )}
+
+    it { should contain_anchor('create glance-api anchor').with(
+      :require => 'Exec[execute glance-api validation]',
+    )}
+  end
+
+  describe 'on Debian platforms' do
+    let :facts do
+      { :osfamily => 'Debian' }
+    end
+    let(:params) { default_params }
+
+    it { should contain_package('glance-api').with(
+        :tag => ['openstack'],
+    )}
+  end
+
+  describe 'on RedHat platforms' do
+    let :facts do
+      { :osfamily => 'RedHat' }
+    end
+    let(:params) { default_params }
+
+    it { should contain_package('openstack-glance').with(
+        :tag => ['openstack'],
+    )}
+  end
+
+  describe 'on unknown platforms' do
+    let :facts do
+      { :osfamily => 'unknown' }
+    end
+    let(:params) { default_params }
+
+    it 'should fails to configure glance-api' do
+        expect { subject }.to raise_error(Puppet::Error, /module glance only support osfamily RedHat and Debian/)
+    end
+  end
+
+end