#coding=utf-8

from selenium import webdriver

from time import sleep

import unittest#导入unittest库

import HTMLTestRunner

#创建一个类,并且该类继承unittest.case类

class Test_baidu(unittest.TestCase):

    #初始环境,每一个用例执行时都会先执行这里的代码

    def setUp(self):

        self.dr=webdriver.Chrome()#调用指定的浏览器并赋值给dr

        self.dr.maximize_window()

        self.dr.implicitly_wait(10)#智能等待作用和sleep一样

        self.dr.get('https://www.baidu.com')

        sleep(2)

    #测试用例---执行搜索新方硕--测试用例的脚本

    def test_case2(self):

        self.dr.find_element_by_id('kw').send_keys(u'新方硕')

        sleep(3)

    #测试用例--执行搜索新东方

    def test_case1(self):

        self.dr.find_element_by_id('kw').send_keys(u'新东方')

        sleep(3)

   #还原环境(结束)---用例执行后关闭浏览器(扫尾工作)

    def tearDown(self):

        self.dr.close()

#方案一

 if __name__=="__main__":

     unittest.main()

    #unittest.main()他可以将一个单元测试的模块变为可以执行的脚本,所谓main()的方法使用了

    # unittest中testloader类来搜索以test开头的测试用例,并自动执行

    # main()执行顺序是以ascii用来执行顺序0-9,A-Z,a-z

#方案二:用例的执行顺序,根据你添加的顺序进行执行

 if __name__=='__main__':

     suite=unittest.TestSuite()#构造一个容器用来存放我们的测试用例

     suite.addTest(Test_baidu('test_case2'))#添加类中的测试用例

     suite.addTest(Test_baidu('test_case1'))#添加类中的测试用例

     suite.addTests([Test_baidu('test_case2'),Test_baidu('test_case1')])

     run=unittest.TextTestRunner()

     run.run(suite)#调用对象中的run的方法执行测试套件:suite

#或者如下

 if __name__=='__main__':

     suite=unittest.TestSuite()

     suite.addTests([Test_baidu('test_case2'),Test_baidu('test_case1')])

     run=unittest.TextTestRunner()

     run.run(suite)

#还或者如下

 if __name__=='__main__':

     suite=unittest.TestSuite()

     testcates=[Test_baidu('test_case2'),Test_baidu('test_case1')]

     suite.addTests(testcases)

     run=unittest.TextTestRunner()

     run.run(suite)

unittest.TestSuite()执行用例问题如下:

步入正轨解决方案出炉,在右键点击run时,发现run后面为unittest.in filename,以前执行文件时都是Run fliename,也就是说整个文件都是按照unittest模式来执行的

看到了 两个执行的不一致,两个办法如下:

1,点击控制台Run来运行

2,点击 控制台的右上角见图

此时右键执行就会发现不在unittest模式下了哦

#方案三执行顺序与方案一一样

 if __name__=='__main__':

# 批量执行用例

     case_dir=r'D:\work_doc\pycharm\python_selenium'#当前路径在c:/python文件的xx的目录中有一个ll.py文件

     discover=unittest.defaultTestLoader.discover(case_dir,pattern='unittest_frame.py'

                                              ,top_level_dir=None)

     run=unittest.TextTestRunner()

     run.run(discover)

# 生成测试报告

 suit = unittest.TestSuite()

 suit.addTest(unittest.makeSuite(Test_baidu))

 file1 = open('d:\\test3.html','wb')

 runner = HTMLTestRunner.HTMLTestRunner(file1,title=u'用例报告',description=u'用例描述')

 runner.run(suit)

 file1.close()

unittest执行用例方法的更多相关文章

  1. Unittest组织用例的姿势

    本文我们将会讲解Python Unittest 里组织用例的5种姿势. 环境准备: python 3.0以上 python requests库 小编的环境: python 3.6.4 一.TestLo ...

  2. unittest---unittest多种加载用例方法

    在做自动化测试我们对执行用例很有要求,因为每条用例可能就和上一条数据有关系,那么我想要批量执行一些用例呢?这个怎么去操作呢?unittest自带的功能可以帮助到我们,我们可以通过不同的场景运用不同的执 ...

  3. python:unittest之discover()方法批量执行用例

    自动化测试过程中,自动化覆盖的功能点和对应测试用例之间的关系基本都是1 VS N,如果每次将测试用例一个个单独执行,不仅效率很低, 无法快速反馈测试结果,而且维护起来很麻烦.在python的单元测试框 ...

  4. Unittest加载执行用例的方法总结

    前言 说到测试框架,unittest是我最先接触的自动化测试框架之一了, 而且也是用的时间最长的, unittest框架有很多方法加载用例,让我们针对不同的项目,不同项目的大小及用例的多少自己选择加载 ...

  5. python+unittest 控制用例的执行顺序

    unittest的main()方法执行用例的顺序是按照测试类.测试方法的名字的ASCII顺序来执行测试方法.所以可能执行的顺序和你想要的顺序不一样,可能通过下面两种方法修改执行顺序 1. 通过Test ...

  6. python自动化-unittest批量执行用例(discover)

    前言 我们在写用例的时候,单个脚本的用例好执行,那么多个脚本的时候,如何批量执行呢?这时候就需要用到unittet里面的discover方法来加载用例了. 加载用例后,用unittest里面的Text ...

  7. unittest中diascover批量执行用例

    # case_dir='./'#当前脚本的路径 # discover=unittest.defaultTestLoader.discover(case_dir,pattern='unittest_fr ...

  8. unittest详解(四) 批量执行用例(discover)

    前面我们说了,对于不同文件用例,我们可以通过addTest()把用例加载到一个测试套件(TestSuite)来统一执行,对于少量的文件这样做没问题,但是如果有几十上百个用例文件,这样做就太浪费时间了. ...

  9. python学习笔记(28)-unittest单元测试-执行用例

    执行用例 #写一个测试类 import unittest import HTMLTestRunnerNew #写好的模块可以直接调用 #import HTMLTest #测试报告模板 from cla ...

随机推荐

  1. 脚本代码混淆-Python篇-pyminifier(1)

    前言 最近研究了一下脚本语言的混淆方法,比如 python,javascript等.脚本语言属于动态语言,代码大多无法直接编译成二进制机器码,发行脚本基本上相当于暴露源码,这对于一些商业应用是无法接受 ...

  2. Java 创建/识别条形码、二维码

    条形码(Barcode)是将宽度不等的多个黑条和空白,按照一定的编码规则排列,用以表达一组信息的图形标识符.常用于标示物品的生产国.制造厂家.商品名称.生产日期.图书分类号.邮件起止地点.类别.日期等 ...

  3. vmware vsphere client 创建虚拟机

    浏览器访问https://192.168.120.29 用户名:administrator@zhcs.com 密码:  Deyi123456! 说明:此案例为创建linux的Centos7的操作系统的 ...

  4. 数据库(DDL,DML,DQL、DCL)

    1.数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHERE   子句组成的查询块:   SELECT <字段名表>   FROM <表或视图名& ...

  5. Metaspolit工具----基础

    Metasploit框架(Metasploit Framework,MSF)是一个开源工具,旨在方便渗透测试,他是有Ruby程序语言编写的模板化框架,具有很好的扩展性,便于渗透测试人员开发.使用定制的 ...

  6. TLC5615

    #include <reg51.h> #include "TLC5615.c" code uchar seven_seg[] = {0xc0, 0xf9, 0xa4, ...

  7. 探索form组件和cookie,session组件

    一. 实现注册功能 后端代码: from django.shortcuts import render,HttpResponse,redirect from app01 import models C ...

  8. RocksDB线程局部缓存

    概述 在开发过程中,我们经常会遇到并发问题,解决并发问题通常的方法是加锁保护,比如常用的spinlock,mutex或者rwlock,当然也可以采用无锁编程,对实现要求就比较高了.对于任何一个共享变量 ...

  9. SpringCloud-Hystrix Dashboard 之 Unable to connect to Command Metric Stream

    实践hystrix dashboard仪表盘的时候,不管是按照书上的还是网上的,都提示Unable to connect to Command Metric Stream. 查了好久发现,如果使用sp ...

  10. AMD vs. CommonJS?

    js开发者对js模块加载的尝试和创新从来都没有停止过,尤其是当nodejs的出现后,模块化加载的必要性更加凸显.本文不讨论如何在nodejs环境来模块化加载(创造者已经利用commonJS机制解决), ...