简介
前边具体操作和实战已经讲解和分享了很多了,但是一些android的一些基础知识,你又知道多少了,你都掌握了吗?这篇就由宏哥给小伙伴们既是一个分享,又是对前边的一次总结。为什么要对这些做一个简单的分享了,因为在现实具体工作中经常会遇到这样的问题,这里还是通过一个小故事来说明一下。
QA:“那个谁谁谁,我刚刚按照上一次那样操作这款款APP,我死活是跑不起测试脚本了。(内心独白:我去,这个奇怪的问题,一定是他给我的安装包有问题”)
DEV:“嗯?还有这样的问题,那你看一下你手机和电脑连接好了么?。(内心独白:一定是数据线没有连接好)”
QA:这个、这个...“咦,这个怎么看?(内心独白:我去,我怎么知道怎么看了,你不告诉我,我问手机和电脑,他们也不回答我啊)”
DEV:“嗖的一声,打开命令窗口,用这个命令:adb devices。(内心独白:鄙视一番,什么都不懂,这个简单)”
一会过去了......
QA:满心欢喜状,那个谁谁谁“我看了连接好了!(内心独白:一脸淫笑,我连接的怎么可能有问题了)”
DEV:“是不是package或者Activity有问题,你再看看(内心独白:小样,自己啥都不看就来问我)”
QA:“宝宝心里苦,但是宝宝不说!(内心独白:这个。唉。。。。。。。,我还是不会,硬着头皮再问开发)”
当你了解掌握android基础知识之后:
QA:“那个谁谁谁,我刚刚按照上一次那样操作这款款APP,我死活是跑不起测试脚本了。我也查看设备连接情况,以及安装包的package和Activity等等一些东西,和我代码里配置的Appium Desired Capabilities参数都正确,你看看是什么问题吧”
DEV:“厉害了Word哥!这个这个我查一下,是不是安装包打的包有问题,你稍等一下。(内心独白:真特么牛逼,都排查完了,还帮我定位了问题)”
全剧终!
以上虽说是个小故事,但是对于刚入职场的,确实是屡见不鲜,很多很多,如果你很幸运遇到个善良的开发,那还不错。反之,呵呵,那你就自求多福吧!!!
1、 ADB工具讲解
1.1 什么是ADB呢?
我们不去解释官方语言的翻译,给大家说一个通熟易懂的说法,ADB我理解为他就是电脑和手机连接的桥梁。此连接不是充电的连接,大家不要混淆,说他是一个调试工具,可能更贴切。
1.2 ADB有什么作用呢?
刚说的他是电脑和手机连接的桥梁,我们可以通过ADB操作手机,可以管理手机。可能你说这里手机包括模拟器嘛?答案是肯定的。
1.3 如何使用ADB?
我们在终端直接输入adb的命令就可以执行相应的操作。在测试过程中我们最常用的就是查看已经连接的android设备有哪些。大概整理了一下常用的:
1、adb devices 查看已经连接的android设备
2、adb install Baidu.apk 这个是安装应用,如果我们当前电脑连接了多台android机器时,使用这个命令是不行的,这个时候我们需要指定设备:adb -s install baidu.apk,这里的-s是指设备的信息,就是通过adb devices 查看的设备信息。
3、adb uninstall Baidu.apk 这个是卸载应用
4、adb connect 127.0.0.1:62001这个命令大家一定要记住,连接指定设备信息,这里的设备是指虚拟机,如果说我们使用的虚拟机不是官方的,是国产的天天、夜游神等等虚拟机你需要使用connect 命令连接,这里的端口号不一定是6555,这个需要根据你的模拟器的品牌来决定。刚学如果搞不定还是建议用真机,只需要打开adb调试就好。
2、 UIAutomatorviewer工具讲解
UIAutomatorviewer是一个定位工具,无论是在windows下还是mac下都可以用时,他在你androidsdk目录下的tools目录下,我只是按照我的给大家讲的,下面给大家配置一张图片,更加直观:
可以看一下在我的目录,在最后的tools目录下有一个uiautomatorviewer文件,我们之需要在当前目录直接敲击该目录命令就会打开我们的定位工具界面,下面我们直接看我们的效果图:
这个前边介绍过了,宏哥在这里就不啰嗦了,但是在这里需要记住一个问题,因为我用的是国产的模拟器,所以在启动模拟器后需要adb connect 127.0.0.1:xxxx,但是在这个之前你还是需要将模拟器里面的开发者选项打开的,因为只有建立连接后才能够使用定位工具,不然会报错。
我们打开定位工具、模拟器后直接点击定位工具左上角红色圈出的按钮(获取当前屏幕)uiautomatorviewer会自动获取到当前模拟器所打开的页面。
最左边的区域就是捕获的模拟器页面,在该页面鼠标移到你要查找的元素上面,在整个区域右面上面就是当前对象的一个布局结构,能够清晰的看见他是采用的是什么布局。右下角的区域就是我们需要定位的对象的属性值。
右下角的属性我做了一个区分,左边红色部分为属性名称,右边的则是属性值,当我在上边选择一个控件或者对象的时候下面的属性就会随着变化,在上图中的属性主要是:index、text、resource-id、class、package、content-desc,这些属性和属性值他们对应起来就是我们后面要讲的页面元素定位,我们做自动化最主要是和这几个属性去交互。这里需要注意一个问题:这个页面属性的text属性定位方式是针对name定位,但是在新版本appium中已经去掉了name定位,所以大家注意一下这个问题,到时候如果报错也不要着急。
3 、Package及Activity讲解
在整理这个知识的时候其实很纠结是否要讲这个知识点,但是权衡了一下决定还是讲解一下,不然后面的章节讲自动化时可能对于一些无基础的读者会有一些莫名其妙。
什么是Package呢?中文翻译过来大家都知道是包的意思,其实没错,你如果非得这么理解也没错,只是在我们的app中这个Package是唯一的,就像你身份证号码一样。在我们做app自动化时,我们就需要知道他的Package,我们知道了Package那么也就知道我们需要对哪个app做自动化,现在能理解Package是什么意思了么?
什么是Activity呢?官方给出的解释Activity是Android组建中最基本也是最为常见用的四大组件之一。看了这个是不是觉得很懵?so,他还有一种不确切的说法,就是和用户进行交互的,每当用户打开app进行操作的时候会发现在不断的跳页面,其实每个页面就是一个activity。我们做自动化时拿到了这个app的Package,但是我们还不能启动起来,因为我们没有告诉需要去操作哪一个Activity,因此在这个时候我们需要讲app启动时的Activity写入到启动参数中,如果你传入一个其他页面的是不行的。
4 、package及activity的获取
前面讲了那么多,但是还不知道怎么获取,对吧。哈哈,只知道作用但是不知道来源这个就没处使尽。
先说一下获取package和activity的方法,在网上说了有很多种,这里我只给大家说我们常用的。
1、因为自动化一般都是自己的应用,所以这个肯定是自己公司的,那么你拿这个还不简单?直接找开发要就行。
2、appium 有界面的客户端,这档你在设置里面选择了apk的路径之后系统会自动将该apk的相关信息展示在下面,所以很简单,不过悲催的是他不能够复制,你写在程序你的时候还是需要你一个一个字母敲击
3、通过android sdk工具来,在sdk里面有一个工具,叫做aapt,我们可以直接通过这个工具来,在命令行输入:aapt dump badging xxxx.apk,后面这个xxx.apk文件是我们aok所在的绝对路径,敲入之后那么可以显示出来相关信息,可以在里面仔细找了,packageName、lanuchActivity这两个字端,一个在开始1、2行一个在中间部分。如果找不到,在往后边找一找。
5、小结
好了,宏哥觉得介绍这些应该足够你用了,这样你和开发沟通起来也不是那么费劲,那么吃力,更不会看到开发鄙视的眼神,有兴趣的想了解更多的小伙伴们可以看这里(传送门)。
您的肯定就是我进步的动力。支持宏哥的朋友们和宏哥的宏粉记得点波 推荐 哦!!!
个人公众号
微信群