Python subprocess.run 使用注意事项,避免出现list index out of range

在执行iOS UI 自动化专项测试的时候,在运行第一遍的时候遇到了这样的错误:

python 复制代码
2024-12-04 20:22:27 ERROR conftest pytest_runtest_makereport 106  Test test_open_stream.py::TestOpenStream::test_xxx_open_stream[iPhoneX-xxx-1-250] failed with error: list index out of range

对应客户端上的状态是:

得出判断应该是:开流失败,对应的状态没有回来,程序中没有获取到。那么当这种情况发生时如何解决上面的bug呢?看下代码:

python 复制代码
def grep_from_sandbox_log(grep_condition, iphone_model):
    # iOS沙盒目录
    log_date = datetime.now().strftime("%Y%m%d")
    mount_path = f"/Users/testmanzhang/ios_sandbox/{iphone_model}/Documents/Logs/"
    log_file_path = f"{mount_path}glazero_app_ios_{log_date}.log"

    result = None

    get_state_cmd = f"grep {grep_condition} {log_file_path}"

    if os.path.isfile(log_file_path):
        result = subprocess.run(get_state_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)

        if result.stderr:
            logger.error(f"grep 错误: \n {result.stderr}")
    else:
        logger.error(f"日志文件不存在: {log_file_path}")

    return result
python 复制代码
def get_dev_play_state_result(click_time, iphone_model, sn):
    grep_condition = f"'previewSuccess  deviceId = {sn}'"
    get_result = grep_from_sandbox_log(grep_condition, iphone_model)

    # 分析获取的结果
    if get_result:
        lines = result_get_success.stdout.splitlines()
        last_line = lines[-1]
        logger.info(f"最后一行唤醒成功的结果: {last_line}\n")

问题出现在grep_from_sandbox_log方法中的

python 复制代码
result = subprocess.run(get_state_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)

如果结果是空的时候,返回的result是:

python 复制代码
CompletedProcess(args='truncate -s 0 /Users/testmanzhang/ios_sandbox/iPhoneX/Documents/Logs/glazero_app_ios_20241204.log', returncode=0, stdout='', stderr='')

这时候在get_dev_play_state_result方法中,对获取到的返回结果进行判断也是True,这样问题就发生了,lines其实是一个空列表,再去使用[-1]去获取数据就报错了。

python 复制代码
    if get_result:
        lines = result_get_success.stdout.splitlines()
        last_line = lines[-1]

解决这个问题要在grep_from_sandbox_log方法中对result进行处理,即对result.stdout进行处理,把处理完成后的结果返回给其他方法,例如,get_dev_play_state_result,不能直接返回result。

在grep_from_sandbox_log方法中调整一下:

python 复制代码
    if os.path.isfile(log_file_path):
        result = subprocess.run(get_state_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)

        if result.stderr:
            logger.error(f"grep 错误: \n {result.stderr}")
        elif result.returncode == 0 and result.stdout == '':
            logger.info(f"返回的return code为'',stdout为''")
        elif result.returncode == 0 and result.stdout != '':
            logger.info(f"返回的内容不为空,返回result.stdout的内容")
            get_result = result.stdout
相关推荐
qq_5260991337 分钟前
六口网卡:工业级千兆以太网控制器,赋能智能制造与边缘计算
图像处理·自动化
MZ_ZXD0015 小时前
springboot汽车租赁服务管理系统-计算机毕业设计源码58196
java·c++·spring boot·python·django·flask·php
A 计算机毕业设计-小途5 小时前
大四零基础用Vue+ElementUI一周做完化妆品推荐系统?
java·大数据·hadoop·python·spark·毕业设计·毕设
念念01079 小时前
数学建模竞赛中评价类相关模型
python·数学建模·因子分析·topsis
四维碎片9 小时前
【Qt】线程池与全局信号实现异步协作
开发语言·qt·ui·visual studio
云天徽上9 小时前
【数据可视化-94】2025 亚洲杯总决赛数据可视化分析:澳大利亚队 vs 中国队
python·信息可视化·数据挖掘·数据分析·数据可视化·pyecharts
☺����10 小时前
实现自己的AI视频监控系统-第一章-视频拉流与解码2
开发语言·人工智能·python·音视频
王者鳜錸10 小时前
PYTHON让繁琐的工作自动化-函数
开发语言·python·自动化
xiao助阵11 小时前
python实现梅尔频率倒谱系数(MFCC) 除了傅里叶变换和离散余弦变换
开发语言·python
★YUI★12 小时前
学习游戏制作记录(制作系统与物品掉落系统)8.16
学习·游戏·ui·unity·c#