优化代码

This commit is contained in:
chenyongzhiaaron 2023-07-24 14:48:04 +08:00
parent 4265f28e38
commit d66acb4481
4 changed files with 90 additions and 106 deletions

View File

@ -1,12 +1,7 @@
<?xml version="1.0" encoding="UTF-8"?>
<dataSource name="@localhost">
<database-model serializer="dbm" dbms="MYSQL" family-id="MYSQL" format-version="4.48">
<root id="1">
<DefaultCasing>lower/lower</DefaultCasing>
<DefaultEngine>InnoDB</DefaultEngine>
<DefaultTmpEngine>InnoDB</DefaultTmpEngine>
<ServerVersion>8.0.32</ServerVersion>
</root>
<root id="1"/>
<schema id="2" parent="1" name="flask">
<CollationName>utf8mb4_0900_ai_ci</CollationName>
</schema>

View File

@ -28,7 +28,6 @@ class Action(Extractor, LoadScript, Validator, MysqlClient):
self.set_bif_fun(bif_functions)
def execute_dynamic_code(self, item, code):
# self.set_variables(item)
self.variables = item
if code is not None:
try:
@ -42,7 +41,6 @@ class Action(Extractor, LoadScript, Validator, MysqlClient):
error_message = f"动态代码执行异常: {e}"
self._handle_error(error_message)
return self.variables
# return self.__variables
def _handle_error(self, error_message):
print(f'发现异常: {error_message}')
@ -72,7 +70,6 @@ class Action(Extractor, LoadScript, Validator, MysqlClient):
self.execute_dynamic_code(response, teardown_script)
return response
# Request = property(_get_variables, _set_variables)
if __name__ == '__main__':

View File

@ -10,105 +10,99 @@
import json
from common.data_extraction import logger
# from common.http_client.http_client import Pyt
# from common.environments import
from common.data_extraction.data_extractor import DataExtractor
class DependentParameter(DataExtractor):
"""
该类用于替换接口参数它会从字符串中寻找需要替换的参数并将其替换为关联参数表中对应的值
然后它将替换后的字符串转化为字典并返回如果找不到需要替换的参数则直接返回原始字符串
"""
def __init__(self):
super().__init__()
# self.P = self.pattern_l # re.compile(r"{{\s*([^}\s]+)\s*}}(?:\[(\d+)\])?")
# self.pp = self.PATTERN # re.compile(r"{{(.*?)}}")
# self.p = self.pattern # re.compile(r'({)')
# self.pf = self.pattern_fun # re.compile(r"{{(\w+\(\))}}")
@logger.log_decorator()
def replace_dependent_parameter(self, jst):
"""
替换字符串中的关联参数并返回转化后的字典格式
Args:
jst: 包含接口参数的字符串
Returns:转换后的字典或原始字符串
"""
if not jst:
return jst
jst = json.dumps(jst) if isinstance(jst, (dict, list)) else jst
# 循环替换参数
while self.pattern_l.search(jst):
if self.pattern_fun.search(jst):
# 函数替换
key = self.pattern_fun.search(jst).group()
if key in self.get_environments().keys():
# 如果参数名称存在于关联参数表中,则调用相应的函数获取返回值,并替换字符串中的参数
value_ = self.get_environments(key)()
jst = jst.replace(key, str(value_))
else:
logger.error(
f"key:{key},在关联参数表中查询不到,请检查关联参数字段提取及填写是否正常\n")
break
else:
key = self.pattern_l.search(jst)
# 字符串替换,判断需要替换的字符串是{{key}}还是{{key}}[index]
if "[" and "]" in key.group():
# 如果需要替换的是数组参数,则获取数组下标
index = int(key.group(2))
k = self.PATTERN.search(key.group()).group()
else:
index = ""
k = key.group()
# 如果参数名称存在于关联参数表中,则获取相应的值,并替换字符串中的参数
if k in self.get_environments().keys():
if isinstance(index, int):
value_ = self.get_environments(k)[index]
else:
value_ = self.get_environments(k)
jst = jst.replace(key.group(), str(value_))
else:
logger.error(
f"key:{key},在关联参数表中查询不到,请检查关联参数字段提取及填写是否正常\n")
break
# 将 True 和 False 转换为小写,并继续循环替换参数
jst = jst.replace("True", "true").replace("False", "false")
if self.pattern.search(jst) and not self.pattern_fun.search(jst):
try:
jst = json.loads(jst)
except json.JSONDecodeError as e:
logger.error(f"JSONDecodeError:{jst}:{e}")
return jst
"""
该类用于替换接口参数它会从字符串中寻找需要替换的参数并将其替换为关联参数表中对应的值
然后它将替换后的字符串转化为字典并返回如果找不到需要替换的参数则直接返回原始字符串
"""
def __init__(self):
super().__init__()
@logger.log_decorator()
def replace_dependent_parameter(self, jst):
"""
替换字符串中的关联参数并返回转化后的字典格式
Args:
jst: 包含接口参数的字符串
Returns:转换后的字典或原始字符串
"""
if not jst:
return jst
jst = json.dumps(jst) if isinstance(jst, (dict, list)) else jst
# 循环替换参数
while self.pattern_l.search(jst):
if self.pattern_fun.search(jst):
# 函数替换
key = self.pattern_fun.search(jst).group()
if key in self.get_environments().keys():
# 如果参数名称存在于关联参数表中,则调用相应的函数获取返回值,并替换字符串中的参数
value_ = self.get_environments(key)()
jst = jst.replace(key, str(value_))
else:
logger.error(
f"key:{key},在关联参数表中查询不到,请检查关联参数字段提取及填写是否正常\n")
break
else:
key = self.pattern_l.search(jst)
# 字符串替换,判断需要替换的字符串是{{key}}还是{{key}}[index]
if "[" and "]" in key.group():
# 如果需要替换的是数组参数,则获取数组下标
index = int(key.group(2))
k = self.PATTERN.search(key.group()).group()
else:
index = ""
k = key.group()
# 如果参数名称存在于关联参数表中,则获取相应的值,并替换字符串中的参数
if k in self.get_environments().keys():
if isinstance(index, int):
value_ = self.get_environments(k)[index]
else:
value_ = self.get_environments(k)
jst = jst.replace(key.group(), str(value_))
else:
logger.error(
f"key:{key},在关联参数表中查询不到,请检查关联参数字段提取及填写是否正常\n")
break
# 将 True 和 False 转换为小写,并继续循环替换参数
jst = jst.replace("True", "true").replace("False", "false")
if self.pattern.search(jst) and not self.pattern_fun.search(jst):
try:
jst = json.loads(jst)
except json.JSONDecodeError as e:
logger.error(f"JSONDecodeError:{jst}:{e}")
return jst
if __name__ == '__main__':
from common.environments import Environments
dps = {
"{{var_a}}": "foo",
"{{var_c}}": 123,
"{{var_d}}": None,
"{{var_e_1}}": True,
"{{var_e_2}}": "bar",
"{{var_f}}": ["baz", False],
"{{var_g}}": {'g': 'gg', 'g1': 'gg', 'g2': 'gg2'}
}
d = Environments()
d.set_environments(dps)
from common.validation import loaders
from common import bif_functions
loaders.Loaders().set_bif_fun(bif_functions)
dat = {
"a": "{{var_a}}",
"b": {"c": "{{var_c}}", "d": "{{var_d}}", "e": ["{{var_e_1}}", "{{var_e_2}}"]},
"f": "{{var_f}}[1]",
"g": "{{var_g}}",
"t": "{{get_timestamp()}}"
}
d = DependentParameter()
print("=====》res: ", d.replace_dependent_parameter(dat))
from common.environments import Environments
dps = {
"{{var_a}}": "foo",
"{{var_c}}": 123,
"{{var_d}}": None,
"{{var_e_1}}": True,
"{{var_e_2}}": "bar",
"{{var_f}}": ["baz", False],
"{{var_g}}": {'g': 'gg', 'g1': 'gg', 'g2': 'gg2'}
}
d = Environments()
d.set_environments(dps)
from common.validation import loaders
from common import bif_functions
loaders.Loaders().set_bif_fun(bif_functions)
dat = {
"a": "{{var_a}}",
"b": {"c": "{{var_c}}", "d": "{{var_d}}", "e": ["{{var_e_1}}", "{{var_e_2}}"]},
"f": "{{var_f}}[1]",
"g": "{{var_g}}",
"t": "{{get_timestamp()}}"
}
d = DependentParameter()
print("=====》res: ", d.replace_dependent_parameter(dat))

View File

@ -29,8 +29,6 @@ class Environments:
@classmethod
def reset_environments(cls):
"""重置"""
# cls.request = None
# cls.response = None
cls.environments.clear()