APP自动化入门

01.移动端测试知识概览

01.1 移动端测试是什么?

移动端测试是指对移动应用进行的测试,即实体的特性满足需求的程度。

01.2 移动端测试分类?

  • app功能测试

    • 业务逻辑正确性测试

      • 文档

    • 兼容性测试

      • 系统版本

      • 分辨率

      • 网络情况

    • 异常测试

      • 热启动应用

      • 网络切换&中断恢复

      • 电话&信息中断恢复

    • 升级&安装卸载测试

    • 健壮性测试

      • 手机资源消耗

      • 流量消耗

      • 崩溃恢复等测试

  • app自动化测试

    • 通过场景和数据的预设,把以人为驱动的测试行为转化为机器执行的一种过程,并不是所有功能都能进行自动化。

  • app安全测试

    • 通过安全测试技术,保证app尽可能的不存在安全漏洞.

01.3 市场招聘如何?

互联网移动场景下业务的爆发,导致移动端开发和测试人员需求量增大,市场很缺移动端的人才。

公司待遇:

  1. app功能测试,一般1-3年的功能测试人员月薪8k-15k

  2. app自动化测试,一般1-3年的自动化测试月薪13k-25k

02.移动端测试环境搭建

我们的目标是Android测试,所以环境需要搭建三个,Java,AndroidSDK,Android模拟器。

为什么要安装这三个环境,我们倒着来说:

Android模拟器:实际上就是一台手机,方便我们给大家展示效果。

AndroidSDK:Android SDK给你提供开发测试所必须的Android API类库。

Java:Android的底层是c、c++,应用层用的语言是Java所以需要使用Java环境。

02.1 Java环境

windows

安装JDK1.8

运行jdk-8u151-windows-x64.exe文件,默认安装即可(例如我的安装目录:C:\Program Files\Java\jdk1.8.0)

配置java环境变量(Windowns7为例)

1.进入我的电脑 -> 属性 -> 高级系统设置 -> 环境变量

2.在系统变量下点击新建 -> 变量名: JAVA_HOME -> 变量值: C:\Program Files\Java\jdk1.8.0 -> 点击确定按钮

3.在系统变量下点击新建 -> 变量名: CLASSPATH -> 变量值: .;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar(***变量值最前面有一个".") -> 点击确定按钮

4.在系统变量下找到系统的path变量,进入在最后添加:;%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin(最前面是一个分号,如果path变量最后已有分号,可不用添加) -> 点击确定按钮

验证环境变量


1.win+r 或者 开始 -> 搜索框输入cmd

2.在界面运行java -version

3.出现版本即可

macOS

安装JDK


安装 jdk-8u151-macosx-x64.dmg

配置环境变量


1.进入命令行, vim ~/.bash_profile 
2.# set jdk1.8
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_151.jdk/Contents/Home
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
PATH=$PATH:$JAVA_HOME/bin
export JAVA_HOME CLASSPATH
export PATH

验证


1.打开终端

2.在界面运行java -version

3.出现版本即可

02.2 AndroidSDK环境

windows

将SDK保存到硬盘


Android SDK文件夹解压到任意目录(记住这个目录的位置,目录不要有中文)

配置环境变量


1.进入我的电脑 -> 属性 -> 高级系统设置 -> 环境变量

2.在系统变量下点击新建 -> 变量名: ANDROID_HOME -> 变量值: D:\android-sdk -> 点击确定按钮

3.在系统变量下找到系统的path变量,最后添加:;%ANDROID_HOME%\platform-tools;%ANDROID_HOME%\tools;(最前面是一个分号,如果path变量最后已有分号,可不用添加) -> 点击确定按钮

验证环境变量


命令行输入adb,不报错即可

macOS

将SDK保存到硬盘


Android SDK文件夹解压到任意目录(记住这个目录的位置,目录不要有中文)

配置环境变量

1.进入命令行, vim ~/.bash_profile
2.# set android
ANDROID_HOME=电脑存放的路径/android-sdk-macosx

PATH=$PATH:$ANDROID_HOME/tools:$ANDROID_HOME/platform-tools

export ANDROID_HOME 
export PATH

验证环境变量


命令行输入adb,不报错即可

补充:下载其他版本SDK

1.win或mac的命令行中输入android

2.因国外下载较慢,所以需要配置国内镜像

windows


在弹出的Android SDk Manager页面,点击Tools ,下拉框点击Options...

mac


点击Android SDk Manager,点击preferences


镜像地址列表(也可以网上查找最新的):

    中国科学院开源协会镜像站地址:

        IPV4/IPV6: mirrors.opencas.cn 端口:80

        IPV4/IPV6: mirrors.opencas.org 端口:80

        IPV4/IPV6: mirrors.opencas.ac.cn 端口:80

    上海GDG镜像服务器地址:

        sdk.gdgshanghai.com 端口:8000

    北京化工大学镜像服务器地址:

        IPv4: ubuntu.buct.edu.cn/ 端口:80

        IPv4: ubuntu.buct.cn/ 端口:80

        IPv6: ubuntu.buct6.edu.cn/ 端口:80

    大连东软信息学院镜像服务器地址:

        mirrors.neusoft.edu.cn 端口:80

02.3 Android模拟器安装

windows

模拟器Genymotion安装


1.执行genymotion-2.11.0-vbox.exe(是一个集合程序,包含genymotion和virtualbox) -> 不需要更改配置,直接下一步默认安装

2.安装完genymotion继续等待,会提示安装virtualbox,继续安装,期间会提示安装oracle插件,全部允许安装

3.安装完成后会在桌面展示genymotion和virtualbox两个图标

虚拟机镜像导入


1.打开virtualbox

2.进入virtualbox -> 管理 -> 导入虚拟电脑

3.点击文件选择(Samsung Galaxy S6 - 5.1.0 - API 22 - 1440x2560.ova) -> 点击下一步

4.勾选 重新初始化所有网卡的MAC地址

5.点击导入按钮 -> 等待倒入完成

6.virtualbox列表会展示如下图圈出的选项

启动android模拟器


1.点击genymotion图标 -> 弹出框点击 >Personal Use

2.同意条款

3.genymotion主界面选择系统后点机start按钮

4.启动成功

macOS

请阅读Windows的使用方法后再阅读mac,因为两者基本一致。

模拟器Genymotion安装


1.安装VirtualBox-5.1.30-OSX.dmg

2.安装genymotion-2.11.0.dmg

虚拟机镜像导入


1.双击Samsung Galaxy S6 - 5.1.0 - API 22 - 1440x2560.ova

2.点击导入

启动android模拟器


同 windows

为虚拟机提供安装apk功能


1.安装genymotion ARM插件,此插件可提供x86运行环境,即可运行apk,需要下载对应版本的插件(本次使用android 5.1版本插件)

2.拖动ARM_Translation_Lollipop_20160402.zip到已启动的android虚拟机上

3.点击提示的ok按钮

4.重启后生效

补充:下载其他版本模拟器

需要注册一个genymotion账号,官网:https://www.genymotion.com

进入genymotion,点击Add按钮

点击Sign in,输入注册的genymotion用户名和密码

选择下载需要版本的模拟器

等待下载完成(下载时间根据网络)

03.adb命令介绍

03.1 adb的含义

ADB全名Andorid Debug Bridge。 是一个Debug工具。为何称之为Bridge呢?因为adb是一个标准的C/S结构的工具, 是要连接开发电脑和调试手机的。包含如下几个部分:


1.Client端,运行在开发机器中,即你的开发PC机。用来发送adb命令。
2.Daemon守护进程, 运行在调试设备中, 即的调试手机或模拟器。
3.Server端, 作为一个后台进程运行在开发机器中, 即你的开发PC机. 用来管理PC中的Client端和手机的Daemon之间的通信。

03.2 adb常用命令

adb帮助


adb --help

启动adb server

adb start-server

关闭adb server


adb kill-server

获取设备号

adb devices

获取系统版本


adb -s 设备号 shell getprop ro.build.version.release

发送文件到手机


adb push 电脑端文件路径/需要发送的文件  手机端存储的路径

示例:
    将桌面的xx.png发送到手机sdcard目录下
    adb push C:\Users\win\Desktop\xx.png  /sdcard

从手机拉取文件


adb pull 手机端的路径/拉取文件名 电脑端存储文件路径

示例:
    将手机/sdcard目录中的xx.png文件,发送到电脑桌面
    adb pull /sdcard/xx.png C:\Users\win\Desktop

查看手机运行日志

adb logcat


手机shell命令行

adb shell


获取app启动包名和启动名

手机需要先打开对应app

1.Mac/Linux: 'adb shell dumpsys window windows | grep mFocusedApp’
2.在 Windows 终端运行 'adb shell dumpsys window windows’ 然后去看mFocusedApp这一行的内容。

安装app到手机

adb install 路径/xx.apk

卸载手机手机app


adb uninstall 包名

获取app启动时间

adb shell am start -W 包名/启动名

示例:
	adb shell am start -W com.yly.drawpic/.MainActivity
解释:
	ThisTime  该activity启动耗时
	TotalTime  应用自身启动耗时 = ThisTime + 应用application等资源启动时间
	WaitTime  系统启动应用耗时 = TotalTime + 系统资源启动时间


04.移动端自动化测试工具

04.1 主流的移动端自动化工具

  • Robotium

​ 1.支持语言:Java

​ 2.仅支持Android系统

​ 3.不支持跨应用

  • Macaca

​ 1.支持语言:Java,Python,Node.js

​ 2.支持Android和iOS系统

​ 3.支持跨应用

  • Appium

​ 1.支持语言:Java,C#,Python,php,perl,ruby,Node.js

​ 2.支持Android和iOS系统

​ 3.支持跨应用

  • 自动化工具选择的关注点

​ 1.是否支持native,webview

​ 2.是否支持获取toast

​ 3.是否支持跨应用

04.2 Appium介绍

Appium是一个移动端的自动化框架,可用于测试原生应用,移动网页应用和混合型应用,且是跨平台的。可用于IOS和Android以及firefox的操作系统。原生的应用是指用android或ios的sdk编写的应用,移动网页应用是指网页应用,类似于ios中safari应用或者Chrome应用或者类浏览器的应用。混合应用是指一种包裹webview的应用,原生应用于网页内容交互性的应用。重要的是Appium是跨平台的,何为跨平台,意思就是可以针对不同的平台用一套api来编写测试用例。

04.3 Appium特点

1.使用自动化来测试一个app,但是不需要重新编译它2.写自动化case,不需要学习特定的语言3.一个自动化框架不需要重复造轮子4.一个自动化框架需要开源,在精神和实践上实现开源

04.4 Appium自动化测试环境搭建

我们使用Appium和python来进行自动化测试,需要安装两个东西,一个是Appium的客户端,一个是Appium-python库。这两个需要安装的东西在加上手机就可以进行自动化测试,它们之间的关系是:python代码 -> Appium-python库 -> Appium -> 手机。

Appium客户端安装

Appium背景介绍
1.官网:www.appium.io,由SauceLab公司开发

2.Appium是由nodejs的express框架写的Http Server,Appium使用WebDriver的json wire协议,来驱动Apple系统的UIAutomation库、Android系统的UIAutomator框架


Appium桌面客户端安装方式

1. 运行appium-desktop-Setup-1.2.7.exe,默认安装即可
2. 启动客户端,按图片步骤 1 -> 2 -> 3 -> 4 设置

3. 启动成功展示如下图


Appium命令行安装方式
1. 安装Node.js ->Win:官网下载可执行包安装(Linux: yum install; Macos: brew install)
2. 安装完成后 命令行运行npm或node -v 来查看是否安装成功

敲黑板: npm国内一般被墙,所以选择淘宝镜像安装,官网:http://npm.taobao.org
3. 安装cnpm: npm install -g cnpm --registry=https://registry.npm.taobao.org

4. 安装appium: cnpm install -g appium


4. 启动appium服务命令: appium &,如下图即正确安装
敲黑板: Windows安装会提示os的模块错误,这个需要mac系统支持,不影响windows操作使用

Appium-python库安装

命令行安装(需要联网)
pip3 install Appium-Python-Client
安装包安装
前提:python已安装setuptools包
安装setuptools:
    1.解压setuptools-38.2.4.zip
    2.进入解压后文件夹执行命令: python setup.py install
    3.等待安装完成,无错误信息即可

安装Appium-Python-Client:
    1.解压Appium-Python-Client-0.25.tar.gz
    2.进入解压后文件夹执行命令: python setup.py install
    3.等待安装完成,无错误信息即可

05.Hello Appium

需求

使用Python打开android模拟器中的设置界面。

思路

python代码到手机的过程是需要先经过Appium-python库再经过Appium再到手机。也就是python代码 -> Appium-python库 -> Appium -> 手机。

方法

  from appium import webdriver

  import time

  # server 启动参数
  desired_caps = {}
  # 设备信息
  desired_caps['platformName'] = 'Android'
  desired_caps['platformVersion'] = '5.1'
  desired_caps['deviceName'] = '192.168.56.101:5555'
  # app信息
  desired_caps['appPackage'] = 'com.android.settings'
  desired_caps['appActivity'] = '.Settings'

  driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)

  # time.sleep(2)

  # driver.quit()

06.Appium 基础API

App基础操作API

前置代码

  # server 启动参数

  desired_caps = {}
  desired_caps['platformName'] = 'Android' 
  desired_caps['platformVersion'] = '5.1'
  desired_caps['deviceName'] = '192.168.56.101:5555'
  desired_caps['appPackage'] = 'com.android.settings'
  desired_caps['appActivity'] = '.Settings'
  desired_caps['unicodeKeyboard'] = True
  desired_caps['resetKeyboard'] = True

  # 声明driver对象
  driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub', desired_caps)



脚本内启动其他app

    driver.start_activity(appPackage,appActivity)
    参数:
    	appPackage:包名
    	appActivity:启动名
    示例:
    	driver.start_activity('com.android.mms', '.ui.ConversationList')


关闭app

	driver.close_app()  # 关闭当前操作的app,不会关闭驱动对象


关闭驱动对象

	driver.quit()   # 关闭驱动对象,同时关闭所有关联的app


安装APK到手机

	driver.install_app(app_path) 
	参数:
		app_path:脚本机器中APK文件路径
	示例:
		driver.install_app("/Users/Yoson/Downloads/anzhishichang_6450.apk")


手机中移除APP

	driver.remove_app(app_id) 
	参数:
		app_id:需要卸载的app包名
	示例:
		driver.remove_app('cn.goapk.market')


判断APP是否已安装

	driver.is_app_installed(bundle_id) 
	参数:
		bundle_id: 可以传入app包名,返回结果为True(已安装) / False(未安装)
	示例:
	print(driver.is_app_installed('cn.goapk.market'))


发送文件到手机

	import base64
	data = str(base64.b64encode(data.encode('utf-8')),'utf-8')
	driver.push_file(path,data)
	参数:
		path:手机设备上的路径(例如:/sdcard/a.txt)
		data:文件内数据,要求base64编码
		Python3.x中字符都为unicode编码,而b64encode函数的参数为byte类型,需要先转码;生成的数据为byte类型,需要将byte转换回去。
	示例:
		import base64
		data = str(base64.b64encode('test 123'.encode('utf-8')), 'utf-8')
		driver.push_file('/sdcard/test.txt', data)


从手机中拉取文件

	import base64
	data = driver.pull_file(path) # 返回数据为base64编码
	print(str(base64.b64decode(data),'utf-8')) # base64解码
	参数:
		path: 手机设备上的路径
	示例:
		import base64
		data = driver.pull_file('/sdcard/test.txt') # 返回数据为base64编码
		print(str(base64.b64decode(data), 'utf-8')) # base64解码


获取当前屏幕内元素结构

	driver.page_source  
	作用:
		返回当前页面的文档结构,判断特定的元素是否存在
	示例:
		print(driver.page_source)



你可能感兴趣的:(App自动化)