Merge "Remove ipxe tags when ipx6 is in use."
This commit is contained in:
@@ -470,19 +470,22 @@ def dhcp_options_for_instance(task, ipxe_enabled=False, url_boot=False):
|
|||||||
# added in the Stein cycle which identifies the iPXE User-Class
|
# added in the Stein cycle which identifies the iPXE User-Class
|
||||||
# directly and is only sent in DHCPv6.
|
# directly and is only sent in DHCPv6.
|
||||||
|
|
||||||
# NOTE(TheJulia): Lets send both, let neutron tag/sort it out as
|
if ip_version != 6:
|
||||||
# an ip_version field is also transmitted. Plus, given the
|
dhcp_opts.append(
|
||||||
# semi-obscure nature of this, being more verbose and letting
|
{'opt_name': "tag:!ipxe,%s" % boot_file_param,
|
||||||
# the DHCP server do the best thing possible is likely the best
|
'opt_value': boot_file}
|
||||||
# course of action.
|
)
|
||||||
dhcp_opts.append({'opt_name': "tag:!ipxe,%s" % boot_file_param,
|
dhcp_opts.append(
|
||||||
'opt_value': boot_file})
|
{'opt_name': "tag:ipxe,%s" % boot_file_param,
|
||||||
dhcp_opts.append({'opt_name': "tag:!ipxe6,%s" % boot_file_param,
|
'opt_value': ipxe_script_url}
|
||||||
'opt_value': boot_file})
|
)
|
||||||
dhcp_opts.append({'opt_name': "tag:ipxe,%s" % boot_file_param,
|
else:
|
||||||
'opt_value': ipxe_script_url})
|
dhcp_opts.append(
|
||||||
dhcp_opts.append({'opt_name': "tag:ipxe6,%s" % boot_file_param,
|
{'opt_name': "tag:!ipxe6,%s" % boot_file_param,
|
||||||
'opt_value': ipxe_script_url})
|
'opt_value': boot_file})
|
||||||
|
dhcp_opts.append(
|
||||||
|
{'opt_name': "tag:ipxe6,%s" % boot_file_param,
|
||||||
|
'opt_value': ipxe_script_url})
|
||||||
else:
|
else:
|
||||||
# !175 == non-iPXE.
|
# !175 == non-iPXE.
|
||||||
# http://ipxe.org/howto/dhcpd#ipxe-specific_options
|
# http://ipxe.org/howto/dhcpd#ipxe-specific_options
|
||||||
|
|||||||
@@ -857,15 +857,9 @@ class TestPXEUtils(db_base.DbTestCase):
|
|||||||
self.config(dhcp_provider='neutron', group='dhcp')
|
self.config(dhcp_provider='neutron', group='dhcp')
|
||||||
if ip_version == 6:
|
if ip_version == 6:
|
||||||
# Boot URL variable set from prior test of isc parameters.
|
# Boot URL variable set from prior test of isc parameters.
|
||||||
expected_info = [{'opt_name': 'tag:!ipxe,59',
|
expected_info = [{'opt_name': 'tag:!ipxe6,59',
|
||||||
'opt_value': 'tftp://[ff80::1]/fake-bootfile',
|
'opt_value': 'tftp://[ff80::1]/fake-bootfile',
|
||||||
'ip_version': ip_version},
|
'ip_version': ip_version},
|
||||||
{'opt_name': 'tag:!ipxe6,59',
|
|
||||||
'opt_value': 'tftp://[ff80::1]/fake-bootfile',
|
|
||||||
'ip_version': ip_version},
|
|
||||||
{'opt_name': 'tag:ipxe,59',
|
|
||||||
'opt_value': expected_boot_script_url,
|
|
||||||
'ip_version': ip_version},
|
|
||||||
{'opt_name': 'tag:ipxe6,59',
|
{'opt_name': 'tag:ipxe6,59',
|
||||||
'opt_value': expected_boot_script_url,
|
'opt_value': expected_boot_script_url,
|
||||||
'ip_version': ip_version}]
|
'ip_version': ip_version}]
|
||||||
@@ -874,9 +868,6 @@ class TestPXEUtils(db_base.DbTestCase):
|
|||||||
expected_info = [{'opt_name': 'tag:!ipxe,67',
|
expected_info = [{'opt_name': 'tag:!ipxe,67',
|
||||||
'opt_value': boot_file,
|
'opt_value': boot_file,
|
||||||
'ip_version': ip_version},
|
'ip_version': ip_version},
|
||||||
{'opt_name': 'tag:!ipxe6,67',
|
|
||||||
'opt_value': boot_file,
|
|
||||||
'ip_version': ip_version},
|
|
||||||
{'opt_name': '66',
|
{'opt_name': '66',
|
||||||
'opt_value': '192.0.2.1',
|
'opt_value': '192.0.2.1',
|
||||||
'ip_version': ip_version},
|
'ip_version': ip_version},
|
||||||
@@ -886,9 +877,6 @@ class TestPXEUtils(db_base.DbTestCase):
|
|||||||
{'opt_name': 'tag:ipxe,67',
|
{'opt_name': 'tag:ipxe,67',
|
||||||
'opt_value': expected_boot_script_url,
|
'opt_value': expected_boot_script_url,
|
||||||
'ip_version': ip_version},
|
'ip_version': ip_version},
|
||||||
{'opt_name': 'tag:ipxe6,67',
|
|
||||||
'opt_value': expected_boot_script_url,
|
|
||||||
'ip_version': ip_version},
|
|
||||||
{'opt_name': 'server-ip-address',
|
{'opt_name': 'server-ip-address',
|
||||||
'opt_value': '192.0.2.1',
|
'opt_value': '192.0.2.1',
|
||||||
'ip_version': ip_version}]
|
'ip_version': ip_version}]
|
||||||
|
|||||||
@@ -0,0 +1,6 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
Fixes the duplication of the "ipxe" tag when using IPv6, which leads to
|
||||||
|
the dhcp server possibly returning an incorrect response to the DHCPv6
|
||||||
|
client.
|
||||||
Reference in New Issue
Block a user