iOS App 测试环境升级,遇到的问题以及解决方法

news2025/1/27 12:57:42

iOS App 测试环境升级,遇到的问题以及解决方法

Mac 实体机升级到 Sonima 14.5

Xcode 升级到 15.3

问题1: Xcode 编译 WebDriverAgent 失败

尝试下载 最新版本的WDA 源码编译,可以编译成功。


问题2:具体坐标直接点击的代码都会报错。

向开源项目报了这个问题,过了10分钟就得到回复:https://github.com/appium/appium/issues/20218

Please use W3C Actions instead.
Also, we do not support Appium 1 anymore - please upgrade to Appium 2.

于是升级相关配置和修改所有涉及到的代码,使用 W3C Action 替换原来的 MultiAction、TouchAction。


问题3:升级 Appium 从 1.2.0 升级到 2.9,执行报错,unexpected keyword argument ‘desired_capabilites’

在这里插入图片描述

排查,搜到一个解决方法 https://github.com/appium/python-client/issues/878

该问题已经在 2.10 以上版本修复,于是再更新 Appium 到 2.11.1


问题4:系统弹框元素无法被识别到

在这里插入图片描述

之前也有这个问题,但是可以通过 driver.page_source 来定位到,现在升级后不行。

解决:不直接点击元素,而是使用脚本语句处理

driver.execute_script('mobile: alert',{'action': 'accept', 'buttonLabel': “Continue”}


问题5:登录google页面元素无法获取

之前偶尔也会遇到这个问题,但是重启模拟器、在Xcode重新编译WDA、重启Appium后,就可以定位到登录页面元素,这次升级后却不行。

在这里插入图片描述

重新安装了 Appium Server GUI 1.22.1版本(之前用的是 Appium 1.21.0-1),发现只要启动了Appium Server GUI 客户端后,不需要再通过 Xcode 编译出 WDA 到模拟器中,直接运行代码启动webdriver,模拟器中会自动生成 WDA,此时 Editor app 也能启动起来。

虽然现在不用自己去编译WDA 了,但是进入 Appium Server GUI 1.22.1 安装路径下的 /Applications/Appium\ Server\ GUI.app/Contents/Resources/app/node_modules/appium/node_modules/appium-webdriveragent,打开 WebDriverAgent.xcodeproj 来编译 WDA 会报错,无法生成WDA,但用 github 上的 WebDriverAgent-8.7.2 包来编译,是没问题的。

所以,现在使用 Appium Server GUI 1.22.1版本时,要么不自己去编译WDA,要么要用最新的包来编译 WDA,才能正常运行代码。


部分修改代码

点击坐标的方式改变,使用 PointerInput 和 ActionBuilder,不再支持 TouchAction(self.driver).tap(x=x, y=y, count=1).perform()

from selenium.webdriver import ActionChains
from selenium.webdriver.common.actions import interaction
from selenium.webdriver.common.actions.mouse_button import MouseButton
from selenium.webdriver.common.actions.action_builder import ActionBuilder
from selenium.webdriver.common.actions.pointer_input import PointerInput
pointer = PointerInput(kind=interaction.POINTER_TOUCH, name='finger1')
actions = ActionBuilder(self.driver, mouse=pointer)
actions.pointer_action.move_to_location(x, y)
actions.pointer_action.pointer_down()
actions.pointer_action.pointer_up()
actions.perform()
pointer = PointerInput(kind=interaction.POINTER_TOUCH, name='finger1')
actions = ActionBuilder(self.driver, mouse=pointer)
actions.pointer_action.move_to_location(start_x, start_y)
actions.pointer_action.pointer_down()
actions.pointer_action.pause(duration)
actions.pointer_action.move_to_location(end_x, end_y)
actions.pointer_action.pointer_up()
actions.perform()
actions = ActionChains(self.driver)
actions.w3c_actions.devices = []
pointer_input0 = actions.w3c_actions.add_pointer_input('touch', 'finger0')
pointer_input0.create_pointer_move(x=x, y=y)
pointer_input0.create_pointer_down()
pointer_input0.create_pause(0.5)
pointer_input0.create_pointer_move(x=x1, y=y1)
pointer_input0.create_pointer_up(MouseButton.LEFT)
pointer_input1 = actions.w3c_actions.add_pointer_input('touch', 'finger1')
pointer_input1.create_pointer_move(x=x, y=y)
pointer_input1.create_pointer_down()
pointer_input1.create_pause(0.5)
pointer_input1.create_pointer_move(x=x2, y=y2)
pointer_input1.create_pointer_up(MouseButton.LEFT)
actions.perform()
pointer = PointerInput(kind=interaction.POINTER_TOUCH, name='finger1')
actions = ActionBuilder(self.driver, mouse=pointer)
for index, point in enumerate(coordinate_list):
    x, y = point
    if index == 0:
        # Long press on the first point
        actions.pointer_action.move_to_location(x=x, y=y)
        actions.pointer_action.pointer_down().pause(0.5)
    else:
        # Move to subsequent points
        actions.pointer_action.move_to_location(x=x, y=y).pause(0.5)
actions.pointer_action.pointer_up()
actions.perform()

不再支持像 find_element_by_accessibility_id、find_element_by_name 这类的接口,而是使用 find_element(MobileBy.ACCESSIBILITY_ID, locator)find_element(By.NAME, locator)

# WebDriverWait(self.driver, timeout=time_out, poll_frequency=0.5, ignored_exceptions=None).until(lambda x: x.find_element_by_accessibility_id(locator))

WebDriverWait(self.driver, timeout=time_out, poll_frequency=0.5, ignored_exceptions=None).until(lambda x: x.find_element(MobileBy.ACCESSIBILITY_ID, locator))

处理系统弹框

def handle_system_alert(self, button='Continue'):
    try:
        WebDriverWait(self.driver, 10).until(ec.alert_is_present())
        self.driver.execute_script('mobile: alert', {'action': 'accept', 'buttonLabel': f'{button}'})
        return True
    except Exception as e:
        print(f"No alert present: {e}")
        return False

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1893998.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

简洁纯文字类的Typecho主题wenso

主题介绍 文章说说类博客网站源码,页面清新简洁。适合文章说说美文博客网站建站使用,响应式手机版本。 本来是dedecms的模板,也比较简单,适合用来搭建一个文学类的,纯文字的网站,简单的改成了typecho&…

nccl 04 nvidia 官方小程序

1,代码重新编辑 为了地毯式地检查结果的正确性,这里修改了代码 主要步骤为 step1: data_p指向的空间中,分别生成随机数; step2: 分别拷贝到gpu的sendbuff的显存中; step3: 通过nccl_all_reduce sum;…

职场办公受欢迎的电脑桌面便签,手机电脑同步的备忘录

在快节奏的职场生活中,有效的时间管理和信息记录变得尤为重要。为了帮助大家更好地应对工作挑战,好用的电脑桌面便签和手机电脑同步的备忘录,好用便签应运而生,成为了当前职场办公中的得力助手。 好用便签是一款备受青睐的电脑桌…

香橙派AIpro实测:YOLOv8便捷检测,算法速度与运行速度结合

香橙派AIpro实测:YOLOv8便捷检测,算法速度与运行速度结合 文章目录 香橙派AIpro实测:YOLOv8便捷检测,算法速度与运行速度结合一、引言二、香橙派AIpro简介三、YOLOv8检测效果3.1 目标检测算法介绍3.1.1 YOLO家族3.1.2 YOLOv8算法理…

Node.js 入门

目录 定义 什么是前端工程化? Node.js 为何能执行 JS? Node.js 安装 使用 Node.js fs 模块 - 读写文件 path 模块 - 路径处理 案例 - 压缩前端 html URL 中的端口号 常见的服务程序 http 模块-创建 Web 服务 浏览时钟(案例&#x…

2024最新中级会计职称考试全科题库资料。

1.根据消费税法律制度的规定,下列各项中,属于消费税征税范围的是()。 A.汽车轮胎 B.食用酒精 C.铂金首饰 D.体育上用的发令纸 答案:C 解析:选项ABD均不属于消费税的征税范围。 2.甲企业(…

2024亚太杯中文赛B题全保姆教程

B题 洪水灾害的数据分析与预测 问题 1. 请分析附件 train.csv 中的数据,分析并可视化上述 20 个指标中,哪 些指标与洪水的发生有着密切的关联?哪些指标与洪水发生的相关性不大?并 分析可能的原因,然后针对洪水的提前预…

基于Arduino平台开源小车的初步使用体验

创作原因:偶然有机会接触到基于Arduino平台的开源智能小车,初步使用后与大家分享。因使用时间不常,可以纯当个乐子看看,感谢大家的阅读! 图:一款基于Arduino平台的开源小车 一、开发环境 Misly&#xff1…

两个Activity之间切换时UI部分重叠

书籍 《第一行代码 Android》第三版 开发 环境 Android Studio Jellyfish | 2023.3.1 setContentView android studio自动生成的SecondActivity.kt中自动生成的代码中已经绑定了second_layout.xml的布局资源,通过代码:setContentView(R.layout.secon…

tkinter给按钮设置背景图片

tkinter给按钮设置背景图片 效果代码 效果 代码 import tkinter as tk from PIL import Image, ImageTk# 创建主窗口 root tk.Tk() root.title("按钮背景图片示例")# 加载图片 image Image.open("new.png") photo ImageTk.PhotoImage(image)# 创建按钮…

比Proxmox VE更易用的免费虚拟化平台

之前虚拟化一直玩Proxmox VE,最近发现一个更易用的虚拟化软件CSYun,他与Proxmox VE类似,都是一个服务器虚拟化平台。它不像VMware ESXi那么复杂,对于个人使用者和中小企业是一个比较好的选择。 这个软件所在的网址为:…

Nuxt3 的生命周期和钩子函数(十)

title: Nuxt3 的生命周期和钩子函数(十) date: 2024/6/30 updated: 2024/6/30 author: cmdragon excerpt: 摘要:本文详细介绍了Nuxt3框架中的五个webpack钩子函数:webpack:configResolved用于在webpack配置解析后读取和修改配置…

PCL从理解到应用【02】PCL环境安装 | PCL测试| Linux系统

前言 本文介绍在Ubuntu18.04系统中,如何安装PCL。 源码安装方式:pcl版本1.91,vtk版本8.2.0,Ubuntu版本18.04。 安装好后,可以看到pcl的库,在/usr/lib/中; 通过编写C代码,直接调用…

2.8亿东亚五国建筑数据分享

数据是GIS的血液! 我们现在为你分享东亚5国的2.8亿条建筑轮廓数据,该数据包括中国、日本、朝鲜、韩国和蒙古5个东亚国家完整、高质量的建筑物轮廓数据,你可以在文末查看领取方法。 数据介绍 虽然开源的全球的建筑数据已经有微软的建筑数据…

​埃文科技受邀出席2024 “数据要素×”生态大会​

2024“数据要素”生态大会(以下简称“大会”)于2024年6月30日在河南省郑州市举办。大会在国家数据局、河南省人民政府等单位的指导下,由中国经济体制改革研究会、中国电子信息产业集团有限公司、郑州市人民政府等共同主办。大会主题为“加快数…

C++字体库开发之字体回退三

代码片段 class FontCoverage { public: using SP std::shared_ptr<FontCoverage>; virtual ~FontCoverage() default; virtual void set(int index, FontTypes::CoverageLevel level) 0; virtual FontTypes::Coverag…

架构 | 数据归档

INDEX 1 通用思路2 快速归档3 归档整体流程&#xff08;完整归档 & 快速归档&#xff09;4 准备阶段4.1 确认归档表4.2 思路&#xff1a;确认归档数据范围 & 归档方案待选&#xff08;重点&#xff09;4.3 归档方式选择 & 业务场景覆盖4.4 确认归档数据范围 & …

Spring源码十:BeanPostProcess

上一篇Spring源码九&#xff1a;BeanFactoryPostProcessor&#xff0c;我们看到ApplicationContext容器通过refresh方法中的postProcessBeanFactory方法和BeanFactoryPostProcessor类提供预留扩展点&#xff0c;他可以在Spring容器的层面对BeanFactroy或其他属性进行修改&#…

微信小程序遮罩层显示

效果展示&#xff1a; wxml页面&#xff1a; <view classmodal-mask wx:if{{showModal}}><view class"modal-container"><view classmodal-content></view><view classmodal-footer bindtap"closeImage">//这个/images/ind…

MATLAB——循环语句

一、for end语句 在该语法中&#xff0c;循环变量是用于迭代的变量名&#xff0c;它会在每次循环迭代中从向量或矩阵中取出一列的值。数值向量或者矩阵则表示了循环变量可以取值的范围&#xff0c;通常根据实际需要事先给定。一旦循环变量遍历完数值向量或者矩阵中的所有值&…