本篇转自博客:上海-悠悠

原文地址:http://www.cnblogs.com/yoyoketang/tag/python%E6%8E%A5%E5%8F%A3%E8%87%AA%E5%8A%A8%E5%8C%96/

前言

有很多小伙伴吵着要完整的项目源码,完整的项目属于公司内部的代码,这个是没法分享的,违法职业道德了,就算别人分享了,也只适用于本公司内部的业务。

所以用例的代码还是得自己去一个个写,我只能分享项目框架,只能帮你们到这了。

一、项目结构

1.新建一个工程(一定要创建工程),工程名称自己定义,如:yoyo_jiekou

2.在工程的跟目录新建一个脚本:run_main.py,用来执行全部用例

3.在工程下创建以下几个pakage包:

--case:这个包放test开头的测试用例,也可以放一些封装接口的方法,如:loginblog(如果封装的接口比较多,也可以单独放一个包)

--common:这个包放一些公共的方法,如:读取excel文件方法,读取mysql、oracle,logger.py这个是封装日志的输入

--config:cfg.ini这里是配置文件,如邮箱的一些参数:收件人,发件人,密码等,readConfig.py用于读取配置文件

--logs:这里存放日志信息

--report:这里存放测试报告

二、run_main

第一步:用discover方法加载所有的测试用例

1.cur_path这个参数是读取当前这个脚本的真实路径,也就是run_main.py的真实路径

2.caseName="case"这个case是存放测试用例的文件夹,如果没有的话,自动创建。如果想运行其它文件夹的用例,就改下caseName这个参数值

3.rule="test*.py"这个是匹配用例脚本名称的规则,默认匹配test开头的所有用例

第二步:生成HTML报告

1.把上一步加载到用例的参数传入这个函数,测试报告的文件名称默认report文件夹:reportName="report

2.如果没有这个report文件夹也没关系,可以自动创建的

第三步:获取最新的测试报告

1.如果第二步生成的测试报告加了时间戳,想找到最新的文件就用第三步

2.如果第二步不加时间戳,只是生成result.html,那这一步其实没卵用,可以忽略

(个人觉得报告用一个名称result.html就行,新的自动覆盖旧的)

第四步:发送测试报告到邮箱

1.像QQ邮箱这种ssl加密的就走SMTP_SSL,用授权码登录

2.其它邮箱就正常账号密码登录,走SMTP

最后执行代码

1.这里邮箱的内容读的配置文件

三、config配置

1.cfg.ini打开,这里写配置文件内容

2.用readConfig.py读取配置文件

3.读取的内容就是传入第二步操作里面需要调用邮箱的配置信息

三、logger

1.logger.py这个文件放到common目录下,封装日志文件的读取

2.日志保存到logs文件夹

3.封装代码

# coding:utf-8
import logging, time
import os
# log_path是存放日志的路径
cur_path = os.path.dirname(os.path.realpath(__file__))
log_path = os.path.join(os.path.dirname(cur_path), 'logs')
# 如果不存在这个logs文件夹,就自动创建一个
if not os.path.exists(log_path):os.mkdir(log_path)

class Log():
    def __init__(self):
        # 文件的命名
        self.logname = os.path.join(log_path, '%s.log'%time.strftime('%Y_%m_%d'))
        self.logger = logging.getLogger()
        self.logger.setLevel(logging.DEBUG)
        # 日志输出格式
        self.formatter = logging.Formatter('[%(asctime)s] - %(filename)s] - %(levelname)s: %(message)s')

def __console(self, level, message):
        # 创建一个FileHandler,用于写到本地
        fh = logging.FileHandler(self.logname, 'a')  # 追加模式  这个是python2的
        # fh = logging.FileHandler(self.logname, 'a', encoding='utf-8')  # 这个是python3的
        fh.setLevel(logging.DEBUG)
        fh.setFormatter(self.formatter)
        self.logger.addHandler(fh)

# 创建一个StreamHandler,用于输出到控制台
        ch = logging.StreamHandler()
        ch.setLevel(logging.DEBUG)
        ch.setFormatter(self.formatter)
        self.logger.addHandler(ch)

if level == 'info':
            self.logger.info(message)
        elif level == 'debug':
            self.logger.debug(message)
        elif level == 'warning':
            self.logger.warning(message)
        elif level == 'error':
            self.logger.error(message)
        # 这两行代码是为了避免日志输出重复问题
        self.logger.removeHandler(ch)
        self.logger.removeHandler(fh)
        # 关闭打开的文件
        fh.close()

def debug(self, message):
        self.__console('debug', message)

def info(self, message):
        self.__console('info', message)

def warning(self, message):
        self.__console('warning', message)

def error(self, message):
        self.__console('error', message)

if __name__ == "__main__":
   log = Log()
   log.info("---测试开始----")
   log.info("操作步骤1,2,3")
   log.warning("----测试结束----")

四、case放用例

1.常用的接口,需要检查被调用的单独封装处理,如登录等

2.test开头的用例

五、logs日志查看

1.运行完后日志都会收集到logs文件夹以日期命名

六、生成测试报告

1.这里调用的是HTMLTestRunner生成html的测试报告

七、发送报告到邮箱

1.运行run_main.py就会自动生成报告,然后发送到邮箱了

(这里QQ邮箱的展示是有问题的,一般用企业邮箱的话,是可以正常展示的)

最新文章

  1. Synchronization Service Manager
  2. 在Apache中使用mod_rewrite模块重写URL
  3. 基本分类方法——KNN(K近邻)算法
  4. sphinx 配置sphinx.conf
  5. sid超过8个字符处理步骤
  6. java基础之抽象类与接口的区别
  7. websphere节点、单元、服务之间的关系
  8. ngrok 本机代码部署外网访问神器(转)
  9. DB Query Analyzer 5.03 is distributed, EXCEL table name will be enclosed in square bracket
  10. 思科模拟器PacketTracer7--利用一台交换机和2台pc互连构成小型局域网
  11. HTML+css基础认识
  12. 玩转BLE(3)_使用微信蓝牙精简协议伪造记步数据
  13. PostgreSQL 数据类型
  14. Gradle vs Maven Comparison
  15. php企业建站源码
  16. mysqli扩展库的预处理
  17. 大一下第2次作业(markdown改)
  18. yum源更换为本地光盘
  19. PCRE函数简介和使用示例【转】
  20. nexus maven私服搭建

热门文章

  1. 9.4python开发之virtualenv与virtualenvwrapper
  2. Reverse Word in a String(翻转字符串)&字符串最后一个单词的长度
  3. (C)spring boot读取自定义配置文件时乱码解决办法
  4. Apache Spark 2.2.0 中文文档
  5. Spark Streaming实例
  6. APP遇到大量的真实手机号刷注册用户该如何应对?
  7. Pascal小游戏 随机函数
  8. 运用Pascal来破坏DLL的一个实例
  9. 《数据结构》C++代码 散列表
  10. 【Binary Search Tree Iterator 】cpp