10分彩交流群_Appium+python自动化(四十一)

  • 时间:
  • 浏览:3
  • 来源:云南生活网_云南人的网上生活家园

1.简介

  今天大伙儿紧接着上一篇继续分享Appium自动化测试框架综合实践 - 代码实现。到今天为止,大功即将告成;框架所需用的代码实现都基本完成。

2.data数据封装

2.1使用背景

在实际项目过程中,大伙儿的数据可是 是存储在原先数据文件中,如txt,excel、csv文件类型。大伙儿还需用封装一点方法来读取文件中的数据来实现数据驱动。

2.2案例

将测试账号存储在account.csv文件,内容如下:

account.csv

hg2018

hg2018

hg2019

zxw2019

666

222

参考代码

2.3enumerate()简介

enumerate()是python的内置函数

  • enumerate在字典上是枚举、列举的意思
  • 对于原先可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成原先索引序列,利用它还需用同去获得索引和值
  • enumerate多用于在for循环中得到计数。

2.4enumerate()使用

可是 对原先列表,既要遍历索引又要遍历元素时,首先还需用原先 写:

参考代码
list = ["", "", "原先", "测试","数据"]

for i in range(len(list)):

    print(i,list[i])

上述方法一点累赘,利用enumerate()会更加直接和优美:

参考代码
list1 = ["", "", "原先", "测试","数据"]

for index, item in enumerate(list1):

        print(index,item)

3.数据读取方法封装

  数据读取方法也属于公共方法,这里大伙儿首先实现一下,可是 将其封装下 中间即可。

3.1数据读取方法实现的参考代码

import csv


     def get_csv_data(csv_file,line):

        with open(csv_file, 'r', encoding='utf-8-sig') as file:

            reader=csv.reader(file)

            for index, row in enumerate(reader,1):

                if index == line:

                    return row

 

    csv_file='../data/account.csv'

    data=get_csv_data(csv_file,3)

    print(data)

3.2封装

将其封装下 公共方法中,在一点地方用到的前一天,直接导入调用即可。

4.utf-8与utf-8-sig本身编码格式的区别

UTF-8以字节为编码单元,它的字节顺序在所有系统中详细都是一样的,没人 字节序的什么的问题,也可是 它实际上不需要需用BOM(“ByteOrder Mark”)。可是 UTF-8 with BOM即utf-8-sig需用提供BOM。

5.config文件配置

各种配置文件都装下 去一点目录下。

5.1日志文件配置 

主可是 一点日志信息的配置。

log.config

 参考代码
[loggers]
keys=root,infoLogger

[logger_root]
level=DEBUG
handlers=consoleHandler,fileHandler

[logger_infoLogger]
handlers=consoleHandler,fileHandler
qualname=infoLogger
propagate=0

[handlers]
keys=consoleHandler,fileHandler

[handler_consoleHandler]
class=StreamHandler
level=INFO
formatter=form02
args=(sys.stdout,)

[handler_fileHandler]
class=FileHandler
level=INFO
formatter=form01
args=('../logs/runlog.log', 'a')

[formatters]
keys=form01,form02

[formatter_form01]
format=%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s

[formatter_form02]
format=%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s

6.测试用例封装

这里宏哥举例给小伙伴们演示:封装注册和登录原先测试用例。

6.1测试用例执行之后开始英语 英语 英语 之后开始英语 英语 英语 操作封装

测试用例执行之后开始英语 英语 英语 和之后开始英语 英语 英语 的封装,一点模块用到直接导入,调用即可。

myunit.py

参考代码
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般装下



去第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-20
@author: 北京-宏哥   QQ交流群:707699217
Project:Appium自动化测试框架综合实践 - 代码实现
'''
# 3.导入模块
import unittest
from kyb_testProject.common.desired_caps import appium_desired
import logging
from time import sleep

class StartEnd(unittest.TestCase):
    def setUp(self):
        logging.info('=====setUp====')
        self.driver=appium_desired()

    def tearDown(self):
        logging.info('====tearDown====')
        sleep(5)
        self.driver.close_app()

6.2注册用例

之后开始英语 英语 英语 注册用例代码逻辑的实现。

test_register.py

参考代码
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般装下



去第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-20
@author: 北京-宏哥   QQ交流群:707699217
Project:Appium自动化测试框架综合实践 - 代码实现
'''
# 3.导入模块
from kyb_testProject.common.myunit import StartEnd
from kyb_testProject.businessView.registerView import RegisterView
import logging,random,unittest

class RegisterTest(StartEnd):
    def test_user_register(self):
        logging.info('======test_user_register======')
        r=RegisterView(self.driver)

        username = 'bjhg2019' + 'fly' + str(random.randint(50000, 9000))
        password = 'bjhg2020' + str(random.randint(50000, 9000))
        email = 'bjhg' + str(random.randint(50000, 9000)) + '@163.com'

        self.assertTrue(r.register_action(username,password,email))

if __name__ == '__main__':
    unittest.main()

6.3登录用例

之后开始英语 英语 英语 登录用例代码逻辑的实现。

test_login.py

参考代码
# coding=utf-8
# 1.先设置编码,utf-8可支持中英文,如上,一般装下



去第一行

# 2.注释:包括记录创建时间,创建人,项目名称。
'''
Created on 2019-11-13
@author: 北京-宏哥   QQ交流群:707699217
Project:Appium自动化测试框架综合实践 - 代码实现
'''
# 3.导入模块
from kyb_testProject.common.myunit import StartEnd
from kyb_testProject.businessView.loginView import LoginView
import unittest
import logging

class TestLogin(StartEnd):
    csv_file='../data/account.csv'

    @unittest.skip('test_login_zxw2018')
    def test_login_zxw2018(self):
        logging.info('======test_login_zxw2018=====')
        l=LoginView(self.driver)
        data=l.get_csv_data(self.csv_file,2)

        l.login_action(data[0],data[1])
        self.assertTrue(l.check_loginStatus())

    # @unittest.skip('skip test_login_zxw2017')
    def test_login_zxw2017(self):
        logging.info('======test_login_zxw2017=====')
        l=LoginView(self.driver)
        data = l.get_csv_data(self.csv_file, 1)

        l.login_action(data[0], data[1])
        self.assertTrue(l.check_loginStatus())

    @unittest.skip('test_login_error')
    def test_login_error(self):
        logging.info('======test_login_error=====')
        l = LoginView(self.driver)
        data = l.get_csv_data(self.csv_file, 3)

        l.login_action(data[0], data[1])
        self.assertTrue(l.check_loginStatus(),msg='login fail!')

if __name__ == '__main__':
    unittest.main()

7.小结

到此,Appium自动化测试框架就差下一篇就详细完成了,聪明的你都懂什么之后???嘿嘿!慢慢地来吧。

下节预告

下一篇,讲解执行测试用例,生成测试报告,以及自动化平台,请关注宏哥,敬请期待!!!

猜你喜欢

10分快3官方邀请码_天津年内将为50名困难肢体残疾人员免费安假肢

 天津北方网讯:在5月17日全国助残日到来之际,110分快3官方邀请码0分快3官方邀请码市慈善学好和市残疾人福利基金会一齐启动2015“爱心助飞梦想”假肢助残行动。昨天,记者获

2020-04-06

幸运快3规律_ 比尾气更污染的是香味剂

带香味的日常用品,比如洗发水、香水和洁净用品等,对空气污染的影响与汽车排放量一样大幸运快3规律。大伙儿把石油当做幸运快3规律燃料的使用量是把它作为化学品原料的15倍,通过香味产

2020-04-06

2分飞艇官方邀请码_2019Q1 K12在线教育报告:市场规模环比增6.7%

K12教育阶段覆盖时间长,且富含了小升初、初升高等重要阶段,成为目前我国最大的细分教育市场。随着互联网的深度发展渗透,K122分飞艇官方邀请码在线教育渗透率不断上升,并将从一二

2020-04-06

快三充值_2019 年 12月 12 日 随笔档案

2019年12月12日守护进程员在创业前可不都要尝试的试炼任务摘要:在互联网时代,不少干IT的人白手起家,在短短的几年里通过努力干出了一番事业,有房有车有公司,在人前也很光鲜。

2020-04-06

秒速飞艇官方app_禽流感来袭 一只鸡的独白

▲最近秒速飞艇官方app禽流感闹得厉害,批发市场秒速飞艇官方app交易惨淡,亲戚亲戚大伙不到呆在笼子里,心里闷得慌……哎!交易骤减,老板每日花高成本保亲戚亲戚大伙的口粮,但他的

2020-04-06