当前位置: 首页 > news >正文

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

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

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呢?看下代码:

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 = Noneget_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
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方法中的

result = subprocess.run(get_state_cmd, shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True)

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

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]去获取数据就报错了。

    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方法中调整一下:

    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

相关文章:

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

在执行iOS UI 自动化专项测试的时候,在运行第一遍的时候遇到了这样的错误: 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 err…...

包管理器npm,cnpm,yarn和pnpm

npm (Node Package Manager) 核心技术与工作原理 依赖解析: 广度优先搜索(BFS):npm 使用 BFS 算法来解析依赖树,尽量扁平化 node_modules 目录以减少重复的依赖项。冲突处理:如果两个包需要同一个依赖的不…...

树莓派4B使用opencv读取摄像头配置指南

本文自己记录,给我们lab自己使用,其他朋友们不一定完全适配,请酌情参考。 一. 安装opecnv 我们的树莓派4B默认是armv7l架构,安装的miniconda最新的版本 Miniconda3-latest-Linux-armv7l.sh 仍然是python3.4几乎无法使用&#xff…...

Spring Boot 进阶话题:部署

部署是将应用程序从开发环境移动到可以供用户访问的生产环境的过程。Spring Boot提供了多种部署选项,包括打包为可执行jar文件,使用Docker容器化,以及部署到云平台。 打包Spring Boot应用 Spring Boot应用可以打包为包含所有依赖、类和资源…...

Python 3 和 MongoDB 的集成使用

Python 3 和 MongoDB 的集成使用 MongoDB 是一个流行的 NoSQL 数据库,以其灵活的数据模型和强大的查询功能而闻名。Python 3 作为一种广泛使用的编程语言,与 MongoDB 的集成变得日益重要。本文将介绍如何在 Python 3 环境中集成和使用 MongoDB&#xff…...

perl语言中模式匹配的左右关系

这里简单记录一下,在perl语言中,关于模式匹配的一个细节: 在进行模式匹配的时候,左边写需要查找的字符串,右侧写匹配的关键字. 两边的顺序不一样就会导致匹配结果不一样. 测试代码:…...

【漏洞复现】网动统一通信平台(ActiveUC)接口iactiveEnterMeeting存在信息泄露漏洞

🏘️个人主页: 点燃银河尽头的篝火(●’◡’●) 如果文章有帮到你的话记得点赞👍+收藏💗支持一下哦 @TOC 一、漏洞概述 1.1漏洞简介 漏洞名称:网动统一通信平台(ActiveUC)接口iactiveEnterMeeting存在信息泄露漏洞漏洞编号:无漏洞类型:信息泄露漏洞威胁等级:高危影…...

C++ STL 容器系列(三)list —— 编程世界的万能胶,数据结构中的百变精灵

STL系列学习参考: C STL系列__zwy的博客-CSDN博客https://blog.csdn.net/bite_zwy/category_12838593.html 学习C STL的三个境界,会用,明理,能扩展,STL中的所有容器都遵循这个规律,下面我们就按照这三个境…...

Java经典面试题总结(附答案)2025

点击获取PDF版 10、如何将字符串反转? 添加到StringBuilder中,然后调用reverse()。 11、String 类的常用方法都有那些? equals、length、contains、replace、split、hashcode、indexof、substring、trim、toUpperCase、toLowerCase、isEmpt…...

Stylus 浏览器扩展开发-Cursor AI辅助

项目起源 作为一个经常需要长时间盯着屏幕的开发者,我一直在寻找一个简单的方法来保护眼睛。最初的想法很简单:将网页背景色替换成护眼的豆沙绿。虽然市面上已经有类似的扩展,但我想要一个更加轻量且可定制的解决方案。 这个简单的需求逐渐…...

DAY35|动态规划Part03|LeetCode:01背包问题 二维、01背包问题 一维、416. 分割等和子集

目录 01背包理论基础(一) 基本思路 C代码 01背包理论基础(二) 基本思路 C代码 LeetCode:416. 分割等和子集 基本思路 C代码 01背包理论基础(一) 题目链接:卡码网46. 携带研究材料 文字…...

创建空向量:std::vector<int> v,刚创建时大小为0

创建一个空的std::vector<int> v会在刚创建时具有大小&#xff08;size&#xff09;为0的特点。这意味着此时向量中没有任何元素&#xff0c;而且其容量&#xff08;capacity&#xff09;也返回0&#xff0c;表明还没有为这个向量分配任何内存空间3。换句话说&#xff0c…...

VBA基础2

VBA基础2 sub过程语法对单元格进行赋值操作连续赋值不连续赋值 cells &#xff08;行&#xff0c;列&#xff09;行引用rows列引用 &#xff08;columns&#xff09;offset位移属性End属性&#xff08;指定返回&#xff09; 使用VBA编辑器需要用AltF11打开 或者VB编辑器打开 可…...

计算机网络-GRE基础实验二

前面我们学习了GRE隧道的建立以及通过静态路由指向的方式使得双方能够网络互联&#xff0c;但是通过静态路由可能比较麻烦&#xff0c;GRE支持组播、单播、广播因此可以在GRE隧道中运行动态路由协议使得网络配置更加灵活。 通过前面的动态路由协议的学习我们知道动态路由协议都…...

JSON 使用

JSON 使用 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。它基于JavaScript编程语言的一个子集,但因其文本格式清晰简洁,被广泛用于数据交换和存储。本文将详细介绍JSON的使用方法,包括其语法、数据类型、如…...

Leetcode—1539. 第 k 个缺失的正整数【简单】

2024每日刷题&#xff08;206&#xff09; Leetcode—1539. 第 k 个缺失的正整数 C实现代码 class Solution { public:int findKthPositive(vector<int>& arr, int k) {int missing 1;int cur 1;int n arr.size();int missingCnt 0;int ptr 0;for(; missingCn…...

深入浅出:PHP 控制结构与循环语句

文章目录 引言控制结构条件判断if-else 语句elseif 语句嵌套的 if 语句三元运算符 switch 语句 循环语句for 循环遍历数组使用 range() while 循环基本用法无限循环循环控制语句break 语句continue 语句do-while 循环 综合案例参考资料 引言 PHP 是一种广泛用于服务器端开发的…...

深入解析 Loss 减少方式:mean和sum的区别及其在大语言模型中的应用 (中英双语)

深入解析 Loss 减少方式&#xff1a;mean 和 sum 的区别及其在大语言模型中的应用 在训练大语言模型&#xff08;Large Language Models, LLM&#xff09;时&#xff0c;损失函数&#xff08;Loss Function&#xff09;的处理方式对模型的性能和优化过程有显著影响。本文以 re…...

c++ auto

在C中&#xff0c;auto 是一种类型推导关键字&#xff0c;它允许编译器根据初始化表达式的类型自动推导变量的类型。自 C11 标准引入以来&#xff0c;auto 使得代码更加简洁&#xff0c;并且可以减少冗长的类型声明&#xff0c;尤其是在类型名称非常复杂或难以立即确定的情况下…...

python中的列表、元组、字典的介绍与使用

目录 一、区别介绍 1.使用场景以及区别图 2.详细介绍 列表 元组 字典 二、例子操作 (一)列表list 1.定义和初始化 2.访问元素&#xff08;下标&#xff09; 3.修改元素&#xff08;下标&#xff09; 4.添加元素&#xff08;append、下标insert&#xff09; 5.删除…...

C51可重入函数原理与实践指南

1. 理解C51中的可重入函数概念 在8051单片机开发中&#xff0c;可重入函数(Reentrant Function)是一个关键但常被误解的概念。与通用计算机上的C语言开发不同&#xff0c;由于8051架构的特殊限制&#xff0c;标准C51函数默认都是不可重入的。这源于8051硬件设计的几个固有特点&…...

VMware虚拟机安装银河麒麟V10超详细图文教程(全程附实拍截图+避坑指南)

前言 近期工作学习需要使用国产银河麒麟操作系统&#xff0c;于是在VMware虚拟机中进行安装部署&#xff0c;安装途中接连踩坑&#xff0c;选错镜像、系统无法识别、启动报错等问题全部遇到。本文全程实拍每一步操作截图&#xff0c;记录完整安装流程&#xff0c;同时把所有踩…...

终极ncmdump使用指南:3步解锁网易云NCM加密音乐,实现跨平台自由播放

终极ncmdump使用指南&#xff1a;3步解锁网易云NCM加密音乐&#xff0c;实现跨平台自由播放 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 你是否曾为网易云音乐下载的NCM格式文件无法在其他设备播放而烦恼&#xff1f;ncmdump作为…...

重复内容误标率高达37%?NotebookLM检测逻辑漏洞全曝光,立即修复这6个隐藏开关

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;重复内容误标率高达37%&#xff1f;NotebookLM检测逻辑漏洞全曝光&#xff0c;立即修复这6个隐藏开关 NotebookLM 的“重复内容检测”功能并非基于端到端语义比对&#xff0c;而是依赖于分块哈希&#…...

gptree:为AI生成项目结构报告,提升代码分析与协作效率

1. 项目概述与核心价值最近在整理个人项目和代码库时&#xff0c;我遇到了一个几乎所有开发者都会头疼的问题&#xff1a;项目越做越多&#xff0c;文件夹嵌套越来越深&#xff0c;README写得再好&#xff0c;时间一久也记不清某个具体功能的实现细节藏在哪个文件的哪个角落里。…...

Arm Neoverse V2内存架构与PCIe地址管理解析

1. Arm Neoverse V2内存架构设计精要 在Arm Neoverse V2的体系结构中&#xff0c;内存映射机制是其高性能计算能力的基石。这套架构通过精细的地址空间划分&#xff0c;实现了对各类硬件资源的高效管理。我们先来看一个典型的多芯片系统内存布局示例&#xff1a; Chip 0: 0x0…...

Dify工作流终极指南:50+模板一键导入,零基础也能快速上手AI自动化

Dify工作流终极指南&#xff1a;50模板一键导入&#xff0c;零基础也能快速上手AI自动化 【免费下载链接】Awesome-Dify-Workflow 分享一些好用的 Dify DSL 工作流程&#xff0c;自用、学习两相宜。 Sharing some Dify workflows. 项目地址: https://gitcode.com/GitHub_Tren…...

哔哩下载姬终极指南:5分钟掌握B站视频批量下载与高清画质处理

哔哩下载姬终极指南&#xff1a;5分钟掌握B站视频批量下载与高清画质处理 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等…...

让macOS窗口切换像Windows一样高效:alt-tab-macos完全指南

让macOS窗口切换像Windows一样高效&#xff1a;alt-tab-macos完全指南 【免费下载链接】alt-tab-macos Windows alt-tab on macOS 项目地址: https://gitcode.com/gh_mirrors/al/alt-tab-macos 你是否曾经在macOS上怀念Windows的alttab快捷键&#xff1f;是否觉得macOS…...

使用Taotoken后API调用延迟与稳定性体感观察报告

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 使用Taotoken后API调用延迟与稳定性体感观察报告 1. 引言&#xff1a;从直接对接模型到使用聚合平台 在开发基于大语言模型的应用…...