mirror of
https://github.com/ARM-software/workload-automation.git
synced 2025-09-03 20:02:39 +01:00
WA Types: Added 'ParameterDict' type.
A new 'ParameterDict' has been added that automatically encodes and decodes values when they are store in a dictionary. The dictionary uses 2 characters prefixed to each value to store the original type information, e.g. 'fl' -> list of floats, before being passed through a url encoder. The reverse process happens on retrieval. To access the encoded values an `iterEncodedItems` and `getEncodedValue` methods have been added. The appropriate unit tests have also been added.
This commit is contained in:
@@ -17,11 +17,12 @@
|
||||
# pylint: disable=R0201
|
||||
from unittest import TestCase
|
||||
|
||||
from nose.tools import raises, assert_equal, assert_not_equal # pylint: disable=E0611
|
||||
from nose.tools import raises, assert_equal, assert_not_equal, assert_true # pylint: disable=E0611
|
||||
|
||||
from wlauto.utils.android import check_output
|
||||
from wlauto.utils.misc import merge_dicts, merge_lists, TimeoutError
|
||||
from wlauto.utils.types import list_or_integer, list_or_bool, caseless_string, arguments
|
||||
from wlauto.utils.types import (list_or_integer, list_or_bool, caseless_string, arguments,
|
||||
ParameterDict)
|
||||
|
||||
|
||||
class TestCheckOutput(TestCase):
|
||||
@@ -88,3 +89,126 @@ class TestTypes(TestCase):
|
||||
assert_equal(arguments('--foo 7 --bar "fizz buzz"'),
|
||||
['--foo', '7', '--bar', 'fizz buzz'])
|
||||
assert_equal(arguments(['test', 42]), ['test', '42'])
|
||||
|
||||
class TestParameterDict(TestCase):
|
||||
|
||||
# Define test parameters
|
||||
orig_params = {
|
||||
'string' : 'A Test String',
|
||||
'string_list' : ['A Test', 'List', 'With', '\n in.'],
|
||||
'bool_list' : [False, True, True],
|
||||
'int' : 42,
|
||||
'float' : 1.23,
|
||||
'long' : long(987),
|
||||
'none' : None,
|
||||
}
|
||||
|
||||
def setUp(self):
|
||||
self.params = ParameterDict()
|
||||
self.params['string'] = self.orig_params['string']
|
||||
self.params['string_list'] = self.orig_params['string_list']
|
||||
self.params['bool_list'] = self.orig_params['bool_list']
|
||||
self.params['int'] = self.orig_params['int']
|
||||
self.params['float'] = self.orig_params['float']
|
||||
self.params['long'] = self.orig_params['long']
|
||||
self.params['none'] = self.orig_params['none']
|
||||
|
||||
# Test values are encoded correctly
|
||||
def test_getEncodedItems(self):
|
||||
encoded = {
|
||||
'string' : 'ssA%20Test%20String',
|
||||
'string_list' : 'slA%20Test0newelement0List0newelement0With0newelement0%0A%20in.',
|
||||
'bool_list' : 'blFalse0newelement0True0newelement0True',
|
||||
'int' : 'is42',
|
||||
'float' : 'fs1.23',
|
||||
'long' : 'ds987',
|
||||
'none' : 'nsNone',
|
||||
}
|
||||
# Test iter_encoded_items
|
||||
for k, v in self.params.iter_encoded_items():
|
||||
assert_equal(v, encoded[k])
|
||||
|
||||
# Test get single encoded value
|
||||
assert_equal(self.params.get_encoded_value('string'), encoded['string'])
|
||||
assert_equal(self.params.get_encoded_value('string_list'), encoded['string_list'])
|
||||
assert_equal(self.params.get_encoded_value('bool_list'), encoded['bool_list'])
|
||||
assert_equal(self.params.get_encoded_value('int'), encoded['int'])
|
||||
assert_equal(self.params.get_encoded_value('float'), encoded['float'])
|
||||
assert_equal(self.params.get_encoded_value('long'), encoded['long'])
|
||||
assert_equal(self.params.get_encoded_value('none'), encoded['none'])
|
||||
|
||||
# Test it behaves like a normal dict
|
||||
def test_getitem(self):
|
||||
assert_equal(self.params['string'], self.orig_params['string'])
|
||||
assert_equal(self.params['string_list'], self.orig_params['string_list'])
|
||||
assert_equal(self.params['bool_list'], self.orig_params['bool_list'])
|
||||
assert_equal(self.params['int'], self.orig_params['int'])
|
||||
assert_equal(self.params['float'], self.orig_params['float'])
|
||||
assert_equal(self.params['long'], self.orig_params['long'])
|
||||
assert_equal(self.params['none'], self.orig_params['none'])
|
||||
|
||||
def test_get(self):
|
||||
assert_equal(self.params.get('string'), self.orig_params['string'])
|
||||
assert_equal(self.params.get('string_list'), self.orig_params['string_list'])
|
||||
assert_equal(self.params.get('bool_list'), self.orig_params['bool_list'])
|
||||
assert_equal(self.params.get('int'), self.orig_params['int'])
|
||||
assert_equal(self.params.get('float'), self.orig_params['float'])
|
||||
assert_equal(self.params.get('long'), self.orig_params['long'])
|
||||
assert_equal(self.params.get('none'), self.orig_params['none'])
|
||||
|
||||
def test_contains(self):
|
||||
assert_true(self.orig_params['string'] in self.params.values())
|
||||
assert_true(self.orig_params['string_list'] in self.params.values())
|
||||
assert_true(self.orig_params['bool_list'] in self.params.values())
|
||||
assert_true(self.orig_params['int'] in self.params.values())
|
||||
assert_true(self.orig_params['float'] in self.params.values())
|
||||
assert_true(self.orig_params['long'] in self.params.values())
|
||||
assert_true(self.orig_params['none'] in self.params.values())
|
||||
|
||||
def test_pop(self):
|
||||
assert_equal(self.params.pop('string'), self.orig_params['string'])
|
||||
assert_equal(self.params.pop('string_list'), self.orig_params['string_list'])
|
||||
assert_equal(self.params.pop('bool_list'), self.orig_params['bool_list'])
|
||||
assert_equal(self.params.pop('int'), self.orig_params['int'])
|
||||
assert_equal(self.params.pop('float'), self.orig_params['float'])
|
||||
assert_equal(self.params.pop('long'), self.orig_params['long'])
|
||||
assert_equal(self.params.pop('none'), self.orig_params['none'])
|
||||
|
||||
self.params['string'] = self.orig_params['string']
|
||||
assert_equal(self.params.popitem(), ('string', self.orig_params['string']))
|
||||
|
||||
def test_iteritems(self):
|
||||
for k, v in self.params.iteritems():
|
||||
assert_equal(v, self.orig_params[k])
|
||||
|
||||
def test_parameter_dict_update(self):
|
||||
params_1 = ParameterDict()
|
||||
params_2 = ParameterDict()
|
||||
|
||||
# Test two ParameterDicts
|
||||
params_1['string'] = self.orig_params['string']
|
||||
params_1['string_list'] = self.orig_params['string_list']
|
||||
params_1['bool_list'] = self.orig_params['bool_list']
|
||||
params_2['int'] = self.orig_params['int']
|
||||
params_2['float'] = self.orig_params['float']
|
||||
params_2['long'] = self.orig_params['long']
|
||||
params_2['none'] = self.orig_params['none']
|
||||
|
||||
params_1.update(params_2)
|
||||
assert_equal(params_1, self.params)
|
||||
|
||||
# Test update with normal dict
|
||||
params_3 = ParameterDict()
|
||||
std_dict = dict()
|
||||
|
||||
params_3['string'] = self.orig_params['string']
|
||||
std_dict['string_list'] = self.orig_params['string_list']
|
||||
std_dict['bool_list'] = self.orig_params['bool_list']
|
||||
std_dict['int'] = self.orig_params['int']
|
||||
std_dict['float'] = self.orig_params['float']
|
||||
std_dict['long'] = self.orig_params['long']
|
||||
std_dict['none'] = self.orig_params['none']
|
||||
|
||||
params_3.update(std_dict)
|
||||
for key in params_3.keys():
|
||||
assert_equal(params_3[key], self.params[key])
|
||||
|
Reference in New Issue
Block a user