NSX|V3: fix bulk subnet breakage

Commit cf34df857273d3be289e00590d80498cc11149ee broke the plugin.

Change-Id: I94f7828b6cbb0ca9ee069666fbff77425e4a868c
This commit is contained in:
Gary Kotton 2017-04-01 22:18:49 -07:00
parent 7b64469d32
commit 0f4a7a7364

View File

@ -1164,8 +1164,8 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
objects = [] objects = []
collection = "%ss" % resource collection = "%ss" % resource
items = request_items[collection] items = request_items[collection]
context.session.begin(subtransactions=True)
try: try:
with db_api.context_manager.writer.using(context):
for item in items: for item in items:
obj_creator = getattr(self, 'create_%s' % resource) obj_creator = getattr(self, 'create_%s' % resource)
obj = obj_creator(context, item) obj = obj_creator(context, item)
@ -1174,7 +1174,6 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
# The user-provided post_create function is called # The user-provided post_create function is called
# after a new object is created. # after a new object is created.
post_create_func(obj) post_create_func(obj)
context.session.commit()
except Exception: except Exception:
if rollback_func: if rollback_func:
# The user-provided rollback function is called when an # The user-provided rollback function is called when an
@ -1725,6 +1724,7 @@ class NsxV3Plugin(agentschedulers_db.AZDhcpAgentSchedulerDbMixin,
for fixed_ip in fixed_ips: for fixed_ip in fixed_ips:
if netaddr.IPNetwork(fixed_ip['ip_address']).version != 4: if netaddr.IPNetwork(fixed_ip['ip_address']).version != 4:
continue continue
with db_api.context_manager.reader.using(context):
subnet = self.get_subnet(context, fixed_ip['subnet_id']) subnet = self.get_subnet(context, fixed_ip['subnet_id'])
if subnet['enable_dhcp']: if subnet['enable_dhcp']:
ips.append(fixed_ip) ips.append(fixed_ip)