Files
neutron/neutron/tests/common/exclusive_resources/ip_network.py
Brian Haley 27a98b5c62 pyupgrade changes for Python3.10+
As discussed at the Flamingo PTG meeting, run an automated
upgrade tool to make code python 3.10+ compliant.

Result of running:

$ pyupgrade --py310-plus $(git ls-files | grep ".py$")

Fixed PEP8 errors introduced by pyupgrade by running:

$ autopep8 --select=E127,E128,E501 --max-line-length 79 -r \
--in-place neutron

Also did manual updates as necessary to fix other errors
and warnings after above commands.

Bumped versions of checkers - pylint, bandit and mypy to
more recent versions, which required disabling a new
warning, too-many-positional-arguments.

Change-Id: Ic6908af2c331e3ea6c50f1a8a8e261db41572645
2025-05-21 17:11:13 +01:00

49 lines
1.6 KiB
Python

# Copyright 2016 Red Hat, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import functools
import netaddr
from neutron.tests.common.exclusive_resources import ip_address
from neutron.tests.common.exclusive_resources import resource_allocator
def _get_random_network(low, high, netmask):
ip = ip_address.get_random_ip(low, high)
return str(netaddr.IPNetwork(f"{ip}/{netmask}").cidr)
class ExclusiveIPNetwork(resource_allocator.ExclusiveResource):
"""Allocate a non-overlapping ip network.
:ivar network: allocated ip network
:type network: netaddr.IPNetwork
"""
def __init__(self, low, high, netmask):
super().__init__(
'ip_networks',
functools.partial(_get_random_network, low, high, netmask),
self.is_valid)
def _setUp(self):
super()._setUp()
self.network = netaddr.IPNetwork(self.resource)
def is_valid(self, new_resource, allocated_resources):
new_ipset = netaddr.IPSet([new_resource])
allocated_ipset = netaddr.IPSet(allocated_resources)
return new_ipset.isdisjoint(allocated_ipset)