直接贴代码:

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. python日志1

    import logging # logging.basicConfig(filename='app.log', # format='%(asctime)s - %(name)s - %(leveln ...

  2. 使用RocketMQ实现分布式事务

    .. todo ref https://blog.csdn.net/zhejingyuan/article/details/79480128

  3. P1880 [NOI1995]石子合并(区间DP)

    题目链接:https://www.luogu.org/problemnew/show/P1880 题目大意:中文题目 具体思路:和上一篇的思路是差不多的,也是对于每一个小的区间进行处理,然后再归并到大 ...

  4. 阿里云IoT物联网平台入门教程

    参考链接:https://www.geek-workshop.com/thread-37883-1-1.html

  5. 通用redis命令

    Redis五种数据类型,String,hash,list,set,有序set keys pattern:获取所有与pattern匹配的key,返回所有与该key匹配的keys. 通配符: *表示任意0 ...

  6. 异常:已引发: "设置 connectionId 时引发了异常。" (System.Xaml.XamlObjectWriterException) 引发了一个 System.Xaml.XamlObjectWriterException: "

    项目中,引用一个富文本编辑器,SmithHtmlEditor,进入页面的时候异常. 在View和ViewModel所在的类库引用. 还需要在Main中引用.

  7. Mint-UI

    Mint-UI是基于Vue.js的移动端组件库 Mint-UI是Vue组件库,是使用Vue技术封装出来的成套的组件,可以无缝地和Vue项目进行集成开发 Mint UI官网 不同版本的安装 导入有两种方 ...

  8. 【leetcode】657. Robot Return to Origin

    Algorithm [leetcode]657. Robot Return to Origin https://leetcode.com/problems/robot-return-to-origin ...

  9. Direct Shot Correspondence Matching

    一篇BMVC18的论文,关于semantic keypoints matching.dense matching的工作,感觉比纯patch matching有意思,记录一下. 1. 摘要 提出一种针对 ...

  10. matplotlib 直方图绘制详解

    n, bins, patches = plt.hist(datasets, bins, normed=False, facecolor=None, alpha=None) 函数说明 用于绘制多个数据集 ...