e506daba20
This fixes the fields and filters units tests that break with a randomized PYTHONHASHSEED (see the bug report). The RESOURCE_ATTRIBUTE_MAP is stored as a dict leading to an unpredictable output order. Values in kvp strings are being stored as sets underpinned by dicts when converted, leading to unpredictable ordering of values when read. Discovered with PYTHONHASHSEED = 2455351445 on these tests: test_api_v2.APIv2TestCase.test_fields test_api_v2.APIv2TestCase.test_fields_multiple test_api_v2.FiltersTestCase.test_attr_info_with_convert_list_to test_api_v2.APIv2TestCase.test_filters_with_fields test_api_v2.APIv2TestCase.test_fields_multiple_with_empty There are 3 parts to this fix: 1. Update the APIv2TestCase _do_field_list function to construct field list in the same order as the controller constructs its list. 2. Ensure the APIv2TestCase _get_collection_kwargs maintains order throughout. 3. Use new assertOrderedEqual function to sort values before assertion in test_attr_info_with_convert_list_to Change-Id: I547cfa80cf83b0340b459279df9283443562326b Partial-bug: #1348818 |
||
---|---|---|
.. | ||
agent | ||
api | ||
cmd | ||
common | ||
db | ||
debug | ||
extensions | ||
hacking | ||
locale | ||
notifiers | ||
openstack | ||
plugins | ||
scheduler | ||
server | ||
services | ||
tests | ||
__init__.py | ||
auth.py | ||
context.py | ||
hooks.py | ||
manager.py | ||
neutron_plugin_base_v2.py | ||
policy.py | ||
quota.py | ||
service.py | ||
version.py | ||
wsgi.py |