既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
def method1(duration=0.000001):
time.sleep(duration)
return “test”
**创建被测函数**
创建性能测试函数:编写需要进行性能测试或基准测试的函数,并使用pytest装饰器将其标记为性能测试函数。例如:
import pytest, pytest_benchmark
def test_my_function(benchmark):
result = benchmark(method1, argument1, argument2)
assert result == expected_result
在上面的示例中,test\_my\_function是性能测试函数,benchmark是pytest-benchmark插件提供的装饰器。method1是要进行性能测试的函数,argument1和argument2是该函数的参数,这些参数要根据实际需要进行调整即可。
**运行测试**
pytest
**测试结果**
![](https://img-blog.csdnimg.cn/img_convert/81a06003bb4ccf84a9f30b9d8e8e45bb.png)
当使用pytest-benchmark运行性能测试后,测试结果将显示在控制台中。以下是结果中每列的含义:
1. name: 测试函数的名称。每个测试函数都有自己的名称,用于区分不同的测试。
2. min: 执行测试函数的最小时间。这是在所有运行中观察到的最短时间。
3. max: 执行测试函数的最大时间。这是在所有运行中观察到的最长时间。
4. mean: 执行测试函数的平均时间。这是所有运行时间的平均值。
5. stddev: 执行测试函数的标准差。标准差用于衡量运行时间的离散程度。较小的标准差表示运行时间更稳定。
6. median: 执行测试函数的中位数时间。中位数是将所有运行时间按大小排序后,位于中间位置的值。
7. IQR: 四分位距(InterQuartile Range)。这是一种不同的测量方差的方法。
8. outliers: 执行测试函数时观察到的异常值数量。异常值是指与其他观测值相比明显偏离的值。
9. OPS: 表示在一定时间内(比如1秒)测试方法被调用了多少次。
10. rounds: 执行测试函数的运行次数。pytest-benchmark默认会多次运行测试函数,并根据这些运行结果计算出平均时间等统计数据。
11. iterations: 每个运行中执行测试函数的迭代次数。pytest-benchmark会在每个运行中多次迭代执行测试函数,并计算每次迭代的时间。
![img](https://img-blog.csdnimg.cn/img_convert/8a9ed2f7e190c84cd65e33ba908b06b2.png)
![img](https://img-blog.csdnimg.cn/img_convert/06c710b043140696f4dfec15bd3d5194.png)
![img](https://img-blog.csdnimg.cn/img_convert/b86c9438a38d390bb0d541d6768539e3.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618608311)**
目、大纲路线、讲解视频,并且后续会持续更新**
**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618608311)**