首页
/ Python Unit Test Reporting to TeamCity 技术文档

Python Unit Test Reporting to TeamCity 技术文档

2024-12-26 09:21:11作者:何举烈Damon

本文档旨在帮助用户了解如何使用 teamcity-messages 项目,将 Python 单元测试结果报告到 TeamCity 持续集成服务器。文档内容包括安装指南、使用说明、API 使用文档以及项目安装方式。

1. 安装指南

使用 pip 安装

你可以通过 pip 命令安装 teamcity-messages 包:

pip install teamcity-messages

从源码安装

你也可以从源码安装该项目:

python setup.py install

2. 项目的使用说明

teamcity-messages 包通过发送服务消息来向 TeamCity 报告构建状态。以下是如何在不同测试框架中使用该包的说明。

unittest

如果你使用 Python 自带的 unittest 框架,可以通过修改测试运行器来集成 TeamCity 报告功能:

import unittest
from teamcity import is_running_under_teamcity
from teamcity.unittestpy import TeamcityTestRunner

class Test(unittest.TestCase):
    ...

if __name__ == '__main__':
    if is_running_under_teamcity():
        runner = TeamcityTestRunner()
    else:
        runner = unittest.TextTestRunner()
    unittest.main(testRunner=runner)

你也可以在命令行中使用以下命令来运行测试:

python -m teamcity.unittestpy

nose

在 TeamCity 构建环境下,nose 的测试状态报告会自动启用。

py.test

在 TeamCity 构建环境下,py.test 的测试状态报告会自动启用。

Django

对于 Django 1.6+,你可以在 settings.py 中修改 TEST_RUNNER 设置,使用 TeamcityDjangoRunner 替代默认的 DiscoverRunner

TEST_RUNNER = "teamcity.django.TeamcityDjangoRunner"

flake8

在 TeamCity 构建环境下,flake8 的测试状态报告会自动启用。

PyLint

在运行 pylint 时,添加 --output-format=teamcity.pylint_reporter.TeamCityReporter 参数:

pylint --output-format=teamcity.pylint_reporter.TeamCityReporter

tox

tox 的测试虚拟环境中传递 TEAMCITY_VERSION 环境变量:

[testenv]
passenv = TEAMCITY_VERSION

Twisted trial

在运行 trial 时,添加 --reporter=teamcity 参数:

trial --reporter=teamcity

Behave

对于 Behave 1.2.6,你可以通过以下代码启用 TeamCity 报告:

from behave.formatter import _registry
from behave.configuration import Configuration
from behave.runner import Runner
from teamcity.jb_behave_formatter import TeamcityFormatter

_registry.register_as("TeamcityFormatter", TeamcityFormatter)
configuration = Configuration()
configuration.format = ["TeamcityFormatter"]
configuration.stdout_capture = False
configuration.stderr_capture = False
Runner(configuration).run()

3. 项目 API 使用文档

teamcity-messages 提供了以下主要 API:

  • is_running_under_teamcity(): 检查当前是否在 TeamCity 环境下运行。
  • TeamcityTestRunner: 用于 unittest 框架的测试运行器。
  • TeamcityDjangoRunner: 用于 Django 的测试运行器。
  • TeamcityFormatter: 用于 Behave 的格式化器。

4. 项目安装方式

使用 pip 安装

pip install teamcity-messages

从源码安装

python setup.py install

通过以上步骤,你可以成功安装并使用 teamcity-messages 包,将 Python 单元测试结果报告到 TeamCity 持续集成服务器。

热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
373
72
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
276
72
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
200
47
xzs-mysqlxzs-mysql
学之思开源考试系统是一款 java + vue 的前后端分离的考试系统。主要优点是开发、部署简单快捷、界面设计友好、代码结构清晰。支持web端和微信小程序,能覆盖到pc机和手机等设备。 支持多种部署方式:集成部署、前后端分离部署、docker部署
HTML
5
1
LangChatLangChat
LangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用
Java
11
3
gin-vue-admingin-vue-admin
🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能。
Go
16
3
source-vuesource-vue
🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...
Java
24
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
898
0
madongmadong
基于Webman的权限管理系统
PHP
4
0
cool-admin-javacool-admin-java
🔥 cool-admin(java版)一个很酷的后台权限管理框架,Ai编码、流程编排、模块化、插件化、CRUD极速开发,永久开源免费,基于springboot3、typescript、vue3、vite、element-ui等构建
Java
18
2