From 931e5ba286ad0a6c0f4c68a97dcba289ce16b27c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlos=20Garc=C3=ADa=20Morch=C3=B3n?= Date: Mon, 25 Mar 2024 13:12:35 +0100 Subject: [PATCH] fix partial replacement for string with length (#383) --- .../test/utils/test_dataset_replace_param.py | 9 ++++++++ toolium/utils/dataset.py | 21 ++++++++----------- 2 files changed, 18 insertions(+), 12 deletions(-) diff --git a/toolium/test/utils/test_dataset_replace_param.py b/toolium/test/utils/test_dataset_replace_param.py index ad9243d4..ce5361f8 100644 --- a/toolium/test/utils/test_dataset_replace_param.py +++ b/toolium/test/utils/test_dataset_replace_param.py @@ -429,3 +429,12 @@ def test_replace_param_type_inference_disabled(): assert param == '{"a":"test1", "b":true, "c":null}' param = replace_param('["1", true, null]', infer_param_type=False) assert param == '["1", true, null]' + + +def test_replace_param_partial_string_with_length(): + param = replace_param('parameter=[STRING_WITH_LENGTH_5]') + assert param == 'parameter=aaaaa' + param = replace_param('[STRING_WITH_LENGTH_5] is string') + assert param == 'aaaaa is string' + param = replace_param('parameter [STRING_WITH_LENGTH_5] is string') + assert param == 'parameter aaaaa is string' diff --git a/toolium/utils/dataset.py b/toolium/utils/dataset.py index 0fc75c37..fa09df11 100644 --- a/toolium/utils/dataset.py +++ b/toolium/utils/dataset.py @@ -308,11 +308,16 @@ def _replace_param_fixed_length(param): :param param: parameter value :return: tuple with replaced value and boolean to know if replacement has been done """ + string_seed = 'a' + integer_seed = '1' new_param = param param_replaced = False + # we allow partial replacements for STRING + string_expression = re.compile(r'\[STRING_WITH_LENGTH_([0-9]+)\]') + new_param = string_expression.sub(lambda x: int(x.group(1)) * 'a', param) if param.startswith('[') and param.endswith(']'): if any(x in param for x in ['STRING_ARRAY_WITH_LENGTH_', 'INTEGER_ARRAY_WITH_LENGTH_']): - seeds = {'STRING': 'a', 'INTEGER': 1} + seeds = {'STRING': string_seed, 'INTEGER': int(integer_seed)} seed, length = param[1:-1].split('_ARRAY_WITH_LENGTH_') new_param = list(seeds[seed] for x in range(int(length))) param_replaced = True @@ -320,18 +325,10 @@ def _replace_param_fixed_length(param): length = int(param[1:-1].split('JSON_WITH_LENGTH_')[1]) new_param = dict((str(x), str(x)) for x in range(length)) param_replaced = True - elif any(x in param for x in ['STRING_WITH_LENGTH_', 'INTEGER_WITH_LENGTH_']): - seeds = {'STRING': 'a', 'INTEGER': '1'} - # The chain to be generated can be just a part of param - start = param.find('[') - end = param.find(']') - seed, length = param[start + 1:end].split('_WITH_LENGTH_') - generated_part = seeds[seed] * int(length) - placeholder = '[' + seed + '_WITH_LENGTH_' + length + ']' - new_param = param.replace(placeholder, generated_part) + elif any(x in param for x in ['INTEGER_WITH_LENGTH_']): + length = param[len('[INTEGER_WITH_LENGTH_'):-1] + new_param = int(integer_seed * int(length)) param_replaced = True - if seed == 'INTEGER': - new_param = int(new_param) return new_param, param_replaced