测试与调试专项测试
考察知识点
- unittest模块:TestCase类、断言方法、测试套件
- pytest框架:pytest语法、fixture、参数化测试
- 调试技巧:pdb调试器、断点设置、变量检查
- 日志记录:logging模块、日志级别、日志配置
Python的logging模块提供了灵活的日志记录功能,支持多种日志级别(DEBUG、INFO、WARNING、ERROR、CRITICAL)和多种输出方式(文件、控制台、网络等)。
设置日志级别为INFO后,以下哪个日志消息不会被输出?
logging有5个级别:______(调试)、______(一般)、_______(警告)、______(错误)、________(严重)。basicConfig设置______参数指定最低输出级别,________参数指定输出文件,______参数指定日志格式。
生产环境日志最佳实践包括:使用合适的日志级别、结构化日志格式、避免记录敏感信息、配置日志轮转防止文件过大、集中存储便于分析。
RotatingFileHandler的作用是:
RotatingFileHandler按______轮转日志,参数________设置最大大小,___________设置保留备份数。TimedRotatingFileHandler按______轮转,when='________'每天午夜轮转。避免记录______信息。使用______格式便于分析。
cProfile模块用于分析Python程序的性能,统计各函数的调用次数和执行时间;timeit模块用于精确测量小段代码的执行时间。
cProfile分析结果中的"cumtime"表示:
cProfile.run('______()')分析函数性能。ncalls表示________,tottime表示函数______执行时间,_______表示累计时间(含______)。timeit.timeit('code', ______=n)测量代码______次的执行______。
unittest是Python内置的单元测试框架,测试类继承unittest.TestCase,测试方法以test开头,使用assertEqual等断言方法验证结果。
unittest测试类中,以下哪个方法会被自动执行为测试?
unittest测试类继承________,测试方法以______开头。self.___________(a, b)断言相等,self.__________(x)断言为真,self.________(a, b)断言包含,self.____________(exc)断言抛出异常。运行测试用_____________()。
pytest是Python流行的第三方测试框架,语法简洁,测试函数无需继承类,直接使用普通assert语句即可,支持参数化测试和丰富的插件生态。
pytest相比unittest的主要优势是:
pytest测试函数以______开头,直接使用______语句断言。运行测试用______命令。参数化测试用___________装饰器。fixture用_______________定义。pytest需要______安装,语法比unittest更______。
Python的assert语句用于调试时检查条件,如果条件为False则抛出AssertionError异常,可用于测试代码验证预期结果。
执行assert 5 > 10会发生什么?
assert语句检查条件,条件为______时抛出______________异常。pytest直接使用______断言。unittest使用self.___________()断言相等,self.__________()断言为真,self.____________()断言抛出异常。python ______选项可禁用assert。
coverage是Python的代码覆盖率分析工具,可以统计测试过程中执行的代码行数比例,帮助发现未被测试覆盖的代码路径。
使用coverage分析pytest测试覆盖率,正确的命令顺序是:
📝 发现内容有误?点击此处直接编辑
长按或扫描二维码,立即体验