直接贴代码:

import unittest
from selenium import webdriver
from time import sleep
import os
import time # 定义打开浏览器的方法,这里用的是Chrome,火狐为Firfox,IE为Ie,必须在根目录下对应的driver才能调用
dr = webdriver.Chrome()
# 浏览器最大化
dr.maximize_window() # 创建测试类LoginCase,用unittest的测试框架的格式
class LoginCase(unittest.TestCase):
    global path
    path = 'F:/Python_test/'
    # 定义登录方法,被测试用例调用
    def login(self, username, password):
        # 需要测试的网页
        dr.get('https://passport.cnblogs.com/user/signin')         # 需要输入的用户名,变量名和方法中的一致,find_element_by_id('input1')为抓取到的用户名的输入框,用谷歌或者火狐F12可以抓取到
        dr.find_element_by_id('input1').send_keys(username)         # 需要输入的密码,变量名和方法中的一致,find_element_by_id('input2')为抓取到的密码的输入框
        dr.find_element_by_id('input2').send_keys(password)         # 点击登陆按钮,find_element_by_id('signin')为抓取到的登陆按钮,click()为点击事件
        dr.find_element_by_id('signin').click()  # 点击登陆按钮         # 定义测试方法,框架中测试方法以test_开头,底下引号中的中文会在报告中显示,利于清楚的知道测试目的     def test_login_success(self):
        '''用户名、密码正确'''
        self.login('anyXXX', 'XXXXXX')  # 调用定义的login方法,传入正确用户名和密码
        sleep(1)         # 可以用get_screenshot_as_file方法用来截图,可自定义截图后的保存位置和图片命名
        dr.get_screenshot_as_file(path + "login_success.jpg")         # 定义了一个实际值,用谷歌或者火狐F12可以抓取到登陆后显示的用户名,.text是获取地址的文本值
        # assert先判断需要的实际值是否正确,正确,继续运行用例;如果不正确,不继续运行该用例并返回错误
        assert dr.find_element_by_id('lnk_current_user').text, '判断的元素错误,请确认!'         # 将实际值赋值给一个变量link,方便比较,可自定义
        link = dr.find_element_by_id('lnk_current_user').text         # 用assertTrue(x)方法来断言,登录成功后预期的值是否和定义的实际值一致
        self.assertTrue('anyXXX' in link)     def test_login_pwd_error(self):
        '''用户名正确、密码不正确'''
        self.login('1', '1')  # 正确用户名,错误密码
        sleep(1)
        dr.get_screenshot_as_file(path + "login_password_error.jpg")
        assert dr.find_element_by_id("tip_btn").text, '提示信息类型错误!'
        error_message = dr.find_element_by_id('tip_btn').text
        #self.assertIn('用户名或密码错误', error_message)  # 用assertIn(a,b)方法来断言
        assert error_message[0:7],'用户名或密码错误'     def test_login_pwd_null(self):
        '''用户名正确、密码为空'''
        self.login('1', '')  # 密码为空
        sleep(1)
        dr.get_screenshot_as_file(path + "login_password_null.jpg")
        assert dr.find_element_by_id("tip_input2").text, '提示信息类型错误!'
        error_message = dr.find_element_by_id('tip_input2').text
        #self.assertEqual(error_message, '请输入密码')  # 用assertEqual(a,b)方法来断言
        assert error_message, '请输入密码'     def test_login_user_error(self):
        '''用户名错误、密码正确'''
        self.login('1', '1')  # 密码正确,用户名错误
        sleep(1)
        dr.get_screenshot_as_file(path + "login_username_error.jpg")
        assert dr.find_element_by_id("tip_btn").text, '提示信息类型错误!'
        error_message = dr.find_element_by_id('tip_btn').text
        #self.assertIn('该用户不存在', error_message)  # 用assertIn(a,b)方法来断言 a in b
        assert error_message[0:5], '该用户不存在'     def test_login_user_null(self):
        '''用户名为空、密码正确'''
        self.login('', '1')  # 用户名为空,密码正确
        sleep(1)
        dr.get_screenshot_as_file(path + "login_username_null.jpg")
        assert dr.find_element_by_id("tip_input1").text, '提示信息类型错误!'
        error_message = dr.find_element_by_id('tip_input1').text
        #self.assertEqual(error_message, '请输入登录用户名')  # 用assertEqual(a,b)方法来断言
        assert error_message,'请输入登录用户名'     # 每个test_执行完执行一次tearDown()方法
    def tearDown(self):
        sleep(1)
        # refresh()方法为刷新浏览器
        dr.refresh()
        # 关闭浏览器
        dr.quit() if __name__ == '__main__':
    # 导入HTMLTestRunner库,这句也可以放在脚本开头
    import HTMLTestRunner     # 定义脚本标题,加u为了防止中文乱码     report_title = u'登陆模块测试报告'     # 定义脚本内容,加u为了防止中文乱码
    desc = u'博客园登陆模块测试报告详情:'     # 定义date为日期,time为时间
    date = time.strftime("%Y%m%d")
    time = time.strftime("%Y%m%d%H%M%S")     # 定义path为文件路径,目录级别,可根据实际情况自定义修改
    path = 'F:/Python_test/' + date + "/login/" + time + "/"     # 定义报告文件路径和名字,路径为前面定义的path,名字为report(可自定义),格式为.html
    report_path = path + "report.html"     # 判断是否定义的路径目录存在,不能存在则创建
    if not os.path.exists(path):
        os.makedirs(path)
    else:
        pass     # 定义一个测试容器
    testsuite = unittest.TestSuite()     # 将测试用例添加到容器
    testsuite.addTest(LoginCase("test_login_success"))
    testsuite.addTest(LoginCase("test_login_pwd_error"))
    testsuite.addTest(LoginCase("test_login_pwd_null"))
    testsuite.addTest(LoginCase("test_login_user_error"))
    testsuite.addTest(LoginCase("test_login_user_null"))     # 将运行结果保存到report,名字为定义的路径和文件名,运行脚本
    with open(report_path, 'wb') as report:
        runner = HTMLTestRunner.HTMLTestRunner(stream=report, title=report_title, description=desc)
        runner.run(testsuite)     # 关闭report,脚本结束
    report.close() 生成报告为:

python用unittest+HTMLTestRunner的框架测试并生成测试报告的更多相关文章

  1. python用unittest+HTMLTestRunner+csv的框架测试并生成测试报告

    直接贴代码: import csv  # 导入scv库,可以读取csv文件from selenium import webdriverimport unittestfrom time import s ...

  2. Python+selenium+unittest+HTMLTestReportCN单元测试框架分享

    分享一个比较基础的,系统性的知识点.Python+selenium+unittest+HTMLTestReportCN单元测试框架分享 Unittest简介 unittest是Python语言的单元测 ...

  3. Python+Excel+Unittest+HTMLTestRunner实现数据驱动接口自动化测试(一)

    整个流程: 使用HTMLTestRunner的Run方法执行用例,用例调用Excel读取方法,将测试数据导入到unittest用例中执行,测试结果返回给HTMLTestRunner. 因为刚接触接口自 ...

  4. UI测试后生成测试报告,利用shell脚本上传svn

    ui测试后生成测试报告,把报告保存在某一个固定路径 shell脚本把这个报告上传 #!/bin/bash -ile #svn下载文件 #svn checkout http://svn.xxx.com/ ...

  5. Python+Selenium+Unittest+HTMLTestRunner生成测试报告+发送至邮箱,记一次完整的cnblog登录测试示例,

    测试思路:单个测试集.单个测试汇成多个测试集.运行测试集.生成测试报告.发送至邮箱. 第一步:建立单个测试集,以cnblog登录为例. 测试用例: cnblog的登录测试,简单分下面几种情况:(1)用 ...

  6. Appium基于Python unittest自动化测试 & 自动化测试框架 -- PO并生成html测试报告

    基于python单元测试框架unittest完成appium自动化测试,生成基于html可视化测试报告 代码示例: #利用unittest并生成测试报告 class Appium_test(unitt ...

  7. Python + request + unittest实现接口测试框架

    1.为什么要写代码实现接口自动化 大家知道很多接口测试工具可以实现对接口的测试,如postman.jmeter.fiddler等等,而且使用方便,那么为什么还要写代码实现接口自动化呢?工具虽然方便,但 ...

  8. Python Selenium unittest+HTMLTestRunner实现 自动化测试及发送测试报告邮件

    1.UI测试框架搭建-目录结构 2. 文件介绍 2.1.baseinfo->__init__.py 配置文件定义基础参数 #-*-coding:utf-8-*- #测试用例配置参数 base_u ...

  9. python:unittest之跳过测试和预期失败的用例

    在利用单元测试框架执行测试用例的过程中,有时只需要执行一部分用例,或者跳过某些暂不需要执行的用例,python的unittest框架就内置这样的功能. 前面的博客介绍了unittest框架的测试用例加 ...

随机推荐

  1. ue4配置分析记录

    相关代码 UObject::CallFunctionByNameWithArguments  ExecuteConsoleCommand << 配置.ini[???.类名]    //要先 ...

  2. Coursera, Deep Learning 4, Convolutional Neural Networks - week1

    CNN 主要解决 computer vision 问题,同时解决input X 维度太大的问题. Edge detection 下面演示了convolution 的概念 下图的 vertical ed ...

  3. windows Apache 环境下配置支持HTTPS的SSL证书

    windows Apache 环境下配置支持HTTPS的SSL证书 1.准备工作 1)在设置Apache + SSL之前, 需要做: 安装Apache, 下载安装Apache时请下载带有SSL版本的A ...

  4. GitHub贡献第一的公司是谁?微软开源软件列表

    参考:http://www.infoq.com/cn/news/2017/03/GitHub-first-Microsoft-open-sour 提起微软公司,不少人第一反应是老牌巨头专注于私有化软件 ...

  5. gradle文件中自定义字段值在java代码中使用

    1. 在build.gradle 中  buildConfigField  的参数有3个 第一个类型 第二个为名称 第三个是值 如果是字符串类型 请不要忘记 双引号! buildTypes {     ...

  6. python - 代码练习 - 差异备份/同步更新

    差异备份以及文件同步: import os import filecmp import shutil import re # 差异增量更新,dir2 文件目录 与 dir1 文件目录更新, def a ...

  7. Django学习手册 - 自定义分页函数

    前端代码: <div class="xianshi"> {% for i in info %} <ul> <li>{{ i }}</li& ...

  8. NOIP2018 20天训练

    Day 0 2018.10.20 其实写的时候已经是Day 1了--(凌晨两点) 终于停课了,爽啊 get树状数组+线段树(延迟标记) 洛谷:提高组所有nlogn模板+每日一道搜索题(基本的图的遍历题 ...

  9. Python全栈(第一部分)day2

    昨日内容回顾 编译型:一次性将全部代码编译成二进制文件 代表语言: C,C++ 优点:执行效率高 缺点:开发速度慢,不能跨平台 解释型:当程序运行时,从上至下一行一行的解释成二进制 优点:开发速度快, ...

  10. windows下安装MySql + navicat(图形化界面)

    MySQL安装过程参考:https://www.cnblogs.com/ayyl/p/5978418.html navicat图形化界面安装过程参考:https://www.cnblogs.com/l ...