]> git.donarmstrong.com Git - dsa-puppet.git/blobdiff - 3rdparty/modules/nova/spec/classes/nova_network_neutron_spec.rb
try again, with puppetforge modules, correctly included now
[dsa-puppet.git] / 3rdparty / modules / nova / spec / classes / nova_network_neutron_spec.rb
diff --git a/3rdparty/modules/nova/spec/classes/nova_network_neutron_spec.rb b/3rdparty/modules/nova/spec/classes/nova_network_neutron_spec.rb
new file mode 100644 (file)
index 0000000..20eaafc
--- /dev/null
@@ -0,0 +1,100 @@
+require 'spec_helper'
+
+describe 'nova::network::neutron' do
+
+  let :default_params do
+    { :neutron_auth_strategy           => 'keystone',
+      :neutron_url                     => 'http://127.0.0.1:9696',
+      :neutron_url_timeout             => '30',
+      :neutron_admin_tenant_name       => 'services',
+      :neutron_default_tenant_id       => 'default',
+      :neutron_region_name             => 'RegionOne',
+      :neutron_admin_username          => 'neutron',
+      :neutron_admin_auth_url          => 'http://127.0.0.1:35357/v2.0',
+      :neutron_ovs_bridge              => 'br-int',
+      :neutron_extension_sync_interval => '600',
+      :security_group_api              => 'neutron',
+      :firewall_driver                 => 'nova.virt.firewall.NoopFirewallDriver',
+      :vif_plugging_is_fatal           => true,
+      :vif_plugging_timeout            => '300',
+      :dhcp_domain                     => 'novalocal'
+    }
+  end
+
+  let :params do
+    { :neutron_admin_password => 's3cr3t' }
+  end
+
+
+  context 'with required parameters' do
+    it 'configures neutron endpoint in nova.conf' do
+      should contain_nova_config('neutron/admin_password').with_value(params[:neutron_admin_password]).with_secret(true)
+      should contain_nova_config('DEFAULT/network_api_class').with_value('nova.network.neutronv2.api.API')
+      should contain_nova_config('DEFAULT/dhcp_domain').with_value(default_params[:dhcp_domain])
+      should contain_nova_config('neutron/auth_strategy').with_value(default_params[:neutron_auth_strategy])
+      should contain_nova_config('neutron/url').with_value(default_params[:neutron_url])
+      should contain_nova_config('neutron/url_timeout').with_value(default_params[:neutron_url_timeout])
+      should contain_nova_config('neutron/admin_tenant_name').with_value(default_params[:neutron_admin_tenant_name])
+      should contain_nova_config('neutron/default_tenant_id').with_value(default_params[:neutron_default_tenant_id])
+      should contain_nova_config('neutron/region_name').with_value(default_params[:neutron_region_name])
+      should contain_nova_config('neutron/admin_username').with_value(default_params[:neutron_admin_username])
+      should contain_nova_config('neutron/admin_auth_url').with_value(default_params[:neutron_admin_auth_url])
+      should contain_nova_config('neutron/extension_sync_interval').with_value(default_params[:neutron_extension_sync_interval])
+    end
+    it 'configures Nova to use Neutron Bridge Security Groups and Firewall' do
+      should contain_nova_config('DEFAULT/firewall_driver').with_value(default_params[:firewall_driver])
+      should contain_nova_config('DEFAULT/security_group_api').with_value(default_params[:security_group_api])
+      should contain_nova_config('neutron/ovs_bridge').with_value(default_params[:neutron_ovs_bridge])
+    end
+    it 'configures neutron vif plugging events in nova.conf' do
+      should contain_nova_config('DEFAULT/vif_plugging_is_fatal').with_value(default_params[:vif_plugging_is_fatal])
+      should contain_nova_config('DEFAULT/vif_plugging_timeout').with_value(default_params[:vif_plugging_timeout])
+    end
+  end
+
+  context 'when overriding class parameters' do
+    before do
+      params.merge!(
+        :neutron_url                     => 'http://10.0.0.1:9696',
+        :neutron_url_timeout             => '30',
+        :neutron_admin_tenant_name       => 'openstack',
+        :neutron_default_tenant_id       => 'default',
+        :neutron_region_name             => 'RegionTwo',
+        :neutron_admin_username          => 'neutron2',
+        :neutron_admin_auth_url          => 'http://10.0.0.1:35357/v2.0',
+        :network_api_class               => 'network.api.class',
+        :security_group_api              => 'nova',
+        :firewall_driver                 => 'nova.virt.firewall.IptablesFirewallDriver',
+        :neutron_ovs_bridge              => 'br-int',
+        :neutron_extension_sync_interval => '600',
+        :vif_plugging_is_fatal           => false,
+        :vif_plugging_timeout            => '0',
+       :dhcp_domain                     => 'foo'
+      )
+    end
+
+    it 'configures neutron endpoint in nova.conf' do
+      should contain_nova_config('neutron/auth_strategy').with_value(default_params[:neutron_auth_strategy])
+      should contain_nova_config('neutron/admin_password').with_value(params[:neutron_admin_password]).with_secret(true)
+      should contain_nova_config('DEFAULT/network_api_class').with_value('network.api.class')
+      should contain_nova_config('DEFAULT/dhcp_domain').with_value(params[:dhcp_domain])
+      should contain_nova_config('neutron/url').with_value(params[:neutron_url])
+      should contain_nova_config('neutron/url_timeout').with_value(params[:neutron_url_timeout])
+      should contain_nova_config('neutron/admin_tenant_name').with_value(params[:neutron_admin_tenant_name])
+      should contain_nova_config('neutron/default_tenant_id').with_value(params[:neutron_default_tenant_id])
+      should contain_nova_config('neutron/region_name').with_value(params[:neutron_region_name])
+      should contain_nova_config('neutron/admin_username').with_value(params[:neutron_admin_username])
+      should contain_nova_config('neutron/admin_auth_url').with_value(params[:neutron_admin_auth_url])
+      should contain_nova_config('neutron/extension_sync_interval').with_value(params[:neutron_extension_sync_interval])
+    end
+    it 'configures Nova to use Neutron Security Groups and Firewall' do
+      should contain_nova_config('DEFAULT/firewall_driver').with_value(params[:firewall_driver])
+      should contain_nova_config('DEFAULT/security_group_api').with_value(params[:security_group_api])
+      should contain_nova_config('neutron/ovs_bridge').with_value(params[:neutron_ovs_bridge])
+    end
+    it 'configures neutron vif plugging events in nova.conf' do
+      should contain_nova_config('DEFAULT/vif_plugging_is_fatal').with_value(params[:vif_plugging_is_fatal])
+      should contain_nova_config('DEFAULT/vif_plugging_timeout').with_value(params[:vif_plugging_timeout])
+    end
+  end
+end