Make nova-network use FixedIP object for updates

This makes nova-network manager use the FixedIP object for
updates instead of direct database calls.

Related to blueprint nova-network-objects

Change-Id: Ia191148cf7510ffdb0fbd4186fa34bb4c5ab1b0f
This commit is contained in:
Dan Smith 2014-01-16 14:36:32 -08:00
parent 79121d9a11
commit 542958fac7
2 changed files with 28 additions and 25 deletions
nova
network
tests/network

@ -857,9 +857,9 @@ class NetworkManager(manager.Manager):
context.elevated(), network['id'], instance_id)
vif = vif_obj.VirtualInterface.get_by_instance_and_network(
context, instance_id, network['id'])
values = {'allocated': True,
'virtual_interface_id': vif['id']}
self.db.fixed_ip_update(context, str(fip.address), values)
fip.allocated = True
fip.virtual_interface_id = vif.id
fip.save()
self._do_trigger_security_group_members_refresh_for_instance(
instance_id)
@ -916,9 +916,9 @@ class NetworkManager(manager.Manager):
self.instance_dns_manager.delete_entry(n,
self.instance_dns_domain)
self.db.fixed_ip_update(context, address,
{'allocated': False,
'virtual_interface_id': None})
fixed_ip_ref.allocated = False
fixed_ip_ref.virtual_interface_id = None
fixed_ip_ref.save()
if teardown:
network = fixed_ip_ref.network
@ -974,11 +974,8 @@ class NetworkManager(manager.Manager):
LOG.warn(_('IP %s leased that is not associated'), address,
context=context)
return
now = timeutils.utcnow()
self.db.fixed_ip_update(context,
fixed_ip.address,
{'leased': True,
'updated_at': now})
fixed_ip.leased = True
fixed_ip.save()
if not fixed_ip.allocated:
LOG.warn(_('IP |%s| leased that isn\'t allocated'), address,
context=context)
@ -995,9 +992,8 @@ class NetworkManager(manager.Manager):
if not fixed_ip.leased:
LOG.warn(_('IP %s released that was not leased'), address,
context=context)
self.db.fixed_ip_update(context,
fixed_ip.address,
{'leased': False})
fixed_ip.leased = False
fixed_ip.save()
if not fixed_ip.allocated:
fixed_ip.disassociate()
@ -1725,8 +1721,8 @@ class VlanManager(RPCAllocateFixedIP, floating_ips.FloatingIP, NetworkManager):
if kwargs.get('vpn', None):
address = network['vpn_private_address']
fixed_ip_obj.FixedIP.associate(context, address, instance_id,
network['id'], reserved=True)
fip = fixed_ip_obj.FixedIP.associate(context, address, instance_id,
network['id'], reserved=True)
else:
address = kwargs.get('address', None)
if address:
@ -1737,13 +1733,13 @@ class VlanManager(RPCAllocateFixedIP, floating_ips.FloatingIP, NetworkManager):
fip = fixed_ip_obj.FixedIP.associate_pool(context,
network['id'],
instance_id)
address = fip.address
address = fip.address
vif = vif_obj.VirtualInterface.get_by_instance_and_network(
context, instance_id, network['id'])
values = {'allocated': True,
'virtual_interface_id': vif.id}
self.db.fixed_ip_update(context, str(address), values)
fip.allocated = True
fip.virtual_interface_id = vif.id
fip.save()
if not kwargs.get('vpn', None):
self._do_trigger_security_group_members_refresh_for_instance(
@ -1903,10 +1899,11 @@ class VlanManager(RPCAllocateFixedIP, floating_ips.FloatingIP, NetworkManager):
self.driver.kill_dhcp(dev)
self.l3driver.remove_gateway(network)
if not CONF.share_dhcp_address:
values = {'allocated': False,
'host': None}
self.db.fixed_ip_update(context, network['dhcp_server'],
values)
fip = fixed_ip_obj.FixedIP.get_by_address(
context, network.dhcp_server)
fip.allocated = False
fip.host = None
fip.save()
else:
self.driver.update_dhcp(elevated, dev, network)

@ -1364,7 +1364,8 @@ class VlanNetworkTestCase(test.TestCase):
@mock.patch('nova.db.fixed_ip_get_by_address')
@mock.patch('nova.db.network_get')
def test_deallocate_fixed_no_vif(self, net_get, fixed_get):
@mock.patch('nova.db.fixed_ip_update')
def test_deallocate_fixed_no_vif(self, fixed_update, net_get, fixed_get):
"""Verify that deallocate doesn't raise when no vif is returned.
Ensures https://bugs.launchpad.net/nova/+bug/968457 doesn't return
@ -1384,13 +1385,18 @@ class VlanNetworkTestCase(test.TestCase):
elevated = context1.elevated()
fix_addr = db.fixed_ip_associate_pool(elevated, 1, instance['uuid'])
fixed_get.return_value = dict(test_fixed_ip.fake_fixed_ip,
address=fix_addr.address,
allocated=True,
virtual_interface_id=3,
instance_uuid=instance.uuid,
network=dict(test_network.fake_network,
**networks[1]))
self.flags(force_dhcp_release=True)
fixed_update.return_value = fixed_get.return_value
self.network.deallocate_fixed_ip(context1, fix_addr.address, 'fake')
fixed_update.assert_called_once_with(context1, fix_addr.address,
{'allocated': False,
'virtual_interface_id': None})
@mock.patch('nova.db.fixed_ip_get_by_address')
@mock.patch('nova.db.network_get')