python异常模拟工具类(异常生成工具类)

文章目录

主要是做测试的时候方便,

创建代码类

1、新建python文件exception_mock_utils.py,代码为:

python 复制代码
import random
import time
from typing import Any, Optional

class ExceptionMockUtils:
    """
    异常模拟工具类
    用于在开发或测试阶段模拟各种常见的程序异常
    """

    # --- 基础空值与逻辑异常 ---

    @staticmethod
    def mock_null_pointer(msg: str = "Attempted to access null reference"):
        """
        模拟 Java 风格的空指针异常 (Python 中对应 TypeError 或 AttributeError)
        """
        raise TypeError(msg)

    @staticmethod
    def mock_value_error(msg: str = "Invalid value provided"):
        """
        模拟参数值错误
        """
        raise ValueError(msg)

    @staticmethod
    def mock_key_error(key: Any = "missing_key"):
        """
        模拟字典键缺失异常
        """
        raise KeyError(key)

    @staticmethod
    def mock_index_error(index: int = 0):
        """
        模拟列表索引越界
        """
        raise IndexError(f"list index out of range: {index}")

    @staticmethod
    def mock_assertion_error(msg: str = "Assertion failed"):
        """
        模拟断言失败
        """
        raise AssertionError(msg)

    # --- 文件与 IO 异常 ---

    @staticmethod
    def mock_file_not_found(filepath: str = "/tmp/missing.txt"):
        """
        模拟文件未找到
        """
        raise FileNotFoundError(f"[Errno 2] No such file or directory: '{filepath}'")

    @staticmethod
    def mock_permission_denied(filepath: str = "/root/secret.txt"):
        """
        模拟权限拒绝
        """
        raise PermissionError(f"[Errno 13] Permission denied: '{filepath}'")

    # --- 网络与 API 异常 (模拟外部服务) ---

    @staticmethod
    def mock_timeout(seconds: float = 30.0):
        """
        模拟连接超时
        """
        raise TimeoutError(f"Connection timed out after {seconds} seconds")

    @staticmethod
    def mock_connection_refused(port: int = 8080):
        """
        模拟连接被拒绝
        """
        raise ConnectionRefusedError(f"Connection refused on port {port}")

    @staticmethod
    def mock_http_error(status_code: int = 500):
        """
        模拟 HTTP 错误 (需配合 requests 库或自定义异常)
        这里使用通用的 Exception 模拟
        """
        raise Exception(f"HTTP Error {status_code}: Internal Server Error")

    # --- 运行时与随机异常 ---

    @staticmethod
    def mock_runtime_error(msg: str = "Unexpected runtime error"):
        """
        模拟通用运行时错误
        """
        raise RuntimeError(msg)

    @staticmethod
    def mock_random_failure(rate: float = 0.5, msg: str = "Random failure occurred"):
        """
        模拟随机失败
        :param rate: 失败概率 (0.0 - 1.0)
        """
        if random.random() < rate:
            raise RuntimeError(msg)

    @staticmethod
    def mock_slow_down(delay: float = 3.0):
        """
        模拟服务响应过慢 (不抛异常,但模拟卡顿,常用于测试超时逻辑)
        """
        time.sleep(delay)
使用

创建python文件test_exception.py,代码如下:

python 复制代码
from exception_mock_utils import ExceptionMockUtils

exceptionMockUtils = ExceptionMockUtils()
exceptionMockUtils.mock_random_failure()

运行即可。

相关推荐
2301_803875615 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_743623925 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
2401_873479405 小时前
如何利用IP查询定位识别电商刷单?4个关键指标+工具配置方案
开发语言·tcp/ip·php
我爱cope6 小时前
【从0开始学设计模式-10| 装饰模式】
java·开发语言·设计模式
2501_914245936 小时前
CSS如何处理CSS变量作用域冲突_利用特定类名重写变量值
jvm·数据库·python
菜鸟学Python6 小时前
Python生态在悄悄改变:FastAPI全面反超,Django和Flask还行吗?
开发语言·python·django·flask·fastapi
<-->6 小时前
Megatron(全称 Megatron-LM,由 NVIDIA 开发)和 DeepSpeed(由 Microsoft 开发)
人工智能·pytorch·python·深度学习·transformer
测试19987 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
浪浪小洋7 小时前
c++ qt课设定制
开发语言·c++
charlie1145141917 小时前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构