直接贴代码:

import csv  # 导入scv库,可以读取csv文件
from selenium import webdriver
import unittest
from time import sleep
import time
import os
import HTMLTestRunner
import codecs
import sys
dr = webdriver.Chrome()

class testLo(unittest.TestCase):
    def setUp(self):
        pass

def test_login(self):
        '''登陆测试'''
        path = 'F:\\Python_test\\'
        # 要读取的scv文件路径
        my_file = 'F:\\pythonproject\\interfaceTest\\testFile\\ss.csv'
        # csv.reader()读取csv文件,
        # Python3.X用open,Python2.X用file,'r'为读取
        # open(file,'r')中'r'为读取权限,w为写入,还有rb,wd等涉及到编码的读写属性
        #data = csv.reader(codecs.open(my_file, 'r', encoding='UTF-8',errors= 'ignore'))
        with codecs.open(my_file, 'r', encoding='UTF-8',errors= 'ignore') as f:
            data=csv.reader((line.replace('\x00','') for line in f))
            # for循环将读取到的csv文件的内容一行行循环,这里定义了user变量(可自定义)
            # user[0]表示csv文件的第一列,user[1]表示第二列,user[N]表示第N列
            # for循环有个缺点,就是一旦遇到错误,循环就停止,所以用try,except保证循环执行完
            print(my_file)
            for user in data:
                print(user)
                dr.get('https://passport.cnblogs.com/user/signin')
                # dr.find_element_by_id('input1').clear()
                dr.find_element_by_id('input1').send_keys(user[0])
                # dr.find_element_by_id('input2').clear()
                dr.find_element_by_id('input2').send_keys(user[1])
                dr.find_element_by_id('signin').click()
                sleep(1)
                print('\n' + '测试项:' + user[2])
                dr.get_screenshot_as_file(path + user[3] + ".jpg")
                try:
                    assert dr.find_element_by_id(user[4]).text
                    try:
                        error_message = dr.find_element_by_id(user[4]).text
                        self.assertEqual(error_message, user[5])
                        print('提示信息正确!预期值与实际值一致:')
                        print('预期值:' + user[5])
                        print('实际值:' + error_message)
                    except:
                        print('提示信息错误!预期值与实际值不符:')
                        print('预期值:' + user[5])
                        print('实际值:' + error_message)
                except:
                    print('提示信息类型错误,请确认元素名称是否正确!')

def tearDown(self):
        dr.refresh()
        # 关闭浏览器
        dr.quit()

if __name__ == "__main__":
    # 定义脚本标题,加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(testLo("test_login"))

# 将运行结果保存到report,名字为定义的路径和文件名,运行脚本
    report = open(report_path, 'wb')
    #with open(report_path, 'wb') as report:
    runner = HTMLTestRunner.HTMLTestRunner(stream=report, title=report_title, description=desc)
    runner.run(testsuite)

# 关闭report,脚本结束
    report.close()

csv文件格式:

备注:

使用python处理中文csv文件,并让execl正确显示中文(避免乱码)设施编码格式为:utf_8_sig,示例:

    1. '''''
    2. 将结果导出到result.csv中,以UTF_8 with BOM编码(微软产品能正确识别UTF_8 with BOM存储的中文文件)存储
    3. '''
    4. #data.to_csv('result_utf8_no_bom.csv',encoding='utf_8')#导出的结果不能别excel正确识别
    5. data.to_csv('result_utf8_with_bom.csv',encoding='utf_8_sig')

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

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

    直接贴代码: import unittestfrom selenium import webdriverfrom time import sleepimport osimport time # 定义打 ...

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

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

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

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

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

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

  5. Python3 完美解决unittest框架下不生成测试报告

    前提: 1.运行测试用例一切正常,只是没有测试报告显示 2.使用命令行pyhon 脚本名字.py 却可以生成测试报告 3.pycharm 在运行测试用例的时候 默认是以unittest 框架来运行的, ...

  6. Python单元测试框架之pytest -- 生成测试报告

    继续pytest单元测试框架的学习,pytest可以生成多种类型的测试报告.这一节就来学习pytest如何生成测试报告. 创建test_calss.py 测试用例文件,这里以测试该文件为例. #cod ...

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

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

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

    因为小白,这2天研究了好久才算是搞好.先附上一个测试完成后邮件的截图: 上一篇有提到: unittest中实际运行了一个接口的很多条用例,而报告中只会有一条记录.这是因为unittest test c ...

  9. python+request+unittest+HTMLTestRunner

    https://www.imooc.com/article/details/id/20813 https://www.cnblogs.com/fennudexiaoniao/p/7771931.htm ...

随机推荐

  1. LinkedStack的底层实现

    package zy813ture; import java.util.EmptyStackException; public class MyLinkedStack1 { private Node ...

  2. Spring Boot Endpoint

    Spring Boot 的 Endpoints 带着强烈的 DevOps 色彩, “you build it, you run it” ,开发不仅要关心如何实现功能,还需要关心服务在线上运行的状态,如 ...

  3. mysql 案例 ~ mysql常见日志错误

    一 简介: mysql note级别日志汇总二错误系列  1 Aborted connection    1 [Note] Aborted connection 61 to db: 'unconnec ...

  4. Javascript - ExtJs - GridPanel组件

    GridPanel组件(Ext.grid.GridPanel)logogram:Ext.grid.Panel | xtype:gridpanel 此类派生自Ext.Panel,创建表格需要两个必须的对 ...

  5. vue 中通过 ajax 获取数据时,如何避免绑定的数据中出现 property of undefined 错误

    参考链接:https://segmentfault.com/q/1010000008264089?_ea=1597485

  6. css3 特效拓展 画个安卓机器人

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. qtcreator 快捷键常用

    F1        查看帮助F2        跳转到函数定义(和Ctrl+鼠标左键一样的效果)Shift+F2    声明和定义之间切换F4        头文件和源文件之间切换Ctrl+1     ...

  8. SpringCloud Config(分布式配置中心)

    ⒈是什么? Spring Cloud Config分为服务端和客户端两部分. 服务端也称为分布式配置中心,它是一个独立的微服务应用,用来连接配置服务器并为客户端提供获取配置信息,加密/解密信心等接口. ...

  9. HDOJ 1217 Arbitrage (最短路)

    题意:每两种货币之间都有不同的汇率  如果换回自己最后是赚的 输出Yes 否则是No 因为最多只有三十种货币 所以用Floyd是可行的 与一般的最短路板子不同的地方 汇率是要乘而不是加 如果乘上一个小 ...

  10. vue之router钩子函数

    模块一:全局导航钩子函数 1.vue router.beforeEach(全局前置守卫) beforeEach的钩子函数,它是一个全局的before 钩子函数, (before each)意思是在 每 ...