直接贴代码:

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. Scala思维导图

  2. Linux性能查询常用指令

    类别 监控指令 描述 备注 内存 瓶颈 free 查看内存使用   cpu 瓶颈 top  -Hp 查看cpu使用最高的进程     vmstat 3(间隔时间) 100(监控次数) 查看swap i ...

  3. linux 僵屍进程

    参考链接 :  http://soft.chinabyte.com/os/5/12172005.shtml

  4. rpmlib(PayloadIsLzma) <= 4.4.6-1 is needed【转载】

    以下为转载,但是有改动,原作者在一处写错了,将高写成了低,直接差之毫厘,谬之千里. 环境: centos el5 背景: 由于个人比较喜欢用软件的最新版本,在重新安装服务器上的 xdg-open(还有 ...

  5. Delete 和 Put 请求失效, Spring 框架

    Delete 和 Put 请求失效, Spring 框架 原因:使用tomcat 启动Spring项目的时候,请求失效.因为tomcat 不支持 Delete 和 Put 在 Web.xml 中增加下 ...

  6. 51nod 1379 索函数

    Fib[0]=0,Fib[1]=1,Fib[n]=Fib[n-1]+Fib[n-2] if n>1. 定义索函数Sor(n)=Fib[0]| Fib[1] |Fib[2]|…|Fib[n]. 给 ...

  7. RabbitMQ简单应用の公平分发(fair dipatch)

    公平分发(fair dipatch)和轮询分发其实基本一致,只是每次分发的机制变了,由原来的平均分配到现在每次只处理一条消息 1.MQ连接工厂类Connection package com.mmr.r ...

  8. Pytorch 细节记录

    1. PyTorch进行训练和测试时指定实例化的model模式为:train/eval eg: class VAE(nn.Module): def __init__(self): super(VAE, ...

  9. Delphi 实现自动更新

    Delphi 通用程序自动更新升级:http://www.delphitop.com/html/wangluo/2968.html https://www.cnblogs.com/hnxxcxg/p/ ...

  10. mac下安装memcache

    需求包安装libmemcached brew install libmemcached 安装memcached brew install memcached 启动服务 brew services st ...