
poetry的`new`命令自2021年4月起已变更其项目初始化行为。现在,执行`poetry new`不再自动创建`test_*.py`测试文件,并且`__init__.py`文件默认为空。这一变化旨在提供更灵活的初始化方式,开发者应参照最新官方文档,并根据项目需求手动配置测试结构,以确保项目遵循最新的最佳实践。
Poetry作为一款现代化的Python依赖管理和项目打包工具,以其简洁高效的特性受到了广大开发者的青睐。然而,随着其版本的迭代,某些默认行为也发生了变化。其中一个显著的改变是关于poetry new命令在项目初始化时对测试文件和__init__.py文件的处理。
在此前的版本中,当开发者使用poetry new <project-name>命令创建一个新的Poetry项目时,它会自动生成一个基本的测试文件(例如tests/test_<project-name>.py)以及非空的__init__.py文件。这一设计旨在为新项目提供一个即开即用的测试结构。
然而,自2021年4月起,Poetry的这一默认行为已被修改。此项变更(具体可追溯到此提交)旨在提供更灵活的项目初始化方式。现在,执行poetry new命令后:
这一变化意味着Poetry在项目初始化时更加“轻量化”和“不干预”,将测试结构的搭建和__init__.py文件的具体内容留给开发者根据实际需求自行决定。
鉴于上述行为变更,开发者在初始化Poetry项目时应注意以下几点:
首先,像往常一样使用poetry new命令创建新项目:
poetry new my-new-project
执行此命令后,my-new-project的目录结构将如下所示:
my-new-project/
├── pyproject.toml
├── README.md
├── my_new_project/
│ └── __init__.py # 此文件将为空
└── tests/
└── __init__.py # 此文件将为空可以看到,tests/目录下没有自动生成的测试文件。
如果项目需要测试,开发者需要手动创建测试文件并配置测试框架(如pytest)。
步骤示例:
安装测试框架: 通常,pytest是一个流行的选择。通过Poetry将其添加到开发依赖中:
cd my-new-project poetry add pytest --group dev
或者在pyproject.toml中手动添加:
[tool.poetry.group.dev.dependencies] pytest = "^7.0" # 根据需要选择版本
然后运行 poetry install。
创建测试文件: 在tests/目录下手动创建测试文件,例如tests/test_example.py:
# tests/test_example.py
from my_new_project import __version__
def test_version():
assert __version__ == "0.1.0" # 假设你在pyproject.toml中定义了版本运行测试: 使用Poetry运行测试:
poetry run pytest
对于__init__.py文件,如果需要定义包的版本或其他元数据,应手动添加。例如,在my_new_project/__init__.py中:
# my_new_project/__init__.py __version__ = "0.1.0"
这与Poetry早期版本自动填充版本号的行为不同,现在需要开发者自行管理。
Poetry new 命令的行为变更是一项旨在提升工具灵活性的设计决策。开发者现在需要更加主动地配置项目的测试环境和__init__.py文件内容。通过理解这些变化并遵循最新的官方文档和最佳实践,可以确保您的Poetry项目始终保持健康、高效且易于维护。
以上就是Poetry new 命令行为变更:项目初始化不再自动生成测试文件的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号