Convert iterators to lists to remove late binding
Remove late binding of iterators to enable the creation of an object with an actual state of a variable. Signed-off-by: gabor-mezei-arm <gabor.mezei@arm.com>
This commit is contained in:
parent
7b5c4e2db3
commit
b5db2c480f
@ -313,10 +313,11 @@ class StorageFormat:
|
|||||||
description=description)
|
description=description)
|
||||||
return key
|
return key
|
||||||
|
|
||||||
def all_keys_for_lifetimes(self) -> Iterator[StorageKey]:
|
def all_keys_for_lifetimes(self) -> List[StorageKey]:
|
||||||
"""Generate test keys covering lifetimes."""
|
"""Generate test keys covering lifetimes."""
|
||||||
lifetimes = sorted(self.constructors.lifetimes)
|
lifetimes = sorted(self.constructors.lifetimes)
|
||||||
expressions = self.constructors.generate_expressions(lifetimes)
|
expressions = self.constructors.generate_expressions(lifetimes)
|
||||||
|
keys = [] #type List[StorageKey]
|
||||||
for lifetime in expressions:
|
for lifetime in expressions:
|
||||||
# Don't attempt to create or load a volatile key in storage
|
# Don't attempt to create or load a volatile key in storage
|
||||||
if 'VOLATILE' in lifetime:
|
if 'VOLATILE' in lifetime:
|
||||||
@ -325,7 +326,8 @@ class StorageFormat:
|
|||||||
# but do attempt to load one.
|
# but do attempt to load one.
|
||||||
if 'READ_ONLY' in lifetime and self.forward:
|
if 'READ_ONLY' in lifetime and self.forward:
|
||||||
continue
|
continue
|
||||||
yield self.key_for_lifetime(lifetime)
|
keys.append(self.key_for_lifetime(lifetime))
|
||||||
|
return keys
|
||||||
|
|
||||||
def key_for_usage_flags(
|
def key_for_usage_flags(
|
||||||
self,
|
self,
|
||||||
@ -337,36 +339,38 @@ class StorageFormat:
|
|||||||
if short is None:
|
if short is None:
|
||||||
short = re.sub(r'\bPSA_KEY_USAGE_', r'', usage)
|
short = re.sub(r'\bPSA_KEY_USAGE_', r'', usage)
|
||||||
description = 'usage: ' + short
|
description = 'usage: ' + short
|
||||||
key = StorageKey(version=self.version,
|
return StorageKey(version=self.version,
|
||||||
id=1, lifetime=0x00000001,
|
id=1, lifetime=0x00000001,
|
||||||
type='PSA_KEY_TYPE_RAW_DATA', bits=8,
|
type='PSA_KEY_TYPE_RAW_DATA', bits=8,
|
||||||
usage=usage, alg=0, alg2=0,
|
usage=usage, alg=0, alg2=0,
|
||||||
material=b'K',
|
material=b'K',
|
||||||
description=description)
|
description=description)
|
||||||
return key
|
|
||||||
|
|
||||||
def all_keys_for_usage_flags(self) -> Iterator[StorageKey]:
|
def all_keys_for_usage_flags(self) -> List[StorageKey]:
|
||||||
"""Generate test keys covering usage flags."""
|
"""Generate test keys covering usage flags."""
|
||||||
known_flags = sorted(self.constructors.key_usage_flags)
|
known_flags = sorted(self.constructors.key_usage_flags)
|
||||||
yield self.key_for_usage_flags(['0'])
|
keys = [] #type List[StorageKey]
|
||||||
for usage_flag in known_flags:
|
keys.append(self.key_for_usage_flags(['0']))
|
||||||
yield self.key_for_usage_flags([usage_flag])
|
keys += [self.key_for_usage_flags([usage_flag])
|
||||||
for flag1, flag2 in zip(known_flags,
|
for usage_flag in known_flags]
|
||||||
known_flags[1:] + [known_flags[0]]):
|
keys += [self.key_for_usage_flags([flag1, flag2])
|
||||||
yield self.key_for_usage_flags([flag1, flag2])
|
for flag1, flag2 in zip(known_flags,
|
||||||
yield self.key_for_usage_flags(known_flags, short='all known')
|
known_flags[1:] + [known_flags[0]])]
|
||||||
|
keys.append(self.key_for_usage_flags(known_flags, short='all known'))
|
||||||
|
return keys
|
||||||
|
|
||||||
def keys_for_type(
|
def keys_for_type(
|
||||||
self,
|
self,
|
||||||
key_type: str,
|
key_type: str,
|
||||||
params: Optional[Iterable[str]] = None
|
params: Optional[Iterable[str]] = None
|
||||||
) -> Iterator[StorageKey]:
|
) -> List[StorageKey]:
|
||||||
"""Generate test keys for the given key type.
|
"""Generate test keys for the given key type.
|
||||||
|
|
||||||
For key types that depend on a parameter (e.g. elliptic curve family),
|
For key types that depend on a parameter (e.g. elliptic curve family),
|
||||||
`param` is the parameter to pass to the constructor. Only a single
|
`param` is the parameter to pass to the constructor. Only a single
|
||||||
parameter is supported.
|
parameter is supported.
|
||||||
"""
|
"""
|
||||||
|
keys = [] #type: List[StorageKey]
|
||||||
kt = crypto_knowledge.KeyType(key_type, params)
|
kt = crypto_knowledge.KeyType(key_type, params)
|
||||||
for bits in kt.sizes_to_test():
|
for bits in kt.sizes_to_test():
|
||||||
usage_flags = 'PSA_KEY_USAGE_EXPORT'
|
usage_flags = 'PSA_KEY_USAGE_EXPORT'
|
||||||
@ -377,21 +381,21 @@ class StorageFormat:
|
|||||||
r'',
|
r'',
|
||||||
kt.expression)
|
kt.expression)
|
||||||
description = 'type: {} {}-bit'.format(short_expression, bits)
|
description = 'type: {} {}-bit'.format(short_expression, bits)
|
||||||
key = StorageKey(version=self.version,
|
keys.append(StorageKey(version=self.version,
|
||||||
id=1, lifetime=0x00000001,
|
id=1, lifetime=0x00000001,
|
||||||
type=kt.expression, bits=bits,
|
type=kt.expression, bits=bits,
|
||||||
usage=usage_flags, alg=alg, alg2=alg2,
|
usage=usage_flags, alg=alg, alg2=alg2,
|
||||||
material=key_material,
|
material=key_material,
|
||||||
description=description)
|
description=description))
|
||||||
yield key
|
return keys
|
||||||
|
|
||||||
def all_keys_for_types(self) -> Iterator[StorageKey]:
|
def all_keys_for_types(self) -> List[StorageKey]:
|
||||||
"""Generate test keys covering key types and their representations."""
|
"""Generate test keys covering key types and their representations."""
|
||||||
key_types = sorted(self.constructors.key_types)
|
key_types = sorted(self.constructors.key_types)
|
||||||
for key_type in self.constructors.generate_expressions(key_types):
|
return [key for key_type in self.constructors.generate_expressions(key_types)
|
||||||
yield from self.keys_for_type(key_type)
|
for key in self.keys_for_type(key_type)]
|
||||||
|
|
||||||
def keys_for_algorithm(self, alg: str) -> Iterator[StorageKey]:
|
def keys_for_algorithm(self, alg: str) -> List[StorageKey]:
|
||||||
"""Generate test keys for the specified algorithm."""
|
"""Generate test keys for the specified algorithm."""
|
||||||
# For now, we don't have information on the compatibility of key
|
# For now, we don't have information on the compatibility of key
|
||||||
# types and algorithms. So we just test the encoding of algorithms,
|
# types and algorithms. So we just test the encoding of algorithms,
|
||||||
@ -405,22 +409,21 @@ class StorageFormat:
|
|||||||
usage=usage, alg=alg, alg2=0,
|
usage=usage, alg=alg, alg2=0,
|
||||||
material=b'K',
|
material=b'K',
|
||||||
description='alg: ' + descr)
|
description='alg: ' + descr)
|
||||||
yield key1
|
|
||||||
key2 = StorageKey(version=self.version,
|
key2 = StorageKey(version=self.version,
|
||||||
id=1, lifetime=0x00000001,
|
id=1, lifetime=0x00000001,
|
||||||
type='PSA_KEY_TYPE_RAW_DATA', bits=8,
|
type='PSA_KEY_TYPE_RAW_DATA', bits=8,
|
||||||
usage=usage, alg=0, alg2=alg,
|
usage=usage, alg=0, alg2=alg,
|
||||||
material=b'L',
|
material=b'L',
|
||||||
description='alg2: ' + descr)
|
description='alg2: ' + descr)
|
||||||
yield key2
|
return [key1, key2]
|
||||||
|
|
||||||
def all_keys_for_algorithms(self) -> Iterator[StorageKey]:
|
def all_keys_for_algorithms(self) -> List[StorageKey]:
|
||||||
"""Generate test keys covering algorithm encodings."""
|
"""Generate test keys covering algorithm encodings."""
|
||||||
algorithms = sorted(self.constructors.algorithms)
|
algorithms = sorted(self.constructors.algorithms)
|
||||||
for alg in self.constructors.generate_expressions(algorithms):
|
return [key for alg in self.constructors.generate_expressions(algorithms)
|
||||||
yield from self.keys_for_algorithm(alg)
|
for key in self.keys_for_algorithm(alg)]
|
||||||
|
|
||||||
def all_test_cases(self) -> Iterator[test_case.TestCase]:
|
def all_test_cases(self) -> List[test_case.TestCase]:
|
||||||
"""Generate all storage format test cases."""
|
"""Generate all storage format test cases."""
|
||||||
# First build a list of all keys, then construct all the corresponding
|
# First build a list of all keys, then construct all the corresponding
|
||||||
# test cases. This allows all required information to be obtained in
|
# test cases. This allows all required information to be obtained in
|
||||||
@ -431,13 +434,13 @@ class StorageFormat:
|
|||||||
keys += self.all_keys_for_usage_flags()
|
keys += self.all_keys_for_usage_flags()
|
||||||
keys += self.all_keys_for_types()
|
keys += self.all_keys_for_types()
|
||||||
keys += self.all_keys_for_algorithms()
|
keys += self.all_keys_for_algorithms()
|
||||||
for key in keys:
|
|
||||||
if key.location_value() != 0:
|
# Skip keys with a non-default location, because they
|
||||||
# Skip keys with a non-default location, because they
|
# require a driver and we currently have no mechanism to
|
||||||
# require a driver and we currently have no mechanism to
|
# determine whether a driver is available.
|
||||||
# determine whether a driver is available.
|
keys = filter(lambda key: key.location_value() == 0, keys)
|
||||||
continue
|
|
||||||
yield self.make_test_case(key)
|
return [self.make_test_case(key) for key in keys]
|
||||||
|
|
||||||
|
|
||||||
class TestGenerator:
|
class TestGenerator:
|
||||||
|
Loading…
Reference in New Issue
Block a user