可测试代码的核心是确定性、独立性与易隔离性:函数输入相同则输出固定,不依赖外部状态;业务逻辑与数据库、网络等副作用操作分离;通过依赖注入传入“能干活的对象”,避免硬编码;函数无副作用、纯返回结果;合理拆分粒度,单一职责。
写出可测试的代码,核心是让函数或类的行为**确定、独立、易隔离**——不依赖外部状态(如文件、网络、全局变量),输入相同则输出固定,副作用可控。
数据库操作、HTTP 请求、读写文件这些容易出错且慢的操作,应该从核心逻辑中抽离出来。用参数传入“能干活的对象”,而不是在函数里直接调用 requests.get 或 open()。
user_repo 对象,由它提供 get_user(id) 方法
def add_item(items, new_item): items.append(new_item) —— 修改原列表,测试得先备份def add_item(items, new_item): return items + [new_item] —— 输入不变,输出明确,一行就能测类内部不要直接实例化下游服务,而是通过构造函数或方法参数接收。这样单元测试时可以轻松替换为测试替身(stub/mock/fake)。
self.emailer = EmailService()
def __init__(self, emailer: EmailerProtocol),测试时传个 DummyEmailer 记录是否被调用即可一个函数只做一件事,且这件事足够小。太大的函数难以覆盖所有分支,也难定位失败原因。
validate_order()、reserve_inventory()、charge_payment() 等独立单元