Reverse order of get_unused_ip_addresses
If a test author forgets to disable DHCP on a subnet used for a test (e.g. I17e201ef8822cace86bf805d6bd5a2e4d0e9084d), returning the first IP address in the subnet can race with the creation of the DHCP port. As a defensive measure this adjusts the logic to get unused IP addresses starting with the last addresses in the subnet instead. Change-Id: I31b9fcc9140de08e907bec08584a8c29ec6004e9
This commit is contained in:
parent
a70710bb36
commit
6f455aa398
@ -12,7 +12,6 @@
|
|||||||
# License for the specific language governing permissions and limitations
|
# License for the specific language governing permissions and limitations
|
||||||
# under the License.
|
# under the License.
|
||||||
|
|
||||||
import itertools
|
|
||||||
import netaddr
|
import netaddr
|
||||||
|
|
||||||
from tempest.lib import exceptions as lib_exc
|
from tempest.lib import exceptions as lib_exc
|
||||||
@ -39,10 +38,11 @@ def get_unused_ip_addresses(ports_client, subnets_client,
|
|||||||
alloc_set.add(fixed_ip['ip_address'])
|
alloc_set.add(fixed_ip['ip_address'])
|
||||||
|
|
||||||
av_set = subnet_set - alloc_set
|
av_set = subnet_set - alloc_set
|
||||||
ip_list = [str(ip) for ip in itertools.islice(av_set, count)]
|
addrs = []
|
||||||
|
for cidr in reversed(av_set.iter_cidrs()):
|
||||||
if len(ip_list) != count:
|
for ip in reversed(cidr):
|
||||||
|
addrs.append(str(ip))
|
||||||
|
if len(addrs) == count:
|
||||||
|
return addrs
|
||||||
msg = "Insufficient IP addresses available"
|
msg = "Insufficient IP addresses available"
|
||||||
raise lib_exc.BadRequest(message=msg)
|
raise lib_exc.BadRequest(message=msg)
|
||||||
|
|
||||||
return ip_list
|
|
||||||
|
Loading…
Reference in New Issue
Block a user