Fix LB create and delete VIPs failure when concurrency > 1
Create pools in the scenario instead of context because only one VIP can be associated for a pool. Thus when concurrency>1 failures are avoided. Closes-bug: #1501467 Change-Id: Ibed79807f812a4e46cce0252cfffa8a59624081b
This commit is contained in:
parent
9a17d8490e
commit
0903c73036
@ -209,19 +209,17 @@
|
|||||||
NeutronLoadbalancerV1.create_and_delete_vips:
|
NeutronLoadbalancerV1.create_and_delete_vips:
|
||||||
-
|
-
|
||||||
args:
|
args:
|
||||||
|
pool_create_args: {}
|
||||||
vip_create_args: {}
|
vip_create_args: {}
|
||||||
runner:
|
runner:
|
||||||
type: "constant"
|
type: "constant"
|
||||||
times: {{smoke or 20}}
|
times: {{smoke or 20}}
|
||||||
concurrency: {{smoke or 1}}
|
concurrency: {{smoke or 10}}
|
||||||
context:
|
context:
|
||||||
users:
|
users:
|
||||||
tenants: {{smoke or 5}}
|
tenants: {{smoke or 5}}
|
||||||
users_per_tenant: {{smoke or 2}}
|
users_per_tenant: {{smoke or 2}}
|
||||||
network: {}
|
network: {}
|
||||||
lbaas:
|
|
||||||
pool: {}
|
|
||||||
lbaas_version: 1
|
|
||||||
quotas:
|
quotas:
|
||||||
neutron:
|
neutron:
|
||||||
network: -1
|
network: -1
|
||||||
|
@ -120,23 +120,23 @@ class NeutronLoadbalancerV1(utils.NeutronScenario):
|
|||||||
@validation.required_services(consts.Service.NEUTRON)
|
@validation.required_services(consts.Service.NEUTRON)
|
||||||
@validation.required_openstack(users=True)
|
@validation.required_openstack(users=True)
|
||||||
@validation.required_contexts("network")
|
@validation.required_contexts("network")
|
||||||
@validation.required_contexts("lbaas")
|
|
||||||
@scenario.configure(context={"cleanup": ["neutron"]})
|
@scenario.configure(context={"cleanup": ["neutron"]})
|
||||||
def create_and_delete_vips(self, vip_create_args=None):
|
def create_and_delete_vips(self, pool_create_args=None,
|
||||||
|
vip_create_args=None):
|
||||||
"""Create a vip(v1) and then delete vips(v1).
|
"""Create a vip(v1) and then delete vips(v1).
|
||||||
|
|
||||||
Measure the "neutron lb-vip-create" and "neutron lb-vip-delete"
|
Measure the "neutron lb-vip-create" and "neutron lb-vip-delete"
|
||||||
command performance. The scenario creates a vip for pool and
|
command performance. The scenario creates a vip for pool and
|
||||||
then deletes those vips.
|
then deletes those vips.
|
||||||
|
|
||||||
|
:param pool_create_args: dict, POST /lb/pools request options
|
||||||
:param vip_create_args: dict, POST /lb/vips request options
|
:param vip_create_args: dict, POST /lb/vips request options
|
||||||
"""
|
"""
|
||||||
vips = []
|
vips = []
|
||||||
pools = []
|
pool_create_args = pool_create_args or {}
|
||||||
vip_create_args = vip_create_args or {}
|
vip_create_args = vip_create_args or {}
|
||||||
networks = self.context.get("tenant", {}).get("networks", [])
|
networks = self.context.get("tenant", {}).get("networks", [])
|
||||||
for net in networks:
|
pools = self._create_v1_pools(networks, **pool_create_args)
|
||||||
[pools.append(pool) for pool in net.get("lb_pools")]
|
|
||||||
with atomic.ActionTimer(self, "neutron.create_%s_vips" % len(pools)):
|
with atomic.ActionTimer(self, "neutron.create_%s_vips" % len(pools)):
|
||||||
for pool in pools:
|
for pool in pools:
|
||||||
vips.append(self._create_v1_vip(pool, **vip_create_args))
|
vips.append(self._create_v1_vip(pool, **vip_create_args))
|
||||||
|
@ -33,12 +33,6 @@ class NeutronLoadbalancerv1TestCase(test.TestCase):
|
|||||||
"subnets": ["fake_subnet"]}]}})
|
"subnets": ["fake_subnet"]}]}})
|
||||||
return context
|
return context
|
||||||
|
|
||||||
def _get_context_pools(self):
|
|
||||||
context = self._get_context()
|
|
||||||
for network in context["tenant"]["networks"]:
|
|
||||||
network.update({"lb_pools": [{"pool": {"id": "pool-id"}}]})
|
|
||||||
return context
|
|
||||||
|
|
||||||
@ddt.data(
|
@ddt.data(
|
||||||
{},
|
{},
|
||||||
{"pool_create_args": None},
|
{"pool_create_args": None},
|
||||||
@ -172,24 +166,38 @@ class NeutronLoadbalancerv1TestCase(test.TestCase):
|
|||||||
{"vip_create_args": None},
|
{"vip_create_args": None},
|
||||||
{"vip_create_args": {}},
|
{"vip_create_args": {}},
|
||||||
{"vip_create_args": {"name": "given-name"}},
|
{"vip_create_args": {"name": "given-name"}},
|
||||||
|
{"pool_create_args": None},
|
||||||
|
{"pool_create_args": {}},
|
||||||
|
{"pool_create_args": {"name": "given-pool-name"}},
|
||||||
)
|
)
|
||||||
@ddt.unpack
|
@ddt.unpack
|
||||||
def test_create_and_delete_vips(self, vip_create_args=None):
|
def test_create_and_delete_vips(self, pool_create_args=None,
|
||||||
|
vip_create_args=None):
|
||||||
|
pools = [{
|
||||||
|
"pool": {
|
||||||
|
"id": "pool-id"
|
||||||
|
}
|
||||||
|
}]
|
||||||
vip = {
|
vip = {
|
||||||
"vip": {
|
"vip": {
|
||||||
"id": "vip-id"
|
"id": "vip-id"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
neutron_scenario = loadbalancer_v1.NeutronLoadbalancerV1(
|
neutron_scenario = loadbalancer_v1.NeutronLoadbalancerV1(
|
||||||
self._get_context_pools())
|
self._get_context())
|
||||||
vip_data = vip_create_args or {}
|
vip_data = vip_create_args or {}
|
||||||
|
pool_data = pool_create_args or {}
|
||||||
|
networks = self._get_context()["tenant"]["networks"]
|
||||||
|
neutron_scenario._create_v1_pools = mock.Mock(return_value=pools)
|
||||||
neutron_scenario._create_v1_vip = mock.Mock(return_value=vip)
|
neutron_scenario._create_v1_vip = mock.Mock(return_value=vip)
|
||||||
neutron_scenario._delete_v1_vip = mock.Mock()
|
neutron_scenario._delete_v1_vip = mock.Mock()
|
||||||
neutron_scenario.create_and_delete_vips(
|
neutron_scenario.create_and_delete_vips(
|
||||||
|
pool_create_args=pool_create_args,
|
||||||
vip_create_args=vip_create_args)
|
vip_create_args=vip_create_args)
|
||||||
for net in self._get_context_pools()["tenant"]["networks"]:
|
neutron_scenario._create_v1_pools.assert_called_once_with(
|
||||||
neutron_scenario._create_v1_vip.assert_has_calls(
|
networks, **pool_data)
|
||||||
[mock.call(pool, **vip_data) for pool in net["lb_pools"]])
|
neutron_scenario._create_v1_vip.assert_has_calls(
|
||||||
|
[mock.call(pool, **vip_data) for pool in pools])
|
||||||
neutron_scenario._delete_v1_vip.assert_has_calls(
|
neutron_scenario._delete_v1_vip.assert_has_calls(
|
||||||
[mock.call(vip["vip"])])
|
[mock.call(vip["vip"])])
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user