Please find details at https://bugs.launchpad.net/neutron/+bug/1441512
Tempest v2 api negative tests for invalid or empty tenantid fails as tenant id is not validated at plugin layer. 1. In Case of looging noop driver (no validation is done by driver ) , In test , create returns success whereas it excepts BadRequest. 0} neutron_lbaas.tests.tempest.v2.api.test_members.MemberTestJSON.test_create_member_empty_tenant_id [0.590837s] ... FAILED Captured traceback: ~~~~~~~~~~~~~~~~~~~ Traceback (most recent call last): File "neutron_lbaas/tests/tempest/v2/api/test_members.py", line 244, in test_create_member_empty_tenant_id self.pool_id, **member_opts) File "/opt/stack/neutron-lbaas/.tox/tempest/local/lib/python2.7/site-packages/testtools/testcase.py", line 422, in assertRaises self.assertThat(our_callable, matcher) File "/opt/stack/neutron-lbaas/.tox/tempest/local/lib/python2.7/site-packages/testtools/testcase.py", line 435, in assertThat raise mismatch_error testtools.matchers._impl.MismatchError: <bound method type._create_member of <class 'neutron_lbaas.tests.tempest.v2.api.test_members.MemberTestJSON'>> returned {u'protocol_port': 80, u'weight': 1, u'admin_state_up': True, u'subnet_id': u'e20c013e-33d0-4752-883d-b78bd45ef0ea', u'tenant_id': u'', u'address': u'127.0.0.1', u'id': u'3f8d811f-ab69-44f8-ae18-8fc20a94b228'} 2.In case of if Backend Driver (Say NetScaler) ,driver is raising BadRequest . ================================================================== return self._callable_object(*self._args, **self._kwargs) File "neutron_lbaas/tests/tempest/v2/api/base.py", line 252, in _create_member member = cls.members_client.create_member(pool_id, **member_kwargs) File "neutron_lbaas/tests/tempest/v2/clients/members_client.py", line 51, in create_member resp, body = self.post(url, post_body) File "/opt/stack/neutron-lbaas/.tox/tempest/local/lib/python2.7/site-packages/tempest_lib/common/rest_client.py", line 252, in post return self.request('POST', url, extra_headers, headers, body) File "/opt/stack/neutron-lbaas/.tox/tempest/src/tempest/tempest/common/service_client.py", line 83, in request raise exceptions.ServerFault(ex) tempest.exceptions.ServerFault: Got server fault Details: Got server fault Details: An error happened in the driver =================================================================== Above behavior is observed as ,at plugin layer all Exceptions from Driver is raised as same Driver Exception. plugin.y def _call_driver_operation(self, context, driver_method, db_entity, old_db_entity=None): manager_method = "%s.%s" % (driver_method.__self__.__class__.__name__, driver_method.__name__) LOG.info(_LI("Calling driver operation %s") % manager_method) try: if old_db_entity: driver_method(context, old_db_entity, db_entity) else: driver_method(context, db_entity) # catching and reraising agent issues except (lbaas_agentschedulerv2.NoEligibleLbaasAgent, lbaas_agentschedulerv2.NoActiveLbaasAgent) as no_agent: raise no_agent except Exception: LOG.exception(_LE("There was an error in the driver")) self._handle_driver_error(context, db_entity) raise loadbalancerv2.DriverError() #<-------------- bad request is raised as Driver Error Negative Testcases:- test_create_listener_invalid_tenant_id() test_create_listener_invalid_empty_tenant_id() test_create_member_invalid_tenant_id() test_create_member_empty_tenant_id() -- Santosh
__________________________________________________________________________ OpenStack Development Mailing List (not for usage questions) Unsubscribe: openstack-dev-requ...@lists.openstack.org?subject:unsubscribe http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev