Enable and fix kilo amulet tests.

This commit is contained in:
Corey Bryant 2015-07-12 02:39:11 +00:00
parent 5e98a2c66e
commit 016e5f17c9
2 changed files with 114 additions and 42 deletions

0
tests/017-basic-trusty-kilo Normal file → Executable file
View File

View File

@ -47,6 +47,8 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
other_services = [{'name': 'mysql'}, other_services = [{'name': 'mysql'},
{'name': 'rabbitmq-server'}, {'name': 'keystone'}, {'name': 'rabbitmq-server'}, {'name': 'keystone'},
{'name': 'nova-cloud-controller'}] {'name': 'nova-cloud-controller'}]
if self._get_openstack_release() >= self.trusty_kilo:
other_services.append({'name': 'neutron-api'})
super(NeutronGatewayBasicDeployment, self)._add_services(this_service, super(NeutronGatewayBasicDeployment, self)._add_services(this_service,
other_services) other_services)
@ -62,11 +64,16 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'nova-cloud-controller:identity-service': 'keystone:identity-service', 'nova-cloud-controller:identity-service': 'keystone:identity-service',
'nova-cloud-controller:amqp': 'rabbitmq-server:amqp' 'nova-cloud-controller:amqp': 'rabbitmq-server:amqp'
} }
if self._get_openstack_release() >= self.trusty_kilo:
relations['neutron-api:shared-db'] = 'mysql:shared-db'
relations['neutron-api:amqp'] = 'rabbitmq-server:amqp'
relations['neutron-api:neutron-api'] = 'nova-cloud-controller:neutron-api'
relations['neutron-api:identity-service'] = 'keystone:identity-service'
super(NeutronGatewayBasicDeployment, self)._add_relations(relations) super(NeutronGatewayBasicDeployment, self)._add_relations(relations)
def _configure_services(self): def _configure_services(self):
"""Configure all of the services.""" """Configure all of the services."""
neutron_gateway_config = {} neutron_api_config = neutron_gateway_config = {}
if self.git: if self.git:
release = self._get_openstack_release_string() release = self._get_openstack_release_string()
reqs_branch = 'stable/' + release reqs_branch = 'stable/' + release
@ -93,7 +100,8 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'admin-token': 'ubuntutesting'} 'admin-token': 'ubuntutesting'}
nova_cc_config = {'network-manager': 'Quantum', nova_cc_config = {'network-manager': 'Quantum',
'quantum-security-groups': 'yes'} 'quantum-security-groups': 'yes'}
configs = {'neutron-gateway': neutron_gateway_config, configs = {'neutron-api': neutron_api_config,
'neutron-gateway': neutron_gateway_config,
'keystone': keystone_config, 'keystone': keystone_config,
'nova-cloud-controller': nova_cc_config} 'nova-cloud-controller': nova_cc_config}
super(NeutronGatewayBasicDeployment, self)._configure_services(configs) super(NeutronGatewayBasicDeployment, self)._configure_services(configs)
@ -255,7 +263,7 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'keystone_host': u.valid_ip, 'keystone_host': u.valid_ip,
'quantum_plugin': 'ovs', 'quantum_plugin': 'ovs',
'auth_host': u.valid_ip, 'auth_host': u.valid_ip,
'service_username': 'quantum_s3_ec2_nova', 'service_username': 'nova',
'service_tenant_name': 'services' 'service_tenant_name': 'services'
} }
@ -309,11 +317,7 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'DEFAULT': { 'DEFAULT': {
'verbose': 'False', 'verbose': 'False',
'debug': 'False', 'debug': 'False',
'lock_path': '/var/lock/neutron', 'core_plugin': 'neutron.plugins.ml2.plugin.Ml2Plugin',
'rabbit_userid': 'neutron',
'rabbit_virtual_host': 'openstack',
'rabbit_password': rabbitmq_relation['password'],
'rabbit_host': rabbitmq_relation['hostname'],
'control_exchange': 'neutron', 'control_exchange': 'neutron',
'notification_driver': 'neutron.openstack.common.notifier.' 'notification_driver': 'neutron.openstack.common.notifier.'
'list_notifier', 'list_notifier',
@ -325,9 +329,28 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'/etc/neutron/rootwrap.conf' '/etc/neutron/rootwrap.conf'
} }
} }
if self._get_openstack_release() >= self.trusty_kilo:
expected['DEFAULT']['core_plugin'] = \ oslo_concurrency = {
'neutron.plugins.ml2.plugin.Ml2Plugin' 'oslo_concurrency': {
'lock_path':'/var/lock/neutron'
}
}
oslo_messaging_rabbit = {
'oslo_messaging_rabbit': {
'rabbit_userid': 'neutron',
'rabbit_virtual_host': 'openstack',
'rabbit_password': rabbitmq_relation['password'],
'rabbit_host': rabbitmq_relation['hostname'],
}
}
expected.update(oslo_concurrency)
expected.update(oslo_messaging_rabbit)
else:
expected['DEFAULT']['lock_path'] = '/var/lock/neutron'
expected['DEFAULT']['rabbit_userid'] = 'neutron'
expected['DEFAULT']['rabbit_virtual_host'] = 'openstack'
expected['DEFAULT']['rabbit_password'] = rabbitmq_relation['password']
expected['DEFAULT']['rabbit_host'] = rabbitmq_relation['hostname']
for section, pairs in expected.iteritems(): for section, pairs in expected.iteritems():
ret = u.validate_config_data(unit, conf, section, pairs) ret = u.validate_config_data(unit, conf, section, pairs)
@ -403,9 +426,16 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
unit = self.neutron_gateway_sentry unit = self.neutron_gateway_sentry
conf = '/etc/neutron/fwaas_driver.ini' conf = '/etc/neutron/fwaas_driver.ini'
if self._get_openstack_release() >= self.trusty_kilo:
expected = { expected = {
'driver': 'neutron.services.firewall.drivers.linux.' 'driver': 'neutron_fwaas.services.firewall.drivers.'
'iptables_fwaas.IptablesFwaasDriver', 'linux.iptables_fwaas.IptablesFwaasDriver',
'enabled': 'True'
}
else:
expected = {
'driver': 'neutron.services.firewall.drivers.'
'linux.iptables_fwaas.IptablesFwaasDriver',
'enabled': 'True' 'enabled': 'True'
} }
@ -437,6 +467,8 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'ovs_use_veth': 'True', 'ovs_use_veth': 'True',
'handle_internal_only_routers': 'True' 'handle_internal_only_routers': 'True'
} }
if self._get_openstack_release() >= self.trusty_kilo:
expected['admin_user'] = 'nova'
ret = u.validate_config_data(unit, conf, 'DEFAULT', expected) ret = u.validate_config_data(unit, conf, 'DEFAULT', expected)
if ret: if ret:
@ -465,6 +497,9 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'user_group': 'nogroup' 'user_group': 'nogroup'
} }
} }
if self._get_openstack_release() >= self.trusty_kilo:
expected['DEFAULT']['device_driver'] = ('neutron_lbaas.services.' +
'loadbalancer.drivers.haproxy.namespace_driver.HaproxyNSDriver')
for section, pairs in expected.iteritems(): for section, pairs in expected.iteritems():
ret = u.validate_config_data(unit, conf, section, pairs) ret = u.validate_config_data(unit, conf, section, pairs)
@ -495,6 +530,8 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'nova_metadata_ip': neutron_gateway_relation['private-address'], 'nova_metadata_ip': neutron_gateway_relation['private-address'],
'nova_metadata_port': '8775' 'nova_metadata_port': '8775'
} }
if self._get_openstack_release() >= self.trusty_kilo:
expected['admin_user'] = 'nova'
if self._get_openstack_release() >= self.precise_icehouse: if self._get_openstack_release() >= self.precise_icehouse:
expected['cache_url'] = 'memory://?default_ttl=5' expected['cache_url'] = 'memory://?default_ttl=5'
@ -545,31 +582,63 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
endpoint_type='publicURL') endpoint_type='publicURL')
expected = { expected = {
'DEFAULT': {
'logdir': '/var/log/nova', 'logdir': '/var/log/nova',
'state_path': '/var/lib/nova', 'state_path': '/var/lib/nova',
'lock_path': '/var/lock/nova',
'root_helper': 'sudo nova-rootwrap /etc/nova/rootwrap.conf', 'root_helper': 'sudo nova-rootwrap /etc/nova/rootwrap.conf',
'verbose': 'False', 'verbose': 'False',
'use_syslog': 'False', 'use_syslog': 'False',
'api_paste_config': '/etc/nova/api-paste.ini', 'api_paste_config': '/etc/nova/api-paste.ini',
'enabled_apis': 'metadata', 'enabled_apis': 'metadata',
'multi_host': 'True', 'multi_host': 'True',
'service_neutron_metadata_proxy': 'True', 'network_api_class': 'nova.network.neutronv2.api.API',
}
}
if self._get_openstack_release() >= self.trusty_kilo:
neutron = {
'neutron': {
'auth_strategy': 'keystone',
'url': nova_cc_relation['quantum_url'],
'admin_tenant_name': 'services',
'admin_username': 'nova',
'admin_password': nova_cc_relation['service_password'],
'admin_auth_url': ep,
'service_metadata': 'True',
}
}
oslo_concurrency = {
'oslo_concurrency': {
'lock_path':'/var/lock/nova'
}
}
oslo_messaging_rabbit = {
'oslo_messaging_rabbit': {
'rabbit_userid': 'neutron', 'rabbit_userid': 'neutron',
'rabbit_virtual_host': 'openstack', 'rabbit_virtual_host': 'openstack',
'rabbit_password': rabbitmq_relation['password'], 'rabbit_password': rabbitmq_relation['password'],
'rabbit_host': rabbitmq_relation['hostname'], 'rabbit_host': rabbitmq_relation['hostname'],
'network_api_class': 'nova.network.neutronv2.api.API',
'neutron_auth_strategy': 'keystone',
'neutron_url': nova_cc_relation['quantum_url'],
'neutron_admin_tenant_name': 'services',
'neutron_admin_username': 'quantum_s3_ec2_nova',
'neutron_admin_password': nova_cc_relation['service_password'],
'neutron_admin_auth_url': ep
} }
}
expected.update(oslo_concurrency)
expected.update(oslo_messaging_rabbit)
else:
d = 'DEFAULT'
expected[d]['lock_path'] = '/var/lock/nova'
expected[d]['rabbit_userid'] = 'neutron'
expected[d]['rabbit_virtual_host'] = 'openstack'
expected[d]['rabbit_password'] = rabbitmq_relation['password']
expected[d]['rabbit_host'] = rabbitmq_relation['hostname']
expected[d]['service_neutron_metadata_proxy'] = 'True'
expected[d]['neutron_auth_strategy'] = 'keystone'
expected[d]['neutron_url'] = nova_cc_relation['quantum_url']
expected[d]['neutron_admin_tenant_name'] = 'services'
expected[d]['neutron_admin_username'] = 'quantum_s3_ec2_nova'
expected[d]['neutron_admin_password'] = \
nova_cc_relation['service_password']
expected[d]['neutron_admin_auth_url'] = ep
ret = u.validate_config_data(unit, conf, 'DEFAULT', expected) for section, pairs in expected.iteritems():
ret = u.validate_config_data(unit, conf, section, pairs)
if ret: if ret:
message = "nova config error: {}".format(ret) message = "nova config error: {}".format(ret)
amulet.raise_status(amulet.FAIL, msg=message) amulet.raise_status(amulet.FAIL, msg=message)
@ -621,6 +690,9 @@ class NeutronGatewayBasicDeployment(OpenStackAmuletDeployment):
'ipsec_status_check_interval': '60' 'ipsec_status_check_interval': '60'
} }
} }
if self._get_openstack_release() >= self.trusty_kilo:
expected['vpnagent']['vpn_device_driver'] = ('neutron_vpnaas.' +
'services.vpn.device_drivers.ipsec.OpenSwanDriver')
for section, pairs in expected.iteritems(): for section, pairs in expected.iteritems():
ret = u.validate_config_data(unit, conf, section, pairs) ret = u.validate_config_data(unit, conf, section, pairs)