在前段时间,分享了几篇关于appium基础的博文,再加上期间也有讲到unittest测试框架,所以今天就来一个专题,在appium+python实现的线性代码基础上,引入unittest框架,使代码更简洁。

之前的博客,可以见以下链接快速阅读:

基于Python的Appium环境搭建合集

Genymotion模拟器的安装及脚本制作

Appium Python API 中文版

Appium-Server与Appium-Desktop的区别

单元测试框架Uinttest一文详解

在以上博文中,代码示例,很多只是个线性脚本,没有太多的实用之处,用来写个demo还是可以,但实际运用到产品中,就不行了。脚本还是得引用框架,这样看起来,代码就不会那么乱,更有逻辑性,便于维护。

好了,进入正题,对unittest以及appium还不熟悉的,可以先阅读如上的博文了解,此篇文中,就不赘述了。

unittest代码优化一

优化逻辑:

①将启用服务字段放到初始化当中

②将输入账号、输入密码、获取当前activity的操作封装成一个个函数

③在用例中去调用需要执行的函数

示例代码如下:

import selenium
import time
from appium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
import unittest '''
@author: wenyihuqingjiu
@project: appiumcode
@file: test_login.py
@time: 2019-10-20 22:11
@desc:
''' print('selenium version = ', selenium.__version__) def input_account(self):
account = self.driver.find_element_by_id('id/rel_content')
account.find_element_by_id('id/edit_acount')
print("定位输入框")
self.driver.press_keycode(61)
print("换行操作")
account.send_keys('')
print("账号输入完毕")
time.sleep(2) def current(self):
ac = self.driver.current_activity
print('当前activity:' + ac) def input_password(self):
# genymotion只需要一次换行
self.driver.press_keycode(61)
print("换行操作")
password = self.driver.find_element_by_id('id/rel_content')
password.find_element_by_id('id/edit_pass')
print("定位输入框")
password.send_keys('')
print("输入密码")
self.driver.find_element_by_xpath('//android.widget.TextView[@text="登 录"]').click()
print("点击登录")
time.sleep(5)
print('登录成功') class case_01(unittest.TestCase):
@classmethod
def setUpClass(cls): desired_caps = { 'platformName': 'Android',
'platformVersion': '4.4.4',
'deviceName': 'S5',
'appPackage': '',
# 非首次登录的activity
'appActivity': '.ui.login.view.LoginActivity',
'udid': '192.168.66.101:5555',
'noReset': 'true', }
cls.driver = webdriver.Remote('http://192.168.1.101:4723/wd/hub', desired_caps)
print("服务启动成功") @classmethod
def tearDownClass(cls):
cls.driver.quit() def add_img(self):
self.imgs.append(self.driver.get_screenshot_as_base64())
return True def setUp(self):
# 在是python3.x 中,如果在这里初始化driver ,因为3.x版本 unittestbasic1 运行机制不同,会导致用力失败时截图失败
self.driver.implicitly_wait(30)
self.imgs = []
self.addCleanup(self.cleanup) def cleanup(self):
pass def test_login01(self):
input_account(self)
current(self)
input_password(self) if __name__ == "__main__":
suites = unittest.TestSuite()
suites.addTest(case_01("test_login01"))
runner = unittest.TextTestRunner(verbosity=2)
runner.run(suites)

unittest代码优化二

优化逻辑:

①将启用服务字段放到初始化当中

②将输入账号、输入密码、获取当前activity的操作封装成一个个函数,并将数据参数做成形参

③在用例中去调用需要执行的函数并入参

示例代码如下:

import selenium
import time
from appium import webdriver
from selenium.webdriver.support.ui import WebDriverWait
import unittest '''
@author: wenyihuqingjiu
@project: appiumcode
@file: test_login.py
@time: 2019-10-20 22:11
@desc:
''' print('selenium version = ', selenium.__version__) def input_account(self, username):
account = self.driver.find_element_by_id('id/rel_content')
account.find_element_by_id('id/edit_acount')
print("定位输入框")
self.driver.press_keycode(61)
print("换行操作")
account.send_keys(username)
print("账号输入完毕")
time.sleep(2) def current(self):
ac = self.driver.current_activity
print('当前activity:' + ac) def input_password(self, send_password):
# genymotion只需要一次换行
self.driver.press_keycode(61)
print("换行操作")
password = self.driver.find_element_by_id('id/rel_content')
password.find_element_by_id('id/edit_pass')
print("定位输入框")
password.send_keys(send_password)
print("输入密码")
self.driver.find_element_by_xpath('//android.widget.TextView[@text="登 录"]').click()
print("点击登录")
time.sleep(5)
print('登录成功') class case_01(unittest.TestCase):
@classmethod
def setUpClass(cls): desired_caps = { 'platformName': 'Android',
'platformVersion': '4.4.4',
'deviceName': 'S5',
'appPackage': '',
# 非首次登录的activity
'appActivity': '.ui.login.view.LoginActivity',
'udid': '192.168.66.101:5555',
'noReset': 'true', }
cls.driver = webdriver.Remote('http://192.168.1.101:4723/wd/hub', desired_caps)
print("服务启动成功") @classmethod
def tearDownClass(cls):
cls.driver.quit() def add_img(self):
self.imgs.append(self.driver.get_screenshot_as_base64())
return True def setUp(self):
# 在是python3.x 中,如果在这里初始化driver ,因为3.x版本 unittestbasic1 运行机制不同,会导致用力失败时截图失败
self.driver.implicitly_wait(30)
self.imgs = []
self.addCleanup(self.cleanup) def cleanup(self):
pass def test_login01(self):
# 正常登录
input_account(self, "")
current(self)
input_password(self, "") def test_login02(self):
# 异常登录
input_account(self, "")
current(self)
input_password(self, "") if __name__ == "__main__":
suites = unittest.TestSuite()
suites.addTest(case_01("test_login01"))
suites.addTest(case_01("test_login02"))
runner = unittest.TextTestRunner(verbosity=2)
runner.run(suites)

通过上述代码可看出,使用更方便了,可以满足正向/反向的用例设计了,是不是很简单。

代码可扩展性还有很多,在unittest基础上,再引入PO模式,那代码的健壮性就更高了,以后有时间再出类似博文。

基于appium实现的线性代码引用unittest单元测试框架的更多相关文章

  1. Selenium基于Python web自动化基础二 -- 免登录、等待及unittest单元测试框架

    一.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...

  2. Selenium+Python ---- 免登录、等待、unittest单元测试框架、PO模型

    1.免登录在进行测试的过程中难免会遇到登录的情况,给测试工作添加了工作量,本文仅提供一些思路供参考解决方式:手动请求中添加cookies.火狐的profile文件记录信息实现.人工介入.万能验证码.去 ...

  3. Selenium(十八):unittest单元测试框架(四) HTML测试报告

    1. HTML测试报告 对测试人员来而言,测试的产出很难衡量.换句话说,测试人员的价值比较难以量化和评估,相信这一点对软件测试人员来说深有体会.我们花费了很多时间与精力所做的自动化测试也是如此.所以, ...

  4. unittest单元测试框架前言

    一.在我们没有学习过python语言的时候领导让我们做接口测试 我们都使用工具来做测试,一般常用的如jemeter,postman这些个工具,我来推荐使用postman 这个工具来进行接口测试,有的小 ...

  5. Selenium实战(四)——unittest单元测试框架1

    Python中的单元测试框架包含:doctest.unittest.pyttest.nose等,使用unittest单元测试框架不需要自行定义断言失败的提示,并且当一个测试函数执行失败后,后面的测试函 ...

  6. unittest单元测试框架

    unittest单元测试框架 概述: 单元测试框架主要用来完成以下三件事: 提供用例组织与执行:当测试用例只有几条时,可以不必考虑用例的组织,但是当用例达到成百上千条时,大量的用例堆砌在一起,就产生了 ...

  7. unittest单元测试框架简单说明

    unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果.今天笔者 ...

  8. Python+selenium之简单介绍unittest单元测试框架

    Python+selenium之简单介绍unittest单元测试框架 一.unittest简单介绍 unittest支持测试自动化,共享测试用例中的初始化和关闭退出代码,在unittest中最小单元是 ...

  9. unittest单元测试框架总结(转载)

    转载:https://www.cnblogs.com/yufeihlf/p/5707929.html unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的开发与执行,该 ...

随机推荐

  1. eclipse配置workspace背景颜色

  2. 2.html5新布局元素

    1.html5的优点: ①对人友好,更加语义化,更直观,增加了代码的可读性. ②对计算机友好,浏览器更容易解析,搜索引擎更容易抓取文档内容. ③代码更加的简洁. 2.新增的布局标签: Article: ...

  3. 难题解决:Mycat数据库中间件+Mybatis批量插入数据并返回行记录的所有主键ID

     一.mybatis的版本必须为3.3.1及其以上 项目所依赖的mybatis的版本必须为3.3.1及其以上,低版本的不行,保证hap项目的依赖的mybatis的jar的版本必需为需要的版本: 二.在 ...

  4. Kubernetes 系列(六):Kubernetes部署Prometheus监控

    1.创建命名空间 新建一个yaml文件命名为monitor-namespace.yaml,写入如下内容: apiVersion: v1 kind: Namespace metadata: name: ...

  5. Docker系列(二):通过Docker安装使用 Kubernetes (K8s)

    Docker社区版从17.12版本开始已经提供了对Kubernetes的支持.但是由于其安装过程依赖的镜像服务在国内访问很不稳定,很多朋友都无法配置成功.我们提供了一个简单的工具帮助大家开启Docke ...

  6. WordPress新用户注册时提示“您的密码重设链接无效”

    在使用Wordpress密码找回功能及新用户注册邮件中的重置密码链接时,Wordpress提示“您的密码重设链接无效,请在下方请求新链接.”.“该key似乎无效”.“invalid key”. 这个其 ...

  7. [Scrapy] Some things about Scrapy

    1. Pause and resume a crawl Scrapy supports this functionality out of the box by providing > the ...

  8. 04-Django模型(1)

    ---恢复内容开始--- 模型 MTV图解 ORM ORM全拼:Object-Relation-Mapping翻译就是对象关系映射.在MVC/MTV设计模式中的Model模块中都包括ORM.主要实现模 ...

  9. JavaSE----02.Java语言基础

    02.Java语言基础 1.关键字     Java关键字是电脑语言里事先定义的,有特别意义的标识符,有时又叫保留字,还有特别意义的变量.Java的关键字对Java的编译器有特殊的意义,他们用来表示一 ...

  10. A-08 拉格朗日对偶性

    目录 拉格朗日对偶性 一.原始问题 1.1 约束最优化问题 1.2 广义拉格朗日函数 1.3 约束条件的考虑 二.对偶问题 三.原始问题和对偶问题的关系 3.1 定理1 3.2 推论1 3.3 定理2 ...