python - 为什么 pytest 中的列表与控制台的输出不同?
问题描述
我正在编写 100 天的代码。其中一个项目是在选择的项目上实施 pytest。我选择了一个以前的项目,它采用定义的汽车品牌和型号字典,并将输出返回到各种问题。我已经为其中两个功能编写了单元测试,但它们都失败了。
从控制台运行该函数的代码get_all_jeeps()
将返回:
大切诺基、切诺基、Trailhawk、Trackhawk
如果我使用以下代码运行 pytest:
def test_get_all_jeeps():
expected = 'Grand Cherokee, Cherokee, Trailhawk, Trackhawk'
actual = get_all_jeeps()
assert type(actual) == str
assert actual == expected
它失败了,因为 pytests 输出看起来正在排序。为什么会这样做?
E AssertionError: assert 'Cherokee, Gr...wk, Trailhawk' == 'Grand Cherokee...wk, Trackhawk'
E - Cherokee, Grand Cherokee, Trackhawk, Trailhawk
E + Grand Cherokee, Cherokee, Trailhawk, Trackhawk
另一个测试是从控制台运行时给出不同的输出。该函数的控制台输出get_first_model_each_manufacturer()
为:
[“猎鹰”、“准将”、“千里马”、“思域”、“大切诺基”]
除非它失败了pytest:
def test_get_first_model_each_manufacturer():
expected = ['Falcon', 'Commodore', 'Maxima', 'Civic', 'Grand Cherokee']
actual = get_first_model_each_manufacturer()
assert type(actual) == list
> assert actual == expected
E AssertionError: assert ['Fairlane', ...', 'Cherokee'] == ['Falcon', 'Co...and Cherokee']
E on index 0 diff: 'Fairlane' != 'Falcon'
E Use -v to get the full diff
项目“Fairlane”是如何到达那里的?pytest 有什么不同?
在这里回购https://github.com/cadamei/100daysofcode/tree/master/days/10-12-pytest
所有函数都使用这个字典作为数据:
cars = {
'Ford': ['Falcon', 'Focus', 'Festiva', 'Fairlane'],
'Holden': ['Commodore', 'Captiva', 'Barina', 'Trailblazer'],
'Nissan': ['Maxima', 'Pulsar', '350Z', 'Navara'],
'Honda': ['Civic', 'Accord', 'Odyssey', 'Jazz'],
'Jeep': ['Grand Cherokee', 'Cherokee', 'Trailhawk', 'Trackhawk']
解决方案
您的 cars.py 脚本正在修改列表,因为它print(sort_car_models())
在导入时正在运行,删除这些行或将它们放入if __name__ == '__main__':
要了解更多信息,请查看What does if __name__ == "__main__": do?
推荐阅读
- .net - 在终端中调试 dotnet 核心程序
- python - 计算 txt 文件中每一行的出现次数并将它们保存到 Python 中的矩阵中
- javascript - Java 脚本闭包 - 本地绑定结果不是我所期望的
- angular - 如何在猫鼬的查询中应用?
- getdate - 如何在 SSRS 中使用 getdate() 而不包括周末和节假日
- php - 如何根据用户使用 PHP 的操作来增加变量
- python - 如何根据嵌套字典中的子值计算父字典值
- python - Matplotlib 绘制不同颜色的多边形
- c# - 自动映射器根据枚举值映射某些布尔属性
- javascript - 如何将href链接限制为
标签