贡献指南
原始页面: https://patroni.readthedocs.io/en/latest/contributing_guidelines.html
在线交流
如有疑问、需要互动式故障排查帮助,或希望与其他 Patroni 用户交流,欢迎加入 PostgreSQL Slack 的 #patroni 频道。
报告缺陷
提交缺陷报告前,请务必在最新版 Patroni 上复现该问题!同时请检查 Issues Tracker 中是否已存在相同问题。
运行测试
运行 behave 测试的前置条件:
- 需要安装包含 contrib 模块的 PostgreSQL 软件包。
- PostgreSQL 二进制文件必须在
PATH中可访问。您可能需要通过类似PATH=/usr/lib/postgresql/11/bin:\$PATH python -m behave的方式将其加入路径。 - 如需测试外部 DCS(如 Etcd、Consul、Zookeeper),需要提前安装相应软件包,并确保对应服务在本地默认端口上以无加密/无认证方式接受连接。对于 Etcd 或 Consul,若相应二进制文件在
PATH中可用,behave 测试套件可以自动启动它们。
安装依赖:
# 可以使用 Virtualenv 或指定 pip3。
pip install -r requirements.txt
pip install -r requirements.dev.txt
安装完所有依赖后,可以运行各类测试套件:
# 可以使用 Virtualenv 或指定 python3。
# 运行 flake8 检查语法和格式:
python setup.py flake8
# 运行 tests/ 目录中的 pytest 套件:
python setup.py test
# 也可以以更细粒度运行测试,便于调试;
# -s 选项会在测试执行期间显示打印输出。
# pytest 测试通常遵循 FILEPATH::CLASSNAME::TESTNAME 的格式。
pytest -s tests/test_api.py
pytest -s tests/test_api.py::TestRestApiHandler
pytest -s tests/test_api.py::TestRestApiHandler::test_do_GET
# 运行 features/ 目录中的 behave(https://behave.readthedocs.io/en/latest/)测试套件;
# 可根据需要修改 DCS(raft 没有外部依赖,最易于上手):
DCS=raft python -m behave
使用 tox 进行测试
运行 tox 测试只需安装一个额外依赖(Python 本身除外):
pip install tox>=4
如需运行 behave 测试,还需要安装 Docker。
tox.ini 中的 tox 配置定义了以下"环境"以执行各类任务:
lint:使用flake8对 Python 代码进行 lint 检查test:使用pytest在所有可用 Python 解释器上运行单元测试,生成 XML 报告;若检测到 TTY 则生成 HTML 报告dep:使用pipdeptree检测软件包依赖冲突type:使用pyright进行静态类型检查black:使用black进行代码格式化docker-build:构建用于behave环境的 Docker 镜像docker-cmd:使用上述镜像运行任意命令docker-behave-etcd:使用上述镜像运行 tox behave 测试py*behave:使用可用的 Python 解释器运行 behave(不使用 Docker,但这正是在 Docker 容器内部调用的方式)docs:使用sphinx构建文档
运行 tox
运行默认环境列表(dep、lint、test 和 docs),直接执行:
tox
可以使用 test 标签运行 test 环境:
tox -m test
可以使用 behave 标签运行 behave Docker 测试:
tox -m behave
类似地,docs 使用 docs 标签。
其他所有环境可通过对应的环境名称运行:
tox -e lint
tox -e py39-test-lin
也可以使用 factors 筛选部分环境列表。例如,若要运行所有 Python 3.10 相关环境:
tox -f py310
这等价于运行以下所有环境:
$ tox -l -f py310
py310-test-lin
py310-test-mac
py310-test-win
py310-type-lin
py310-type-mac
py310-type-win
py310-behave-etcd-lin
py310-behave-etcd-win
py310-behave-etcd-mac
可以使用 tox(>= v4)列出所有已配置的环境组合:
tox l
当 tox 在有活跃终端的情况下运行时,test 和 docs 环境在任务完成后会尝试自动打开 HTML 输出文件,方便本地开发人员查看。在 macOS 上会调用 open 命令,在 Linux 上会调用 xdg-open。如需使用其他命令,可将环境变量 OPEN_CMD 设置为该命令的名称或路径。即使此步骤失败,也不会影响整体构建结果。如需禁用此功能,可将 OPEN_CMD 设置为 : 空操作命令。
OPEN_CMD=: tox -m docs
Behave 测试
使用 -m behave 运行 behave 测试时,将基于 PG_MAJOR 版本 11 到 16 构建 Docker 镜像,然后运行所有 behave 测试。这可能需要相当长的时间,因此您可能希望将范围限制为特定的 PostgreSQL 版本或特定的功能集。
若要指定 PostgreSQL 版本,请同时指定所需的镜像构建环境和 behave 环境名称。例如,若要测试 PostgreSQL 14,请使用:
tox -e pg14-docker-build,pg14-docker-behave-etcd-lin
如果只想测试特定功能,可以向 behave 传递位置参数。以下命令将针对所有 PostgreSQL 版本运行 watchdog behave 功能测试场景:
tox -m behave -- features/watchdog.feature
当然,您也可以将上述两种方式结合使用。
提交 Pull Request
- Fork 仓库,在本地开发并测试您的代码变更。
- 在用户文档中同步反映相关变更。
- 提交 Pull Request,并清晰描述本次变更的目标。如涉及已有 Issue,请关联该 Issue。
我们将尽快为您的 Pull Request 提供反馈。
祝 Patroni 开发愉快 ;-)