首页 后端开发 Python教程 像专业人士一样使用 Poetry、Tox、Nox 和 CI/CD 测试 Python 代码

像专业人士一样使用 Poetry、Tox、Nox 和 CI/CD 测试 Python 代码

Jan 07, 2025 am 07:07 AM

嘿那里!

有一个 Python 项目并需要确保它适用于 Python 的每个版本?相信我,这可能会让人非常头疼。但别担心,我会支持你的。在本指南中,我将向您展示如何使用 ToxNoxCI/CD 这些很棒的工具来跨多个 Python 版本测试您的代码。

你猜怎么着?这比你想象的要容易。

当您读完本文时,您将像专业人士一样在 Python 3.8 到 3.13 上运行测试。我们会让事情变得简单、有趣并且完全可行。听起来不错吗?让我们深入了解一下。


为什么你应该关心多版本测试?

想象一下:您编写了一些很酷的 Python 代码,并且它可以在您的计算机上运行。但随后,嘭!一位用户给您发电子邮件,说它在 Python 3.9 上崩溃了。你尝试了一下,果然出了问题。

为什么?

因为Python有所有这些版本,并且每个版本都有其怪癖。如果你不在多个版本上测试你的代码,那么你就是盲目的。

但好消息是,您不必手动安装一堆 Python 版本并对每个版本运行测试。这就是 Tox 和 Nox 像超级英雄一样突然出现的地方。


什么是Tox和Nox?

让我们来分解一下:

  • Tox:将其视为在不同 Python 环境中测试代码的机器人。它组织得非常好,并遵循简单的 tox.ini 文件中的指令。你告诉 Tox 做什么,它就会这么做。

  • Nox:它就像 Tox,但在某些方面更酷。为什么?因为您不需要编写配置文件,而是编写 Python 脚本 (noxfile.py)。想要添加自定义逻辑或条件? Nox 为您提供支持。

那么哪个更好呢?老实说,这取决于。如果您喜欢简洁明了的事物,请选择 Tox。如果您是创意型人士并且喜欢灵活性,Nox 就是您的选择。


让我们构建一些很酷的东西

这是交易:

我们将创建一个具有两个简单功能的迷你项目:

  • 添加两个数字。
  • 用一个数字减去另一个数字。

我们将编写一些测试来确保它们工作,然后我们将使用 Tox 和 Nox 在 Python 版本 3.8 到 3.13 上测试它们。

听起来很有趣,对吧?

这是我们正在使用的文件结构:

tox-nox-python-test-automation/
├── tox_nox_python_test_automation/
│   ├── __init__.py
│   ├── main.py
│   └── calculator.py
├── tests/
│   ├── __init__.py
│   └── test_calculator.py
├── pyproject.toml
├── tox.ini
├── noxfile.py
├── README.md
登录后复制
登录后复制

第 1 步:编写代码

这是我们的calculator.py

def add(a, b):
    """Returns the sum of two numbers."""
    return a + b

def subtract(a, b):
    """Returns the difference of two numbers."""
    return a - b
登录后复制
登录后复制

简单吧?让我们保持这样吧。


第 2 步:编写一些测试

是时候确保我们的代码有效了。这是我们的test_calculator.py

tox-nox-python-test-automation/
├── tox_nox_python_test_automation/
│   ├── __init__.py
│   ├── main.py
│   └── calculator.py
├── tests/
│   ├── __init__.py
│   └── test_calculator.py
├── pyproject.toml
├── tox.ini
├── noxfile.py
├── README.md
登录后复制
登录后复制

我们正在使用pytest,这是一个测试工具,基本上是 Python 测试的 MVP。如果您从未使用过它,请不要担心,它非常容易上手。


第三步:用 Poetry 管理依赖关系

好的,那么我们如何确保参与该项目的每个人都使用相同的依赖项?我们使用 Poetry,它就像一个增压的 requests.txt 文件。

这是我们的 pyproject.toml 的样子:

def add(a, b):
    """Returns the sum of two numbers."""
    return a + b

def subtract(a, b):
    """Returns the difference of two numbers."""
    return a - b
登录后复制
登录后复制

要安装所有内容,只需运行:

import pytest
from tox_nox_python_test_automation.calculator import add, subtract

@pytest.mark.parametrize("a, b, expected", [
    (1, 2, 3),
    (-1, 1, 0),
    (0, 0, 0),
])
def test_add(a, b, expected):
    assert add(a, b) == expected

@pytest.mark.parametrize("a, b, expected", [
    (5, 3, 2),
    (10, 5, 5),
    (-1, -1, 0),
])

def test_subtract(a, b, expected):
    assert subtract(a, b) == expected
登录后复制

第 4 步:使用 Pytest 运行单元测试

您可以这样运行基本单元测试:

[tool.poetry]
name = "tox_nox_python_tests"
version = "0.1.0"
description = "Testing with multiple Python versions using Tox and Nox."
authors = ["Wallace Espindola <wallace.espindola@gmail.com>"]
license = "MIT"

[tool.poetry.dependencies]
python = "^3.8"
pytest = "^8.3"
nox = "^2024.10.9"
tox = "^4.23.2"
登录后复制

并且将看到标准单元测试运行输出。


第 5 步:使用 Tox 进行测试

Tox 就是自动化。这是我们的tox.ini

poetry install
登录后复制

使用一个命令运行 Tox:

poetry run pytest --verbose
登录后复制

繁荣! Tox 将在列出的每个 Python 版本上测试您的代码。请参阅此处的示例输出:

Test Python Code Like a Pro with Poetry, Tox, Nox and CI/CD


第 6 步:使用 Nox 进行测试

想要更多控制权? Nox 让您发挥创意。这是我们的noxfile.py

[tox]
envlist = py38, py39, py310, py311, py312, py313

[testenv]
allowlist_externals = poetry
commands_pre =
    poetry install --no-interaction --no-root
commands =
    poetry run pytest
登录后复制

运行 Nox:

poetry run tox
登录后复制

现在您可以完全灵活地添加逻辑、跳过环境或执行您需要的任何其他操作。请参阅此处的示例输出:

Test Python Code Like a Pro with Poetry, Tox, Nox and CI/CD


第 7 步:使用 CI/CD 实现自动化

为什么要停止本地测试?让我们将其设置为在 GitHub Actions 和 GitLab CI/CD 上自动运行。

GitHub 操作

这是一个工作流程文件.github/workflows/python-tests.yml:

import nox

@nox.session(python=["3.8", "3.9", "3.10", "3.11", "3.12", "3.13"])
def tests(session):
    session.install("poetry")
    session.run("poetry", "install", "--no-interaction", "--no-root")
    session.run("pytest")
登录后复制

GitLab CI/CD

这是一个 .gitlab-ci.yml:

poetry run nox
登录后复制

让我们总结一下

你做到了!您现在知道如何使用 Tox、Nox 和 Poetry 跨多个版本测试 Python 代码。

以下是要记住的内容:

  1. Tox 是您进行简单自动化测试的首选。
  2. Nox 让您可以自由定制。
  3. Poetry 使管理依赖关系变得轻而易举。
  4. CI/CD 确保您的测试自动运行。

当然是参考资料

此项目使用 ToxNoxPoetryPytest 进行测试自动化。详细文档请查看:

毒性文档
Nox 文档
诗歌文献
Pytest 文档


需要完整的代码和示例吗?查看 GitHub 上的存储库:tox-nox-python-tests。

有关其他有趣的主题和技术讨论,请查看我的 LinkedIn 页面。

现在就出去让你的 Python 项目防弹吧! ?

以上是像专业人士一样使用 Poetry、Tox、Nox 和 CI/CD 测试 Python 代码的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1665
14
CakePHP 教程
1424
52
Laravel 教程
1322
25
PHP教程
1270
29
C# 教程
1249
24
Python vs.C:申请和用例 Python vs.C:申请和用例 Apr 12, 2025 am 12:01 AM

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。 Python以简洁和强大的生态系统着称,C 则以高性能和底层控制能力闻名。

Python:游戏,Guis等 Python:游戏,Guis等 Apr 13, 2025 am 12:14 AM

Python在游戏和GUI开发中表现出色。1)游戏开发使用Pygame,提供绘图、音频等功能,适合创建2D游戏。2)GUI开发可选择Tkinter或PyQt,Tkinter简单易用,PyQt功能丰富,适合专业开发。

Python与C:学习曲线和易用性 Python与C:学习曲线和易用性 Apr 19, 2025 am 12:20 AM

Python更易学且易用,C 则更强大但复杂。1.Python语法简洁,适合初学者,动态类型和自动内存管理使其易用,但可能导致运行时错误。2.C 提供低级控制和高级特性,适合高性能应用,但学习门槛高,需手动管理内存和类型安全。

Python和时间:充分利用您的学习时间 Python和时间:充分利用您的学习时间 Apr 14, 2025 am 12:02 AM

要在有限的时间内最大化学习Python的效率,可以使用Python的datetime、time和schedule模块。1.datetime模块用于记录和规划学习时间。2.time模块帮助设置学习和休息时间。3.schedule模块自动化安排每周学习任务。

Python vs.C:探索性能和效率 Python vs.C:探索性能和效率 Apr 18, 2025 am 12:20 AM

Python在开发效率上优于C ,但C 在执行性能上更高。1.Python的简洁语法和丰富库提高开发效率。2.C 的编译型特性和硬件控制提升执行性能。选择时需根据项目需求权衡开发速度与执行效率。

Python:自动化,脚本和任务管理 Python:自动化,脚本和任务管理 Apr 16, 2025 am 12:14 AM

Python在自动化、脚本编写和任务管理中表现出色。1)自动化:通过标准库如os、shutil实现文件备份。2)脚本编写:使用psutil库监控系统资源。3)任务管理:利用schedule库调度任务。Python的易用性和丰富库支持使其在这些领域中成为首选工具。

Python标准库的哪一部分是:列表或数组? Python标准库的哪一部分是:列表或数组? Apr 27, 2025 am 12:03 AM

pythonlistsarepartofthestAndArdLibrary,herilearRaysarenot.listsarebuilt-In,多功能,和Rused ForStoringCollections,而EasaraySaraySaraySaraysaraySaraySaraysaraySaraysarrayModuleandleandleandlesscommonlyusedDduetolimitedFunctionalityFunctionalityFunctionality。

学习Python:2小时的每日学习是否足够? 学习Python:2小时的每日学习是否足够? Apr 18, 2025 am 12:22 AM

每天学习Python两个小时是否足够?这取决于你的目标和学习方法。1)制定清晰的学习计划,2)选择合适的学习资源和方法,3)动手实践和复习巩固,可以在这段时间内逐步掌握Python的基本知识和高级功能。

See all articles