新增支持是否情况历史测试数据的参数
This commit is contained in:
parent
40ce0e6380
commit
f52d80b5e3
|
@ -13,10 +13,11 @@ if __name__=='__main__':
|
||||||
parser=argparse.ArgumentParser()
|
parser=argparse.ArgumentParser()
|
||||||
parser.add_argument('-k','--keyword',help='只执行匹配关键字的用例,会匹配文件名、类名、方法名',type=str)
|
parser.add_argument('-k','--keyword',help='只执行匹配关键字的用例,会匹配文件名、类名、方法名',type=str)
|
||||||
parser.add_argument('-d','--dir',help='指定要测试的目录',type=str)
|
parser.add_argument('-d','--dir',help='指定要测试的目录',type=str)
|
||||||
parser.add_argument('-m', '--markexpr', help='只运行符合给定的mark表达式的测试')
|
parser.add_argument('-m','--markexpr',help='只运行符合给定的mark表达式的测试',type=str)
|
||||||
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0')
|
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0',type=str)
|
||||||
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0')
|
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0',type=str)
|
||||||
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0')
|
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0',type=str)
|
||||||
|
parser.add_argument('-clr', '--clr', help='是否清空已有测试结果,1:是、0:否,默认为0', type=str)
|
||||||
args=parser.parse_args()
|
args=parser.parse_args()
|
||||||
|
|
||||||
# 处理pytest文件
|
# 处理pytest文件
|
||||||
|
@ -54,6 +55,10 @@ if __name__=='__main__':
|
||||||
if args.lf:
|
if args.lf:
|
||||||
if int(args.lf):
|
if int(args.lf):
|
||||||
pytest_execute_params.append('--lf')
|
pytest_execute_params.append('--lf')
|
||||||
|
# 判断是否清空已有测试结果
|
||||||
|
if args.clr:
|
||||||
|
if int(args.clr):
|
||||||
|
pytest_execute_params.append('--clean-alluredir')
|
||||||
pytest_execute_params.append(dir)
|
pytest_execute_params.append(dir)
|
||||||
|
|
||||||
print('开始测试......')
|
print('开始测试......')
|
||||||
|
|
|
@ -20,7 +20,7 @@ import ujson
|
||||||
def pytest_main(pytest_execute_params):
|
def pytest_main(pytest_execute_params):
|
||||||
exit_code = pytest.main(pytest_execute_params)
|
exit_code = pytest.main(pytest_execute_params)
|
||||||
|
|
||||||
def start_app_device_test(index,device_info,keyword,dir,markexpr,capture,reruns,lf):
|
def start_app_device_test(index,device_info,keyword,dir,markexpr,capture,reruns,lf,clr):
|
||||||
for path, dirs, files in os.walk('config/app_ui_tmp'):
|
for path, dirs, files in os.walk('config/app_ui_tmp'):
|
||||||
for file in files:
|
for file in files:
|
||||||
if(int(file)==index):
|
if(int(file)==index):
|
||||||
|
@ -79,6 +79,10 @@ def start_app_device_test(index,device_info,keyword,dir,markexpr,capture,reruns,
|
||||||
if lf:
|
if lf:
|
||||||
if int(lf):
|
if int(lf):
|
||||||
pytest_execute_params.append('--lf')
|
pytest_execute_params.append('--lf')
|
||||||
|
# 判断是否清空已有测试结果
|
||||||
|
if clr:
|
||||||
|
if int(clr):
|
||||||
|
pytest_execute_params.append('--clean-alluredir')
|
||||||
pytest_execute_params.append(dir)
|
pytest_execute_params.append(dir)
|
||||||
# 构建孙进程
|
# 构建孙进程
|
||||||
process = multiprocessing.Process(target=pytest_main, args=(pytest_execute_params,))
|
process = multiprocessing.Process(target=pytest_main, args=(pytest_execute_params,))
|
||||||
|
@ -91,12 +95,13 @@ if __name__=='__main__':
|
||||||
parser=argparse.ArgumentParser()
|
parser=argparse.ArgumentParser()
|
||||||
parser.add_argument('-k', '--keyword', help='只执行匹配关键字的用例,会匹配文件名、类名、方法名', type=str)
|
parser.add_argument('-k', '--keyword', help='只执行匹配关键字的用例,会匹配文件名、类名、方法名', type=str)
|
||||||
parser.add_argument('-d', '--dir', help='指定要测试的目录', type=str)
|
parser.add_argument('-d', '--dir', help='指定要测试的目录', type=str)
|
||||||
parser.add_argument('-m', '--markexpr', help='只运行符合给定的mark表达式的测试')
|
parser.add_argument('-m', '--markexpr', help='只运行符合给定的mark表达式的测试', type=str)
|
||||||
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0')
|
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0', type=str)
|
||||||
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0')
|
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0', type=str)
|
||||||
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0')
|
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0', type=str)
|
||||||
parser.add_argument('-tt', '--test_type', help='【必填】测试类型,phone、windows')
|
parser.add_argument('-tt', '--test_type', help='【必填】测试类型,phone、windows', type=str)
|
||||||
parser.add_argument('-dif', '--devices_info_file', help='多设备并行信息文件,当--test_type为android、ios、chrome时,此选项需提供')
|
parser.add_argument('-dif', '--devices_info_file', help='多设备并行信息文件,当--test_type为android、ios、chrome时,此选项需提供',type=str)
|
||||||
|
parser.add_argument('-clr', '--clr', help='是否清空已有测试结果,1:是、0:否,默认为0', type=str)
|
||||||
args=parser.parse_args()
|
args=parser.parse_args()
|
||||||
|
|
||||||
# 处理pytest文件
|
# 处理pytest文件
|
||||||
|
@ -116,6 +121,7 @@ if __name__=='__main__':
|
||||||
capture=args.capture
|
capture=args.capture
|
||||||
reruns=args.reruns
|
reruns=args.reruns
|
||||||
lf=args.lf
|
lf=args.lf
|
||||||
|
clr=args.clr
|
||||||
test_type=args.test_type.lower()
|
test_type=args.test_type.lower()
|
||||||
devices_info_file=args.devices_info_file
|
devices_info_file=args.devices_info_file
|
||||||
if test_type=='phone':
|
if test_type=='phone':
|
||||||
|
@ -131,7 +137,7 @@ if __name__=='__main__':
|
||||||
for i in range(len(devices_info)):
|
for i in range(len(devices_info)):
|
||||||
device_info=devices_info[i]
|
device_info=devices_info[i]
|
||||||
FileTool.writeObjectIntoFile(device_info,'config/app_ui_tmp/'+str(i))
|
FileTool.writeObjectIntoFile(device_info,'config/app_ui_tmp/'+str(i))
|
||||||
p=p_pool.apply_async(start_app_device_test,(i,device_info,keyword,dir,markexpr,capture,reruns,lf))
|
p=p_pool.apply_async(start_app_device_test,(i,device_info,keyword,dir,markexpr,capture,reruns,lf,clr))
|
||||||
p_pool.close()
|
p_pool.close()
|
||||||
p_pool.join()
|
p_pool.join()
|
||||||
else:
|
else:
|
||||||
|
@ -161,6 +167,10 @@ if __name__=='__main__':
|
||||||
if lf:
|
if lf:
|
||||||
if int(lf):
|
if int(lf):
|
||||||
pytest_execute_params.append('--lf')
|
pytest_execute_params.append('--lf')
|
||||||
|
# 判断是否清空已有测试结果
|
||||||
|
if clr:
|
||||||
|
if int(clr):
|
||||||
|
pytest_execute_params.append('--clean-alluredir')
|
||||||
pytest_execute_params.append(dir)
|
pytest_execute_params.append(dir)
|
||||||
exit_code = pytest.main(pytest_execute_params)
|
exit_code = pytest.main(pytest_execute_params)
|
||||||
|
|
||||||
|
|
|
@ -18,10 +18,11 @@ if __name__=='__main__':
|
||||||
parser=argparse.ArgumentParser()
|
parser=argparse.ArgumentParser()
|
||||||
parser.add_argument('-k','--keyword',help='只执行匹配关键字的用例,会匹配文件名、类名、方法名',type=str)
|
parser.add_argument('-k','--keyword',help='只执行匹配关键字的用例,会匹配文件名、类名、方法名',type=str)
|
||||||
parser.add_argument('-d','--dir',help='指定要测试的目录',type=str)
|
parser.add_argument('-d','--dir',help='指定要测试的目录',type=str)
|
||||||
parser.add_argument('-m', '--markexpr', help='只运行符合给定的mark表达式的测试')
|
parser.add_argument('-m', '--markexpr', help='只运行符合给定的mark表达式的测试',type=str)
|
||||||
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0')
|
parser.add_argument('-s', '--capture', help='是否在标准输出流中输出日志,1:是、0:否,默认为0',type=str)
|
||||||
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0')
|
parser.add_argument('-r', '--reruns', help='失败重跑次数,默认为0',type=str)
|
||||||
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0')
|
parser.add_argument('-lf', '--lf', help='是否运行上一次失败的用例,1:是、0:否,默认为0',type=str)
|
||||||
|
parser.add_argument('-clr', '--clr', help='是否清空已有测试结果,1:是、0:否,默认为0', type=str)
|
||||||
args=parser.parse_args()
|
args=parser.parse_args()
|
||||||
|
|
||||||
print('开始初始化......')
|
print('开始初始化......')
|
||||||
|
@ -80,6 +81,10 @@ if __name__=='__main__':
|
||||||
if args.lf:
|
if args.lf:
|
||||||
if int(args.lf):
|
if int(args.lf):
|
||||||
pytest_execute_params.append('--lf')
|
pytest_execute_params.append('--lf')
|
||||||
|
# 判断是否清空已有测试结果
|
||||||
|
if args.clr:
|
||||||
|
if int(args.clr):
|
||||||
|
pytest_execute_params.append('--clean-alluredir')
|
||||||
pytest_execute_params.append(dir)
|
pytest_execute_params.append(dir)
|
||||||
tmp_exit_code = pytest.main(pytest_execute_params)
|
tmp_exit_code = pytest.main(pytest_execute_params)
|
||||||
if not tmp_exit_code==0:
|
if not tmp_exit_code==0:
|
||||||
|
|
Loading…
Reference in New Issue