• 纵横交织的功能的单元测试


    在编写纵横交织的功能的单元测试时,你需要确保你的测试覆盖了各种情况和交互。这通常包括测试各个功能模块的单元,以及确保它们与其他模块的交互正常。而且在我们实际操作中会遇到这种各样的问题,下面的解决方法可得好好看看。

    在这里插入图片描述

    1、问题背景

    软件开发中,我们经常会遇到一些纵横交织的功能,比如日志记录、安全等。这些功能通常在应用程序中无处不在,因此很难对它们进行单元测试。

    例如,假设我们正在使用Python编写一个Cherrypy web服务器。我们可以使用装饰器来检查登录用户是否具有访问特定页面的权限。但是,这样我们就需要为每个页面编写一个测试,以查看它是否工作正常(或者更确切地说,是为了查看我们是否忘记为该页面检查安全权限)。

    如果在web服务器的“正常业务实现”过程中实现了日志记录和/或安全,那么这种情况可能(强调可能)是可以忍受的。然而,安全和日志记录通常会在应用程序中添加一个作为事后附加的(或者也许这只是我的经验,我通常会被告知一个服务器,然后要求我实现安全模型)。

    对于这个问题,任何想法都非常受欢迎。我目前“解决”了这个问题,嗯——根本不测试它。

    2、解决方案

    对于纵横交织的功能的单元测试,我们可以采用以下解决方案:

    1. 覆盖装饰器用单元测试

    对于装饰器,我们可以先写一个测试函数,然后使用 @decorator 装饰器来装饰这个函数。这样,当我们运行测试函数时,装饰器也会被执行,从而我们可以测试装饰器是否工作正常。

    1. 使用桩(stub)来测试日志记录

    对于日志记录,我们可以使用桩(stub)来模拟日志记录功能。这样,当我们运行测试函数时,日志记录功能不会被实际执行,而是会被桩所替代。我们可以通过检查桩来验证日志记录功能是否工作正常。

    1. 使用模拟(mock)来测试安全

    对于安全,我们可以使用模拟(mock)来模拟安全功能。这样,当我们运行测试函数时,安全功能不会被实际执行,而是会被模拟所替代。我们可以通过检查模拟来验证安全功能是否工作正常。

    以下是一个使用桩来测试日志记录的代码示例:

    import unittest
    import logging
    
    class LoggingTest(unittest.TestCase):
    
        def setUp(self):
            self.logger = logging.getLogger(__name__)
    
            # 创建一个桩来模拟日志记录功能
            self.log_patcher = unittest.mock.patch('logging.Logger.info')
            self.log_patcher.start()
    
        def tearDown(self):
            # 停止桩
            self.log_patcher.stop()
    
        def test_logging(self):
            # 调用日志记录功能
            self.logger.info('Hello, world!')
    
            # 检查桩是否被调用
            self.log_patcher.assert_called_once_with('Hello, world!')
    '
    运行

    以下是一个使用模拟来测试安全的代码示例:

    import unittest
    import security
    
    class SecurityTest(unittest.TestCase):
    
        def setUp(self):
            # 创建一个模拟来模拟安全功能
            self.security_patcher = unittest.mock.patch('security.check_access')
            self.security_patcher.start()
    
        def tearDown(self):
            # 停止模拟
            self.security_patcher.stop()
    
        def test_security(self):
            # 调用安全功能
            security.check_access('user1', 'page1')
    
            # 检查模拟是否被调用
            self.security_patcher.assert_called_once_with('user1', 'page1')
    

    在这个示例中,我们使用了 patch 装饰器来模拟 get_employee_infosend_email 函数,以确保测试是独立的。然后我们编写了一个测试用例来测试 calculate_salary 函数的行为,并验证了它的正确性以及与其他模块的交互。

    如有任何代码问题可以附上截图,看见我会一一解答的。

  • 相关阅读:
    vue + Lodop打印控件的使用
    d的整与nan
    查看docker容器中java进程堆栈信息
    Elasticsearch概述
    MySQL---使用索引优化、大批量插入数据优化
    SpringSecurity源码学习二:异常处理
    每日一练<4>
    SpringSecurity用户授权
    真棒啊,Facebook 官方推出一个模型解释 & 可视化工具 Captum
    Python 操作 MongoDB 数据库介绍
  • 原文地址:https://blog.csdn.net/weixin_44617651/article/details/138943116