本文介绍: 在上面的示例中,test_my_function性能测试函数benchmarkpytestbenchmark插件提供的装饰器。method1是要进行性能测试函数argument1和argument2是该函数参数,这些参数要根据实际需要进行调整即可pytestbenchmark会在每个运行多次迭代执行测试函数,并计算每次迭代时间创建性能测试函数编写需要进行性能测试或基准测试的函数,并使用pytest装饰器将其标记性能测试函数。每个测试函数都有自己名称用于区分不同的测试。

Pytest其实也是可以性能测试或者基准测试的。是非常方便的。 可以考虑使用Pytestbenchmark类库进行。

安装pytestbenchmark

首先,确保已经安装pytestpytest-benchmark插件。可以使用以下命令安装插件:

pip install pytest pytest-benchmark

创建被测函数

创建被测函数如下

import time, pytest_benchmark
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是性能测试函数,benchmarkpytest-benchmark插件提供的装饰器。method1是要进行性能测试的函数,argument1和argument2是该函数的参数,这些参数要根据实际需要进行调整即可

运行测试

pytest

测试结果

使用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会在每个运行中多次迭代执行测试函数,并计算每次迭代的时间。

分析结果时,可以将不同函数的结果进行比较,并考虑是否满足性能要求。可以根据测试结果进行优化和改进,并重新运行测试以验证改进的效果

这可能是B站最详细的pytest自动化测试框架教程,整整100小时,全程实战!!!

原文地址:https://blog.csdn.net/xiao1542/article/details/134742724

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_25652.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注