v3 feat: support extract session variables

This commit is contained in:
debugtalk
2020-04-20 13:26:40 +08:00
parent 39b8f74b27
commit bd7b84d42c
4 changed files with 41 additions and 17 deletions

View File

@@ -3,6 +3,7 @@ from typing import Any, Set, Text
from typing import Dict
from httprunner.v3 import exceptions
from httprunner.v3.exceptions import VariableNotFound
absolute_http_url_regexp = re.compile(r"^https?://", re.I)
@@ -98,7 +99,10 @@ def parse_string_variables(content, variables_mapping):
"""
variables_list = extract_variables(content)
for variable_name in variables_list:
variable_value = variables_mapping[variable_name]
try:
variable_value = variables_mapping[variable_name]
except KeyError:
raise VariableNotFound(f"{variable_name} not in {variables_mapping}")
# TODO: replace variable label from $var to {{var}}
if f"${variable_name}" == content:
@@ -158,20 +162,24 @@ def parse_content(content: Any, variables_mapping: Dict[str, Any] = None, functi
return content
def parse_variables_mapping(variables_mapping: Dict[str, Any]):
def parse_variables_mapping(variables_mapping: Dict[Text, Any]) -> Dict[Text, Any]:
parsed_variables: Dict[str, Any] = {}
parsed_variables: Dict[Text, Any] = {}
while len(parsed_variables) != len(variables_mapping):
for var_name in variables_mapping:
var_value = variables_mapping[var_name]
# variables = extract_variables(var_value)
if var_name in parsed_variables:
continue
parsed_value = parse_content(var_value, parsed_variables)
var_value = variables_mapping[var_name]
# variables = extract_variables(var_value)
try:
parsed_value = parse_content(var_value, parsed_variables)
except VariableNotFound:
continue
parsed_variables[var_name] = parsed_value
return parsed_variables

View File

@@ -3,7 +3,7 @@ from typing import List
import requests
from loguru import logger
from httprunner.v3.parser import build_url, parse_content
from httprunner.v3.parser import build_url, parse_content, parse_variables_mapping
from httprunner.v3.response import ResponseObject
from httprunner.v3.schema import TestsConfig, TestStep
@@ -57,9 +57,15 @@ class TestCaseRunner(object):
"""main entrance"""
session_variables = {}
for step in self.teststeps:
# update with config variables
step.variables.update(self.config.variables)
# update with session variables extracted from former step
step.variables.update(session_variables)
# parse variables
step.variables = parse_variables_mapping(step.variables)
# run step
extract_mapping = self.run_step(step)
# save extracted variables to session variables
session_variables.update(extract_mapping)
def run(self):