全部学科
Python全栈
python
NodeJS全栈
nodejs
小程序首页
📝 1 篇文章 20 道配套习题

测试与调试专题

专题说明

测试与调试是保障代码质量的关键环节。本专题从unittest单元测试框架出发,深入讲解断言方法、mock技术、pytest框架的使用、代码覆盖率分析、日志配置以及Python内置调试工具,帮助学习者建立完整的测试和调试能力体系。

学习目标

  1. 掌握unittest单元测试框架的使用方法
  2. 熟练使用各种断言方法验证代码正确性
  3. 理解mock的原理和使用场景
  4. 掌握pytest框架的核心特性和fixture
  5. 了解代码覆盖率分析和调试工具的使用

学习内容

本专题涵盖以下核心知识点:

单元测试基础

  • unittest框架结构
  • TestCase编写规范
  • setUp和tearDown
  • 测试发现与执行

断言方法

  • 基本断言:assertEqual、assertTrue等
  • 集合断言:assertListEqual、assertDictEqual
  • 异常断言:assertRaises
  • 浮点数断言:assertAlmostEqual

Mock技术

  • unittest.mock模块
  • patch装饰器和上下文管理器
  • Mock对象的属性和方法
  • 模拟返回值和副作用

pytest框架

  • pytest安装和基本用法
  • fixture固定装置
  • parametrize参数化测试
  • conftest.py配置

代码覆盖率

  • coverage.py工具
  • 覆盖率报告生成
  • 分支覆盖率
  • 覆盖率阈值配置

调试技术

  • print调试法
  • logging日志模块
  • pdb调试器
  • IDE调试功能

学习建议

  1. 先掌握unittest基础,再学习pytest
  2. 理解mock的使用场景,避免过度mock
  3. 重视测试覆盖率,但不是越高越好
  4. 调试时善用pdb和日志,提高排错效率

📝 发现内容有误?点击此处直接编辑

📝 配套习题(20 题)

1
判断题

Python的logging模块提供了灵活的日志记录功能,支持多种日志级别(DEBUG、INFO、WARNING、ERROR、CRITICAL)和多种输出方式(文件、控制台、网络等)。

A

B

2
单选题

设置日志级别为INFO后,以下哪个日志消息不会被输出?

A

logging.debug('message')

B

logging.info('message')

C

logging.warning('message')

D

logging.error('message')

3
填空题

logging有5个级别:______(调试)、______(一般)、_______(警告)、______(错误)、________(严重)。basicConfig设置______参数指定最低输出级别,________参数指定输出文件,______参数指定日志格式。

4
判断题

生产环境日志最佳实践包括:使用合适的日志级别、结构化日志格式、避免记录敏感信息、配置日志轮转防止文件过大、集中存储便于分析。

A

B

5
单选题

RotatingFileHandler的作用是:

A

按天分割日志文件

B

按大小轮转日志文件,超过限制创建新文件

C

同时输出到多个文件

D

发送日志到远程服务器

6
填空题

RotatingFileHandler按______轮转日志,参数________设置最大大小,___________设置保留备份数。TimedRotatingFileHandler按______轮转,when='________'每天午夜轮转。避免记录______信息。使用______格式便于分析。

7
判断题

cProfile模块用于分析Python程序的性能,统计各函数的调用次数和执行时间;timeit模块用于精确测量小段代码的执行时间。

A

B

8
单选题

cProfile分析结果中的"cumtime"表示:

A

函数本身的执行时间

B

函数及其调用的所有函数的总时间

C

函数被调用的次数

D

函数单次调用的平均时间

9
填空题

cProfile.run('______()')分析函数性能。ncalls表示________,tottime表示函数______执行时间,_______表示累计时间(含______)。timeit.timeit('code', ______=n)测量代码______次的执行______

10
判断题

unittest是Python内置的单元测试框架,测试类继承unittest.TestCase,测试方法以test开头,使用assertEqual等断言方法验证结果。

A

B

11
单选题

unittest测试类中,以下哪个方法会被自动执行为测试?

A

def add_test(self):

B

def test_add(self):

C

def TestAdd(self):

D

def testing_add(self):

12
填空题

unittest测试类继承________,测试方法以______开头。self.___________(a, b)断言相等,self.__________(x)断言为真,self.________(a, b)断言包含,self.____________(exc)断言抛出异常。运行测试用_____________()。

13
判断题

pytest是Python流行的第三方测试框架,语法简洁,测试函数无需继承类,直接使用普通assert语句即可,支持参数化测试和丰富的插件生态。

A

B

14
单选题

pytest相比unittest的主要优势是:

A

pytest是内置模块,unittest需要安装

B

pytest直接使用assert语句,语法更简洁

C

pytest只能测试函数,不能测试类

D

unittest性能更好

15
填空题

pytest测试函数以______开头,直接使用______语句断言。运行测试用______命令。参数化测试用___________装饰器。fixture用_______________定义。pytest需要______安装,语法比unittest更______

16
判断题

Python的assert语句用于调试时检查条件,如果条件为False则抛出AssertionError异常,可用于测试代码验证预期结果。

A

B

17
单选题

执行assert 5 > 10会发生什么?

A

返回False

B

返回None

C

抛出AssertionError异常

D

正常执行,无输出

18
填空题

assert语句检查条件,条件为______时抛出______________异常。pytest直接使用______断言。unittest使用self.___________()断言相等,self.__________()断言为真,self.____________()断言抛出异常。python ______选项可禁用assert。

19
判断题

coverage是Python的代码覆盖率分析工具,可以统计测试过程中执行的代码行数比例,帮助发现未被测试覆盖的代码路径。

A

B

20
单选题

使用coverage分析pytest测试覆盖率,正确的命令顺序是:

A

coverage report && coverage run -m pytest

B

coverage run -m pytest && coverage report

C

pytest && coverage html

D

coverage pytest && coverage report

← 上一个专题 流程控制专题
下一个专题 → 生态与工具链专题

📝 发现内容有误?点击此处直接编辑

想查看更多习题和详细解析?
小程序提供完整的题库和详细解析

长按或扫描二维码,立即体验

扫码体验小程序
马上就来
使用微信扫描二维码
立即体验完整题库