Skip to main content

XMind2Cases基于Python实现,提供了一个高效测试用例设计的解决方案!

Project description

XMind2Cases

高效测试用例设计解决方案

PyPI version Python Versions License Downloads

功能特性快速开始使用指南API 文档更新日志


🚀 快速开始

一键启动

macOS/Linux 用户:

# 1. 克隆项目
git clone https://github.com/koco-co/xmind2cases.git
cd xmind2cases

# 2. 一键启动(自动安装 uv、配置依赖并启动 Web 工具)
./init.sh

Windows 用户:

# 方式 1: 双击运行(推荐)
# 双击 init.bat 文件即可

# 方式 2: 命令行运行
init.bat

✨ 脚本会自动:

  • ✅ 检测并安装 uv(极速 Python 包管理器)
  • ✅ 同步项目依赖
  • ✅ 检测端口占用并提供交互式选项
  • ✅ 启动 Web 工具(http://localhost:5002)

前置要求:

  • 操作系统: macOS、Linux 或 Windows
  • 无需预装 Python: uv 会自动安装 Python 3.12+
  • 无需预装 uv: 脚本会提示自动安装

手动安装

如果你更喜欢手动安装:

# 安装 uv
curl -LsSf https://astral.sh/uv/install.sh | sh  # macOS/Linux
# 或
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"  # Windows

# 同步依赖
uv sync

# 启动 Web 工具
uv run python webtool/application.py  # Flask Web 工具

发布流程

# 完整发布流程(自动测试、构建、发布到 GitHub 和 PyPI)
./init.sh --release

📖 背景

软件测试过程中,最重要、最核心的工作就是测试用例的设计,也是测试团队日常投入最多时间的内容之一。

痛点分析

传统的测试用例设计过程存在诸多痛点:

方式 优点 缺点
Excel 表格 成本低 版本管理麻烦、维护更新耗时、评审繁琐、统计困难
TestLink/TestCenter 管理、执行、统计方便 编写效率不高、思维不够发散、快速迭代中耗时
自研测试管理工具 高度定制 研发维护成本高、技术要求高

解决方案

越来越多的敏捷开发团队选择使用思维导图进行测试用例设计,因为:

  • 发散性思维 - 思维导图的结构与测试用例设计思维高度吻合
  • 图形化展示 - 直观清晰,便于评审和讨论
  • 提升效率 - 大幅提高测试用例设计效率

但同时也带来了新的问题:

  • ❌ 测试用例难以量化管理
  • ❌ 执行情况难以统计
  • ❌ 与 BUG 管理系统难以打通
  • ❌ 团队成员风格各异,沟通成本高

XMind2Cases 的价值

XMind2CasesXMind 设计测试用例的便利性测试用例系统的高效管理 完美结合:

XMind 思维导图 → 通用模板解析 → 多格式输出 → TestLink/禅道/JSON

✨ 功能特性

  • 🎨 可视化设计 - 使用 XMind 进行直观的测试用例设计
  • 🔄 多格式转换 - 支持 TestLink XML、禅道 CSV、JSON 格式
  • 🌐 Web 工具 - 提供便捷的 Web 转换界面
  • 📊 执行统计 - 支持测试用例执行结果标识和统计
  • 🤖 自动/手动 - 支持通过标签设置用例类型
  • 🌍 中文支持 - 导出文件完全支持中文显示
  • 🔧 API 集成 - 提供 Python API 便于集成到其他系统
  • 🔍 智能检测 - 端口占用自动检测并提供交互式解决方案
  • 🎨 现代化 UI - 图标化操作、紧凑布局、长文件名智能截断
  • 🪟 跨平台支持 - 提供 Windows、macOS、Linux 一键启动脚本
  • 🆕 多版本支持 - 同时支持 XMind 8 和 XMind 2026 文件格式

📸 使用示例

Web 工具界面

webtool

转换结果预览

testcase_preview

TestLink 导入结果

testlink

禅道导入结果

zentao


💡 使用指南

1️⃣ 命令行调用

基本用法

# 转换为所有格式(CSV、XML、JSON)
xmind2cases /path/to/testcase.xmind

# 只转换为 CSV 格式(禅道)
xmind2cases /path/to/testcase.xmind -csv

# 只转换为 XML 格式(TestLink)
xmind2cases /path/to/testcase.xmind -xml

# 只转换为 JSON 格式
xmind2cases /path/to/testcase.xmind -json

输出文件

执行后会生成以下文件:

  • testcase.csv - 禅道导入格式
  • testcase.xml - TestLink 导入格式
  • testcase.json - 通用 JSON 格式

2️⃣ Web 界面

web_tool_cli

启动 Web 工具

# 默认端口 5001
xmind2cases webtool

# 自定义端口
xmind2cases webtool 8000

在浏览器中访问:http://127.0.0.1:5001


3️⃣ Python API

基本用法

import json
import xmind
from xmind2cases.zentao import xmind_to_zentao_csv_file
from xmind2cases.testlink import xmind_to_testlink_xml_file
from xmind2cases.utils import (
    xmind_testcase_to_json_file,
    xmind_testsuite_to_json_file,
    get_xmind_testcase_list,
    get_xmind_testsuite_list
)


def main():
    xmind_file = 'docs/xmind_testcase_template.xmind'
    print(f'Start to convert XMind file: {xmind_file}')

    # 转换为禅道 CSV
    zentao_csv_file = xmind_to_zentao_csv_file(xmind_file)
    print(f'Zentao CSV: {zentao_csv_file}')

    # 转换为 TestLink XML
    testlink_xml_file = xmind_to_testlink_xml_file(xmind_file)
    print(f'TestLink XML: {testlink_xml_file}')

    # 转换为 JSON 文件
    testsuite_json_file = xmind_testsuite_to_json_file(xmind_file)
    print(f'TestSuite JSON: {testsuite_json_file}')

    testcase_json_file = xmind_testcase_to_json_file(xmind_file)
    print(f'TestCase JSON: {testcase_json_file}')

    # 获取测试集数据
    testsuites = get_xmind_testsuite_list(xmind_file)
    print(f'TestSuites:\n{json.dumps(testsuites, indent=2, ensure_ascii=False)}')

    # 获取测试用例数据
    testcases = get_xmind_testcase_list(xmind_file)
    print(f'TestCases:\n{json.dumps(testcases, indent=2, ensure_ascii=False)}')

    # 获取原始 XMind 数据
    workbook = xmind.load(xmind_file)
    print(f'XMind Data:\n{json.dumps(workbook.getData(), indent=2, ensure_ascii=False)}')

    print('Finished conversion!')


if __name__ == '__main__':
    main()

📚 API 文档

数据结构

TestCase JSON 格式

xmind_testcase_demo

from xmind2cases.utils import get_xmind_testcase_list

xmind_file = 'docs/xmind_testcase_demo.xmind'
testcases = get_xmind_testcase_list(xmind_file)

输出结构:

[
  {
    "name": "测试用例1",
    "version": 1,
    "summary": "测试用例1",
    "preconditions": "前置条件",
    "execution_type": 1,
    "importance": 1,
    "estimated_exec_duration": 3,
    "status": 7,
    "steps": [
      {
        "step_number": 1,
        "actions": "测试步骤1",
        "expectedresults": "预期结果1",
        "execution_type": 1
      }
    ],
    "product": "我是产品名",
    "suite": "我是模块名(测试集1)"
  }
]

字段说明:

字段 类型 说明
name string 用例标题
version int 用例版本
summary string 用例摘要
preconditions string 前置条件
execution_type int 执行类型(1: 手动, 2: 自动)
importance int 优先级(1: 高, 2: 中, 3: 低)
estimated_exec_duration int 预计执行时间(分钟)
status int 状态(1: 草稿, 2: 待评审, ..., 7: 终稿)
steps array 测试步骤列表
product string 产品名称
suite string 测试集名称

执行结果字段:

测试用例数据

详细使用指南请参考:使用指南

示例文件:testcase json


TestSuite JSON 格式

from xmind2cases.utils import get_xmind_testsuite_list

xmind_file = 'docs/xmind_testcase_demo.xmind'
testsuites = get_xmind_testsuite_list(xmind_file)

输出结构:

[
  {
    "name": "我是产品名",
    "details": null,
    "testcase_list": [],
    "sub_suites": [
      {
        "name": "我是模块名(测试集1)",
        "details": null,
        "testcase_list": [
          {
            "name": "测试用例1",
            "version": 1,
            "summary": "测试用例1",
            "preconditions": "前置条件",
            "execution_type": 1,
            "importance": 1,
            "estimated_exec_duration": 3,
            "status": 7,
            "steps": [
              {
                "step_number": 1,
                "actions": "测试步骤1",
                "expectedresults": "预期结果1",
                "execution_type": 1
              }
            ]
          }
        ],
        "sub_suites": []
      }
    ]
  }
]

执行结果统计字段:

测试用例数据

示例文件:testsuite json


原始 XMind JSON 格式

基于 XMind 库解析:

import xmind

xmind_file = 'docs/xmind_testcase_demo.xmind'
workbook = xmind.load(xmind_file)
data = workbook.getData()

输出结构:

[
  {
    "id": "7hmnj6ahp0lonp4k2hodfok24f",
    "title": "画布 1",
    "topic": {
      "id": "7c8av5gt8qfbac641lth4g1p67",
      "link": null,
      "title": "我是产品名",
      "note": null,
      "label": null,
      "comment": null,
      "markers": [],
      "topics": [
        {
          "id": "2rj4ek3nn4sk0lc4pje3gvgv9k",
          "title": "我是模块名(测试集1)",
          "topics": [
            {
              "id": "3hjj43s7rv66uncr1srl3qsboi",
              "title": "测试用例1",
              "note": "前置条件\n",
              "label": "手动(执行方式默认为手动)",
              "markers": ["priority-1"],
              "topics": [
                {
                  "id": "3djn37j1fdc6081de319slf035",
                  "title": "测试步骤1",
                  "topics": [
                    {
                      "id": "7v0f1152popou38ndaaamt49l5",
                      "title": "预期结果1"
                    }
                  ]
                }
              ]
            }
          ]
        }
      ]
    }
  }
]

参考示例:xmind_testcase_demo.json


📦 发布到 PyPI

使用 uv 进行构建和发布:

# 构建项目
uv build

# 发布到 PyPI
uv publish

📄 许可证

MIT License

Copyright (c) 2026 Poco https://github.com/koco-co


**[⬆ 返回顶部](#xmind2cases)**

Made with ❤️ by Poco and contributors

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xmind2cases-1.7.0.tar.gz (5.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

xmind2cases-1.7.0-py3-none-any.whl (11.7 MB view details)

Uploaded Python 3

File details

Details for the file xmind2cases-1.7.0.tar.gz.

File metadata

  • Download URL: xmind2cases-1.7.0.tar.gz
  • Upload date:
  • Size: 5.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for xmind2cases-1.7.0.tar.gz
Algorithm Hash digest
SHA256 fb3b5506c52d73acdedba7e5afe8077c2e96a814e79fdd0c39f2a0b8a5f12ae7
MD5 83244022d2baf6e112346b6902fe69da
BLAKE2b-256 8e052afe1a10e83519d43109578dff6290620d520ed5d67d39e8f8a634effce0

See more details on using hashes here.

File details

Details for the file xmind2cases-1.7.0-py3-none-any.whl.

File metadata

  • Download URL: xmind2cases-1.7.0-py3-none-any.whl
  • Upload date:
  • Size: 11.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for xmind2cases-1.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c2659cf9e93762c354aa421b521807776f2d5700c9bafdefabbc917224b5c9b8
MD5 cbda88b478a32c812b89319f86890dab
BLAKE2b-256 d8e2d7f0d4b34f290103e897f8f5e662b60701cea043920f4dc0c018bd6bb060

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page