使用ATOMac进行Mac自动化测试
ATOMac简介
atomac是一个支持在mac上做自动化的python库,GitHub地址如下:
https://github.com/pyatom/pyatom
安装
# Python2
sudo easy_install atomac
# Python3
pip3 install git+https://github.com/pyatom/pyatom/
使用
1. 启动程序
import atomac
atomac.launchAppByBundleId('com.apple.Automator')
查看bundleID的方法
在应用程序->右键选择包内容->Contents->Info.plist
2. 查看app信息
automator = atomac.getAppRefByBundleId('com.apple.Automator')
print(automator)
输出
<atomac.AXClasses.NativeUIElement AXApplication '自动操作'>
3. 获取应用标题
window = automator.windows()[0]
print(window.AXTitle)
输出
未命名
atomac支持获取和操作大部分的元素,可以使用xcode提供的accessibility inspector快速查看各个元素
路径: Xcode -> Open Developer Tools -> Accessibility inspector
4. 获取元素快照列表
window = automator.windows()[0]
sheet = window.sheets()[0]
print(sheet)
输出:
<atomac.AXClasses.NativeUIElement AXSheet '表单'>
windows是atomac的一种定位方法,用来获取window元素,这里我们获取到了最顶层窗口的元素,然后再用sheets定位方法来获取当前window的元素快照(sheet)
atomac所有的定位方法加上'R'字符,就变成了一个搜索方法(可以添加额外的搜索条件),例如上面的方法我们可以直接改为:
sheet = automator.sheetsR()[0]
5. 通过快照获取元素
通过快照我们可以进行元素定位, 这里我们以关闭按钮为例
closeButton = sheet.buttons('关闭')[0]
print(closeButton)
输出:
<atomac.AXClasses.NativeUIElement AXButton '关闭'>
支持的元素类型查询方法有:
textAreas
textFields
buttons
windows
sheets
staticTexts
genericElements
groups
radioButtons
popUpButtons
rows
sliders
6. 条件搜索元素
atomac支持findFirst方法,根据属性来进行元素搜索,例如
closeButton = sheet.findFirst(AXRole='AXButton', AXTitle='关闭')
支持的属性可以在Accessibility inspector中查看
findFirst和findFirstR方法返回首个匹配的元素, 如果没有找到匹配的元素则返回None
同时还有findAll和findAllR使用方法相同,返回所以匹配的元素列表,没有匹配的元素则返回空列表
7. 查看元素支持的属性
closeButton = sheet.findFirst(AXRole='AXButton', AXTitle='关闭')
print(closeButton.getAttributes())
输出
['AXRole', 'AXHelp', 'AXEnabled', 'AXWindow', 'AXSize', 'AXTitle', 'AXRoleDescription', 'AXTopLevelUIElement', 'AXFocused', 'AXParent', 'AXPosition', 'AXFrame', 'AXIdentifier']
查看属性值
print(closeButton.AXTitle)
输出
关闭
8. 查看元素支持的操作
print(closeButton.getActions())
输出
['Press']
9. 元素操作
closeButton.Press()
任何支持的操作都可以这样调用
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 使用VSCode的Remote-SSH连接Linux进行远程开发
- Android ListView之EfficientAdapte的使用详解
- JavaScript:ECMAScript 2020中的新增功能
- Android编程实现播放视频的方法示例
- Android开发之RadioGroup的简单使用与监听示例
- Android 根据手势顶部View自动展示与隐藏效果
- Vue 3 如何安装
- Android实现状态栏(statusbar)渐变效果的示例
- Linux中stat函数和stat命令使用详解
- Android Beam 文件传输失败分析与解决方法
- Android实现修改状态栏背景、字体和图标颜色的方法
- Android视频压缩的示例代码
- Android如何从实现到封装一个MVP详解
- Android利用爬虫实现模拟登录的实现实例
- Android实现移动小球和CircularReveal页面切换动画实例代码