实现给一个路径,去查找test开头的测试用例文件

创建一个计算器的类,方便后面测试用

class Calculator(object):

    def add(self, x, y):
return x + y def sub(self, x, y):
return x - y def mul(self, x, y):
return x * y def div(self, x, y):
return x / y

创建一个unittest的用例集

# coding=utf-8

from unittest import main
from unittest import TestCase
from src import Calculator class TestCalculator(TestCase): def setUp(self):
self.calc = Calculator()
print("setUp") def tearDown(self):
print("tearDown") def test_add(self):
result = self.calc.add(2, 3)
self.assertEqual(result, 5, u"测试加法。")
print("test_add") def test_sub(self):
result = self.calc.sub(2, 3)
self.assertEqual(result, -1, u"测试减法。")
print("test_sub") def test_mul(self):
result = self.calc.mul(2, 3)
self.assertEqual(result, 6, u"测试乘法。")
print("test_mul") def test_div(self):
result = self.calc.div(4, 2)
self.assertEqual(result, 2, u"测试除法。")
print("test_div") if __name__ == '__main__':
main()

查找用例的类

import sys

class Discovery(object):

    def __init__(self):
pass def find_case_by_path(self, path):
""" 获取用例 """
files = self.get_files(path, include=['.py'], exclude=['.xml', '.json', '.pyc'])
cases = self.load_cases(files)
return cases def get_files(self, path, include=[], exclude=['.xml', '.iml']):
""" path是要列出文件的路径。根据代码规则,黑名单机制优先于白名单机制执行。 """
files = []
# 如果路径不存在,则直接返回空列表。
if not os.path.exists(path):
return files
# 如果路径是文件,则直接返回文件。
if os.path.isfile(path):
# 这里处理exclude规则--黑名单机制。
if exclude:
for rule in exclude:
if path.find(rule) != -1:
return files
# 这里处理include规则--白名单机制。
if include:
for rule in include:
if path.find(rule) != -1:
files.append(path)
else:
files.append(path)
return files
# 如果路径是目录,则列出目录内容,递归处理。
if os.path.isdir(path):
results = os.listdir(path)
for result in results:
# 将原路径与路径下文件名拼接成新路径。
new_path = "/".join([path, result])
files.extend(self.get_files(new_path, include, exclude))
return files def load_cases(self, files):
""" 加载用例 """
cases = []
for file in files:
if file.find("test") == -1: # 判断文件名里面没有“test”就查找下一个
continue
case = {'file': file} # 如果有就存到case字典里面
directory = os.path.dirname(file) # 获取到文件的目录
sys.path.append(directory) # 用sys把此文件的目录加进去
name = os.path.basename(file)[:-3] # 获取文件名
module = __import__(name) # 反射导入文件
case.setdefault("module", module) # 把文件加入到case
for attr in dir(module):
if attr.find("TestCase") != -1: # 判断文件里面有没有继承了“TestCase”的类(兼容unittest)
continue
if attr.find("Test") == -1: # 判断类名里面有没有Test
continue
object = getattr(module, attr)() # 反射的方式实例化对象
case.setdefault("object", object) # 获取这个对象
case.setdefault("method", [])
for attr in dir(object): # 提取测试用例里面的方法
# 这里是断言结果。
if attr.find('result') != -1:
case.setdefault("result", getattr(object, attr))
if not callable(getattr(object, attr)): # 从object代表的对象获取attr代表的函数,判断是否可以调用
continue
if attr.find("test") != -1:
case["method"].append(getattr(object, attr))
if attr.find("setUp") != -1:
case.setdefault("setUp", getattr(object, attr))
if attr.find("tearDown") != -1:
case.setdefault("tearDown", getattr(object, attr))
cases.append(case)
return cases if __name__ == '__main__':
discovery = Discovery()
import os case_path = os.path.join(os.path.dirname(os.getcwd()), 'case') # case 文件夹
print(case_path)
cases = discovery.find_case_by_path(case_path)
print(cases)

测开之路五十五:实现类似于unittest查找case的更多相关文章

  1. 测开之路八十五:python处理csv文件

    写入csv文件 一:写入字典 二:写入普通数据 读取: 第一种:普通读取 第二种:读取csv并用namedtuple映射列名,类似于使用类的实例 第三种:字典形式 import csvfrom col ...

  2. 测开之路七十五:linux常用命令

    常用命令: ls:列出文件或目录 pwd:展示当前所在的目录 mkdir:创建目录 mkdir -p :创建连续的目录 cd:切换目录 vi:编辑内容,点i开始编辑,输入::wq保存 cat 显示文件 ...

  3. 测开之路六十五:UI测试平台之js

    //添加网址的函数,生成一个输入网址的标签,并且把标签append到id为cases下function browser() { var html = '\ <div class="ro ...

  4. 测开之路四十五:Django之最小程序

    安装Django库 Django最小程序 import sysfrom django.conf.urls import urlfrom django.conf import settingsfrom ...

  5. 测开之路三十五:css引入

    CSS是一种定义样式结构,如字体.颜色.位置等的语言,被用于描述网页上的信息格式化和现实的方式.CSS样式可以直接存储于HTML网页或者单独的样式单文件.无论哪一种方式,样式单包含将样式应用到指定类型 ...

  6. 测开之路一百零五:bootstrap的两种引用方式

    一:下载到本地引用: 3.3.7版本:https://getbootstrap.com/docs/3.3/getting-started/#download 下载后解压到本地项目中引用 第二种,cdn ...

  7. 测开之路七十六:性能测试蓝图之html

    <!-- 继承base模板 -->{% extends 'base.html' %} {% block script %} <!-- 从cdn引入ace edter的js --> ...

  8. 测开之路四十八:Django之重定向与cookie

    基础配置与上一篇一致 404错误 定义一个error页面 <!DOCTYPE html><html lang="en"><head> <m ...

  9. 测开之路八十九:HTML之图片处理

    <!--width.height设置图片尺寸 alt:当图片不能展示时,显示的内容 title:鼠标放上去时展示的内容--> <img src="../imges/img0 ...

随机推荐

  1. 高级ACL访问控制列表

    实验拓扑: 配置: 基本配置做完之后搭建OSPF网络 R1: ospf 1 area 0 network 10.0.13.0 0.0.0.255 network 1.1.1.1 0.0.0.0 R2: ...

  2. PHP 是怎么接收到请求的?

    本篇文章主要描述一下几点 ● nginx 怎么转发请求 给 PHPFPM? ● CGI 和 FastCGI 到底是个什么玩意? ● PHPFPM 是什么?有什么作用? 简单场景描述 在浏览器上访问一个 ...

  3. Java_1.Java符号体系

    Java符号包含五类:标识符.关键字.常量及字面量.运算符.分隔符 1.标识符 定义:用于标明程序中元素的名字,如类.方法和变量 命名规则: ·由字母.数字.下划线(_)和美元符号($)构成的字母序列 ...

  4. luogu P3657 (NOIP2017) 跳房子(二分+DP+单调队列)

    题面 传送门 分析 显然答案有单调性,可以二分答案,设当前二分值为g,根据题意我们可以求出跳跃长度的范围[l,r] 考虑DP 子状态: dp[i]表示跳到第i个点时的最大和 状态转移方程 \(dp[i ...

  5. 【题解】Hankson 的趣味题

    题目大意 已知正整数$a_{0}$.$a_{1}$.$b_{0}$.$b_{1}$($1 \leq a_{0}, a_{1}, b_{0}, b_{1} \leq 2 \times 10^{9}$), ...

  6. 【JMeter4.0】二、JMeter4.0安装与配置

    二.安装配置JMeter jmeter是一个纯java工具,因此,JDK必不可少,现在最新版的jmeter是4.0,建议使用1.8及以上的JDK安装配置JDK,如没有,请见:[JMeter4.0]一. ...

  7. 微信、qq网页二次分享

    二次分享是指,在APP或者浏览器分享到微信或者qq,然后从微信或者qq再分享到别的平台.如果不处理,再次分享出去的图片或者标题就不会显示,对用户非常不友好. 一.微信二次分享 官方接入文档:https ...

  8. 分析abex'crackme#1

    测试文件下载:https://www.wocloud.com.cn/webclient/share/sindex.action?id=i9K_Br6TgE7Kf_YTF04yHmKcRy5TUdZ8U ...

  9. JavaScript中的反柯里化

    转载自:https://www.cnblogs.com/zztt/p/4152147.html 柯里化 柯里化又称部分求值,其含义是给函数分步传递参数,每次传递参数后部分应用参数,并返回一个更具体的函 ...

  10. elasticsearch 基础 —— URI搜索

    URI搜索 可以通过提供请求参数使用URI来执行搜索请求.使用此模式执行搜索时,并非所有搜索选项都会暴露.这是一个例子: GET twitter/_search?q=user:kimchy 示例响应: ...