1、获取 Android app的Activity

打开终端cmd,先cd进入到刚才下载的“新浪.apk”目录下,然后使用aapt dump badging xxx.apk命令获取包内信息。注意,启动类名称一个字母都不能错。

 aapt dump badging 新浪.apk cat>d:/log.txt     这样可以将信息指定到某一文件下然后 查看 

  罪过了,后面发现正常是没有appt.exe 这个应用程序的。可以下载一个放到tools文件下,因为已经配置了环境变量,所以 可以直接使用。

可以从下面拷贝一个到tools下即可。

2、启动微博

#-*-coding:utf-8-*-
#Time:2017/7/20 18:06
#Author:YangYangJun
import time
from appium import webdriver
desired_caps = {}
desired_caps['platformName'] = 'Android'
desired_caps['platformVersion'] = '6.0'
desired_caps['deviceName'] = 'N79SIV5PVCSODAQC'
desired_caps['appPackage'] = 'com.sina.weibo'
desired_caps['appActivity'] = 'com.sina.weibo.SplashActivity'
driver = webdriver.Remote('http://localhost:4723/wd/hub', desired_caps)
driver.implicitly_wait(5)
time.sleep(3)
driver.quit()

3、元素定位

 3.1、appium的webdriver提供了11种元素定位的方法,在selenium的基础上扩展了三个,可以在pycharm里面输入driver.find_element_by然后会自动匹配出来 
 
 

 多的三个:
      driver.find_element_by_accessibility_id()
      driver.find_element_by_android_uiautomator()
      driver.find_element_by_ios_uiautomation()
      (第三个是ios的专用的)

3.2、下面一一举例进行 介绍

3.2.1、元素定位本篇主要介绍如何使用uiautomatorviewer,通过定位到页面上的元素,然后进行相应的点击等操作.

uiautomatorviewer是android-sdk自带的一个元素定位工具,非常简单好用,使用uiautomatorviewer,你可以检查一个应用的UI来查看应用的布局和组件以及相关的属性。

启动uiautomatorviewer.bat

打开目录D:\SProgram\Sdk\tools

双击启动,启动之后出现如下界面

 

如果不喜欢双击启动的话,也可以在cmd里面通过指令启动

先cd到tools目录下,然后输入uiautomatorviewer.bat回车后启动服务

3.2.1、find_element_by_accessibility_id

driver.find_element_by_accessibility_id(u"我的").click()

 

 3.2.2、通过id定位元素
resrouce-id属性是id:
driver.find_element_by_id('username') 

3.2.3、通过name定位元素
text属性是name

driver.find_element_by_name('password')

 

 4、结合公司刚开发出来的app,进行项目实训
#-*-coding:utf-8-*-
#Time:2017/7/21 16:32
#Author:YangYangJun import time
import unittest from appium import webdriver import sys
reload(sys)
sys.setdefaultencoding('utf8') class Login(unittest.TestCase): def setUp(self):
self.desired_caps = {} self.desired_caps['platformName'] = 'Android'
self.desired_caps['platformVersion'] = '6.0'
self.desired_caps['deviceName'] = 'N79SIV5PVCSODAQC'
self.desired_caps['appPackage'] = 'com.xxxx.mrg'
self.desired_caps['appActivity'] = 'com.uzmap.pkg.EntranceActivity'
#隐藏键盘
self.desired_caps['unicodeKeyboard'] = True
self.desired_caps['resetKeyboard'] = True self.driver = webdriver.Remote('http://localhost:4723/wd/hub', self.desired_caps)
#self.driver.implicitly_wait(15) #测试异常登录-用户不存在 def test_aNoUserLogin(self): driver = self.driver
time.sleep(5)
driver.find_element_by_accessibility_id(u"我的").click() time.sleep(5) driver.find_element_by_accessibility_id(u"登录/注册").click()
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').send_keys('xzbuyer1')
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').send_keys('') time.sleep(2) driver.find_element_by_accessibility_id(u"登录").click()
time.sleep(18) get_alertMessage = driver.find_elements_by_android_uiautomator('new Uiselector().resourceId("android:id/message")').get_attribute('name')
time.sleep(2)
if get_alertMessage == u'用户不存在':
print u"用户不存在,用例执行成功!"
else:
print u"用例执行失败!" def test_bNoPassLogin(self): driver = self.driver
time.sleep(5)
driver.find_element_by_accessibility_id(u"我的").click() time.sleep(5) driver.find_element_by_accessibility_id(u"登录/注册").click()
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').send_keys('xzbuyer')
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').send_keys('') time.sleep(2) driver.find_element_by_accessibility_id(u"登录").click()
time.sleep(18) get_alertMessage = driver.find_elements_by_android_uiautomator('new Uiselector().resourceId("android:id/message")').get_attribute('name')
time.sleep(2)
print get_alertMessage[0:5] # if get_alertMessage == u'用户不存在':
# print u"用户不存在,用例执行成功!"
# else:
# print u"用例执行失败!"
# # 测试正常登录 def test_cLogin(self): driver = self.driver
time.sleep(5)
driver.find_element_by_accessibility_id(u"我的").click() time.sleep(5) driver.find_element_by_accessibility_id(u"登录/注册").click()
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("username")').send_keys('xzbuyer')
time.sleep(2) driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').clear() time.sleep(2)
driver.find_element_by_android_uiautomator('new UiSelector().resourceId("password")').send_keys('') time.sleep(2) driver.find_element_by_accessibility_id(u"登录").click()
time.sleep(2) # 判断是否登录成功 print driver.find_element_by_accessibility_id(u"西藏医药销售有限公司").get_attribute('name') nickName = driver.find_element_by_accessibility_id(u"西藏医药销售有限公司").get_attribute('name')
temp = nickName[0:2]
print temp
if nickName == u'西藏医药销售有限公司':
print '登录成功!' else:
print '登录失败!' def tearDown(self):
self.driver.close_app()
self.driver.quit() if __name__ == "__main__":
unittest.main()

Python Appium 开启Android测试之路的更多相关文章

  1. Python +appium 封装desired_caps模块

    使用python+appium做android的自动化测试时,首先需要启动appium服务,然后连接上手机,配置如下: desired_caps = {"platformName" ...

  2. Android ROM开发(三)——精简官方ROM并且内置ROOT权限,开启Romer之路

    Android ROM开发(三)--精简官方ROM并且内置ROOT权限,开启Romer之路 相信ROM的相关信息大家通过前几篇的学习都是有所了解了,这里就不在一一提示了,这里我们下载一个官方包,我们还 ...

  3. Python+Appium自动化测试(15)-使用Android模拟器(详细)

    做APP的UI自动化测试时,我们往往会使用真机跑自动化测试脚本,因为这样才是最真实的使用场景.但前期调试脚本的话,可以先使用模拟器,这样相对更加方便. 不推荐使用Android SDK里自带模拟器,太 ...

  4. Windows下部署Appium教程(Android App自动化测试框架搭建)

    摘要: 1,appium是开源的移动端自动化测试框架: 2,appium可以测试原生的.混合的.以及移动端的web项目: 3,appium可以测试ios.android.firefox os: 4,a ...

  5. 如何搭建基于C#和 Appium 的 Android自动测试环境

    本文由葡萄城技术团队于博客园原创并首发 转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 如果想做手机端的自动化测试,Appium是首选的测试框架,因为网上使 ...

  6. Python appium搭建app自动化测试环境

    appium做app自动化测试,环境搭建是比较麻烦的. 也是很多初学者在学习app自动化之时,花很多时间都难跨越的坎. 但没有成功的环境,就没有办法继续后续的使用. 在app自动化测试当中,我们主要是 ...

  7. python appium笔记(二):元素定位

    #这里的示例是用android来说明的,xpath应该是通用的,resource-id不太清楚,没配过IOS的环境 #环境配置和一些参数的意思不清楚可以看我上一篇python appium笔记(一) ...

  8. Python+Appium环境搭建

    1.python环境搭建,这里就不做过多介绍 2.安装 node.js 2.1.官网下载node.js:https://nodejs.org/en/download/ 2.2.获取到安装文件后,直接双 ...

  9. Appium 在 Android UI 测试中的应用

    原文地址:https://blog.coding.net/blog/Appium-Android-UI Android 测试工具与 Appium 简介 Appium 是一个 C/S 架构的,支持 An ...

随机推荐

  1. MySQL乐观锁和悲观锁的概念和原理

    乐观锁:在取数据时不加锁,等处理完逻辑的时候,查看是否与上一次相同,若相同则更新,若不同则拒绝. 悲观锁:在取数据时就加上锁,只有更新完数据之后,别的用户才可以进行读. (个人总结)

  2. TCP/IP编程——基于TCP的半关闭

    在TCP服务端和客户端建立连接之后服务端和客户端会分别有两个独立的输入流和输出流,而且相互对应.服务端的输出流对应于客户端的输入流,服务端的输入流对应于客户端的输出流.这是在建立连接之后的状态. 当我 ...

  3. [WCF REST] 一个简单的REST服务实例

    Get:http://www.cnblogs.com/artech/archive/2012/02/04/wcf-rest-sample.html [01] 一个简单的REST服务实例 [02] We ...

  4. Java 之 FileReader FileInputStream InputStreamReader BufferedReader 作用与区别

    ava.io下面有两个抽象类:InputStream和ReaderInputStream是表示字节输入流的所有类的超类Reader是用于读取字符流的抽象类InputStream提供的是字节流的读取,而 ...

  5. 20145221高其_Final

    20145221高其_Final 免考题目 密码保密与信息安全大赛--网络攻防 免考内容 CTF简介 CTF(Capture The Flag)中文一般译作夺旗赛,在网络安全领域中指的是网络安全技术人 ...

  6. poj 1275 Cashier Employment - 差分约束 - 二分答案

    A supermarket in Tehran is open 24 hours a day every day and needs a number of cashiers to fit its n ...

  7. Codeforces 841D Leha and another game about graph - 差分

    Leha plays a computer game, where is on each level is given a connected graph with n vertices and m  ...

  8. upc组队赛1 闪闪发光 【优先队列】

    闪闪发光 题目描述 一所位于云南昆明的中医药本科院校--云南中医学院. 因为报考某专业的人数骤减,正面临着停招的危机. 其中有九名少女想到一条妙计--成为偶像, 只要她们成为偶像,学校的名气便会增加, ...

  9. newcoder F石头剪刀布(DFS + 思维)题解

    题意:wzms 今年举办了一场剪刀石头布大赛,bleaves 被选为负责人. 比赛共有 2n 个人参加, 分为 n 轮, 在每轮中,第 1 位选手和第 2 位选手对战,胜者作为新的第 1 位选手, 第 ...

  10. (转载)Navicat Premium 12.1.16.0安装与激活

    声明:本文所提供的所有软件均来自于互联网,仅供个人研究和学习使用,请勿用于商业用途,下载后请于24小时内删除,请支持正版! 本文介绍Navicat Premium 12的安装.激活与基本使用.已于20 ...