你还在为手动点点点测试Windows应用而感到膝盖疼?更愁于自动化测试工具价格贵得让钱包瑟瑟发抖?今天,我要给你安利一款“野路子有余,正经事儿也能干”的.NET UI自动化神器——FlaUI!别眨眼,看完你能少加三个夜班!
一、现代测试人的新困境
提到Windows UI自动化,你绝对不会陌生以下“名词”:
-
TestComplete:人狠话不多,价格劝退大多数;
-
Ranorex:功能炸裂,绝对旗舰,但同样价格不菲;
-
CodedUI:微软亲儿子,但听说它快退休了?
-
TestStack.White:开源选手,耍得溜但“年纪有点大”;
-
自己写Win32脚本?你可太狠了!
这些工具大多是基于微软UI Automation库的,说白了,底层还是MS家的活。不过你敢信,大厂的自动化测试也才刚过“能用”的线——兼容性像吃了 随机药水,一会好一会炸,真让人抓狂。
FlaUI横空出世,立志“新瓶装旧酒”,要用现代的新姿势搞定这些陈年老问题!
二、FlaUI到底是什么?(技术仔细看,它不一般)
通俗点说,FlaUI就是Windows应用自动化测试的专业“代打选手”。
-
✔ 它是基于.NET的开源库(C#粉丝速来集合!)
-
✔ 支持Win32、WinForms、WPF、甚至Windows Store Apps
-
✔ 底层用的是微软UI Automation的原生库,自己当了个“桥梁”
-
✔ API现代、代码优雅,二次开发易如反掌
-
✔ 支持UIA2 和 UIA3 两套自动化引擎,Flexibility up up up!
你能想到的Windows客户端测试场景,它都能搞。界面操作仿真、控件定位、事件监听、批量模拟,一套龙!
什么是UI Automation?UIA2、UIA3有啥区别?
别走神,这段很重要!
-
MSAA: 祖师爷级别,如今饱经风霜,出场率低(还有人用吗?)。
-
UIA2(Managed):.NET托管库,兼容性好,但不支持WPF新特色、不搭理Windows商店App(气人)。
-
UIA3(COM):微软最新的UIA方案,对WPF和Store App友好,但和部分WinForms控件还需要磨合。
FlaUI牛逼就牛逼在:让你自己选需要的那套UIA引擎,还能无缝切换! 这可是前辈们都搞不定的事(TestStack.White就因为代码太旧,各种尬 bug)。
三、你凭什么要用FlaUI?盘点一波优势
1. API现代易用,撸代码不费劲
-
一扫TestStack.White那种“爷爷级”API的时代风味
-
链式写法、lambda搜索、类型化强,Ctrl+C就是爽(老司机更有赶脚)
2. 支持市面上几乎所有主流Windows桌面技术
-
老旧的Win32、新潮的WPF、最头大的Window Store Apps,通吃!
-
遇啥都能测,没在怕的
3. 可选UIA2、UIA3内核,兼容问题自己灵活解决
-
WinForms偏古董,选UIA2更稳
-
WPF、Store App,直接用UIA3起飞
4. 完全开源,社区活跃,更新快
-
Github星星多,Pull Request响应快
-
遇阻有人问,提BUG也能得到响应
-
寄希望于厂商官方那是梦,开源才是未来
5. 大厂白嫖背书,ReSharper、AppVeyor都送License
-
这社区认可动静,绝对不是小打小闹
四、装逼时间——FlaUI代码体验:小白也能“玩”自动化!
1. 两步安装,官方Nuget包安排
有点基础都知道,只需一句:
Install-Package FlaUI.UIA3
想用UIA2,换个包名就行。你也聪明,自己查查Nuget。
2. 你的第一个FlaUI用例:打开记事本,霸气操作!
using FlaUI.Core;
using FlaUI.UIA3;
var app = Application.Launch("notepad.exe");
using (var automation = new UIA3Automation())
{
var window = app.GetMainWindow(automation);
Console.WriteLine("窗口标题:" + window.Title);
// 在“编辑区”输入文本
var edit = window.FindFirstDescendant(cf => cf.ByControlType(FlaUI.Core.Definitions.ControlType.Edit))?.AsTextBox();
edit?.Enter("FlaUI自动化准时下班,妈妈再也不用担心我的头发!");
// 点击菜单栏 “文件” -> “退出”
var fileMenu = window.FindFirstDescendant(cf => cf.ByText("文件"))?.AsMenuItem();
fileMenu?.Invoke();
// 根据需要关闭应用
}
不但能操作,还能定位子控件~功能伸缩自如!
3. 控件交互?各类Locators让你想点哪点哪
FlaUI的lambda表达式定位,丝滑且强大:
var button1 = window.FindFirstDescendant(cf => cf.ByText("1"))?.AsButton();
button1?.Invoke();
只要你界面里的控件有UI Automation可识别的“属性”,都能随便找!
批量操作
比如批量点击“计算器”的1到9按钮,只需for循环配合买一送一:
for(int i = 1; i <= 9; i++){
var button = window.FindFirstDescendant(cf => cf.ByText(i.ToString()))?.AsButton();
button?.Invoke();
}
4. 录制与辅助,有捷径
虽然FlaUI不是CodedUI自带录制器,但社区已有录制辅助(比如FlaUInspect),录控件更直观,鼠标点哪哪高亮,用起来比某些闭源收费家伙还舒畅!
五、FlaUI的扩展玩法
1. 集成CI/CD,自动化测试流水线一气呵成
FlaUI配合AppVeyor/Jenkins检测客户端回归,用CI让自动化测试上大雅之堂——“人到茶凉,测试已跑完”。
2. 自定义扩展,与任意.NET库共舞
用FlaUI定位控件后,你完全可以混合NUnit/xUnit编写断言; 还可以与你的工厂、封装层配合,让用例更优雅。
3. API级二次开发
想要特殊姿势,比如读取控件更多属性,甚至直接用原生UIA对象,FlaUI全部给你暴露出来!可谓“君子坦荡荡”,开发无死角!
六、被夸得天花乱坠,FlaUI有没有槽点?
1. 录制器体验还有提升空间(但社区正在完善)
2. UIA3和WinForms搭配偶尔会有奇怪bug
3. 必须.NET,Python党等只能看看
不过——凡事没有十全十美,但“开源+现代+强大”的优势已经让大部分人乐开了花。UI录制这块手动写写定位器,也是小菜一碟。
七、学FlaUI去哪看?资源大礼包送给你!
-
官方文档:https://github.com/FlaUI/FlaUI
-
YouTube系列教程:H Y R Tutorials,一个带你手把手实操的好频道
-
社区答疑:Gitter群活跃,点进去发问不迷路
-
源码体验:本体附带十足多的UI测试样例,照葫芦画瓢无压力