selenium + python自动化测试unittest框架学习(二)

1.unittest单元测试框架文件结构

unittest是python单元测试框架之一,unittest测试框架的主要文件结构:

File

  >report

  >all_case.py

>test_case

      >__init__.py

      >test_case1.....

      >public

          >__init__.py

          >login.py

          >loginout.py

test_case文件夹主要存放测试用例,且测试用例命名以test_开头

public文件夹是test_case文件夹的子文件夹,主要存放公共模块,例如登录退出模块

report文件夹主要存放在测试用例执行完成后生成的测试报告

all_case脚本文件是主要的执行脚本,该脚本集合所有测试用例,执行所有的测试用例

2.unittest框架的最简单结构

selenium + python自动化测试unittest框架学习(一)selenium原理及应用这篇中说道可以将录制的浏览器行为导出成指定的编程语言,如果我们先是通过Selenium ide录制后导出的python脚本,那么可以发现每一个脚本的都会有这样一个简单的结构,先忽略那些判断元素是否存在的函数。其基本的结构如下所示:

setUp()

tearDown()

test_case1()

unittest.main()

setUp:初始化函数,每一个测试用例执行之前都会执行一遍

tearDown:测试用例执行完成后的浏览器退出等清理操作

test_case1():编写的测试用例脚本

unittest.main():自动执行方法名为test_开头的方法

3.unittest测试框架优化结构2

单单一个脚本不可能包含所有的测试用例,所以不同的测试用例可以写成不同的测试用例脚本放置在test_case文件夹中,那么执行测试用例的时候我们需要一个测试套件TestSuite来加载所有的测试用例脚本,添加测试用例的方法addTest(),并且使用TextTestRunner运行测试脚本。

  • 先构造测试集

    • 实例化测试套件

      • suite=unittest.TestSuite()
    • 将测试用例加载到测试套件中。
      • suite.addTest(Test(‘test_case2‘))
      • suite.addTest(Test(‘test_case1‘))
  • 执行测试用例
    • 实例化TextTestRunner类

      • runner=unittest.TextTestRunner()
    • 使用run()方法运行测试套件(即运行测试套件中的所有用例)
      • runner.run(suite)

该结构的缺点是每一个测试用例的增加都要添加一条addTest()方法,这就增加自动化脚本上的繁琐,所以我们可以想办法自动加载符合条件的测试用例

4.unittest测试框架优化结构3

该结构简化了一些步骤,即不用先创建测试套件,然后通过添加测试用例的方式,将测试用例逐条加载,TestLoader下的discover方法可以递归查询其指定路径下的子目录下符合条件的测试用例加载。

test_dir = ‘./‘

discover = unittest.defaultTestLoader.discover(test_dir, pattern=‘test_*.py‘)

执行测试用例

实例化TextTestRunner类

runner=unittest.TextTestRunner()

使用run()方法运行测试套件(即运行测试套件中的所有用例)

runner.run(discover)

5.unittest执行文件all_case.py代码结构如下:

# coding=utf-8
import unittest
import HTMLTestRunner
import time
from test_case.public import login

def createsuit():
    #创建测试用例集
    testunit = unittest.TestSuite()
    #判断是否为测试用例,自动加载测试用例到测试套件中
    cslist = "D:\\fcj\\study\\seleniumtest\\test_case"
    #discover方法定义
    discover = unittest.defaultTestLoader.discover(
        #测试用例放置的文件夹名
        cslist,
        pattern = ‘test_*.py‘,
        top_level_dir = None
        )

    #discover方法筛选出来的用例,循环添加到测试套件中
    for test_suite in discover:
        testunit.addTests(test_suite)
        print(testunit)
    return testunit
alltestnames = createsuit()

if __name__ == "__main__":
    now = time.strftime(‘%Y-%m-%d-%H_%M_%S‘,time.localtime(time.time()))
    #定义报告存放路径
    filename = ‘D:\\fcj\\study\\seleniumtest\\report\\‘+now+‘result.html‘
    fp = open(filename,‘wb‘)
    #定义测试报告
    runner = HTMLTestRunner.HTMLTestRunner(
        stream = fp,
        title = u‘A项目后台测试报告‘,
        description = u‘用例执行情况:‘
        )
    #执行测试
    runner.run(alltestnames)
    fp.close()
时间: 2024-12-16 11:10:34

selenium + python自动化测试unittest框架学习(二)的相关文章

selenium + python自动化测试unittest框架学习(五)webdriver的二次封装

因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<selenium +  python自动化测试>一书. 在与测试用例文件夹同一目录下新建一个文件夹package,用来放置封装方法的模块文件 我们将webdriver二次封装的文件命名为location.py from selenium import webdriver from test_case.pub

selenium + python自动化测试unittest框架学习(一)selenium原理及应用

unittest框架的学习得益于虫师的<selenium+python自动化实践>这一书,该书讲得很详细,大家可以去看下,我也只学到一点点用于工作中,闲暇时记录下自己所学才能更加印象深刻.unittest框架学习需要掌握以下知识点: (1)Selenium原理及工具使用 (2)webdriver元素定位,id,name,class name,css seletor,xpath (3)python语言基础,模块,参数化,语言,装饰器 (4)unittest框架认识及学习:模块化,断言,参数化,数

selenium + python自动化测试unittest框架学习(三)webdriver元素操作(二)

上一篇是元素的定位,那么定位元素的目的就是对元素进行操作,例如写入文本,点击按钮,拖动等等的操作 (1)简单元素操作 简单元素操作 find_element_by_id("kw").clear() #文本框清空 find_element_by_id("kw").send_keys("selenium") #文本框输入 find_element_by_id("button").click() #点击按钮操作 (2)webElem

selenium + python自动化测试unittest框架学习(三)webdriver元素定位(一)

1.Webdriver原理 webdirver是一款web自动化操作工具,为浏览器提供统一的webdriver接口,由client也就是我们的测试脚本提交请求,remote server浏览器进行响应请求,相对于原来selenium1中的selenium rc更加的简便,对浏览器的操作更加灵活. 2.定位 (1)元素的定位: 元素的定位可以通过id,name,class name,tag name,link_text,partial_link_text,css selector,xpath等 语

selenium + python自动化测试unittest框架学习(四)python导入模块及包知识点

在写脚本的时候,发现导入某些模块,经常报错提示导入模块失败,这里来恶补下python导入模块的知识点. 1.模块导入时文件查找顺序 在脚本中,import xxx模块时的具体步骤: (1)新建一个module (2)将module插入到sys.module (3)查找module的路径,查找的顺序为先查找当前使用导入模块的文件同一级目录,之后是python的搜索模块的路径集sys.path,最后是python所添加的默认环境变量的路径Python path (4)module查找到之后装载mod

selenium + python自动化测试unittest框架学习(七)随机生成姓名

在自动化测试过程中经常要测试到添加用户的操作,每次都要输入中文,原本是找了十几个中文写成了列表,然后从列表中随机取出填入用户名文本框中,随着测试的增加,发现同名的人搜索出来一大堆,最后在网上找了个随机生成姓名的方法,在此记录下,学习来源:https://segmentfault.com/q/1010000006941249 姓氏和名字的列表: import random import string last_names = ['赵', '钱', '孙', '李', '周', '吴', '郑',

selenium + python自动化测试unittest框架学习(六)分页

接触的项目分页的形式是以下形式: 想要获取总页数后,遍历执行翻页的功能,但由于分页是以javascript方法实现的,每次点击确定按钮后,页面就回刷新,webelement元素过期无法遍历下一个进行翻页操作,报StaleElementReferenceException的错误,所以对于这个操作折腾了半天还是放弃了. 对于分页的操作实现了以下功能: (1)获取总页数并输出 (2)遍历操作'上一页','下一页'按钮,实现翻页功能 (3)在输入页数的文本框中输入页数,点击确定,实现翻页功能 def p

selenium + python自动化测试unittest框架学习(三)webdriver对页面其他控件操作(三)

1.对话框,下拉框 (1)对话框的有两种,一种是iframe格式的,需要switch_to_iframe()进行定位,现在大部分的对话框是div格式的,这种格式的可以通过层级定位来定位元素,先定位对话框的div,然后再对对话框的元素进行定位. (2)另外的弹出消息提示框有三种类型:alert,comfirm,prompt,三种类型的区别为; alert消息提示框仅提供"确定"按钮,用于警告等提示,comfirm提示框提供"是"和"否"的选择,pr

Selenium终极自动化测试环境搭建(二)Selenium+Eclipse+Python

Selenium终极自动化测试环境搭建(二)Selenium+Eclipse+Python 前面举例了Selenium+Eclipse+Junit+TestNG自动化测试环境的搭建,在前一篇的基础上,下面再举例Selenium+Eclipse+Python测试环境搭建. 第一步:安装Python 根据下面的地址,直接一键安装,全部默认方式. 下载地址:http://www.python.org/ftp/python/2.7.5/python-2.7.5.msi 安装到C:\Python27,设置