• Stars
    star
    109
  • Rank 319,077 (Top 7 %)
  • Language
    HTML
  • License
    MIT License
  • Created over 7 years ago
  • Updated over 4 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Convert xmind to test link xml files, support xmind pro and xmind zen.

xmind2testlink

Test Package PyPI

With xmind2testlink, you will be able to convert xmind tests to testlink tests xml files. You should have python installed before running it. See also xmindparser.

Requirement: python 2.7 or 3.4 +

中文说明:xmind2testlink - 快速设计测试案例并导入TestLink,如果你的xmind中包含中文或者unicode,请使用Python 3.4+,谢谢。

Installation and quick start

The most easy to install xmind2testlink is using pip command:

pip install xmind2testlink -U

Now you are ready to convert an xmind to TestLink xml:

xmind2testlink /path/to/testcase.xmind
Generated: testcase.xml

# output json is also supported
xmind2testlink /path/to/testcase.xmind -json
Generated: testcase.json

To build your tools with this package, do it like this:

from xmind2testlink.xmind_parser import *
from xmind2testlink.testlink_parser import *

# do your stuff

Conversion Rules

Now xmind2testlink has been upgraded to v2, it supports 2 kinds of conversion.

v1 rules

For old users (xmind2testlink v1), your xmind looks like below structure.

xmind2testlink_v1

The output:

xmind2testlink_v1_out

Generally to say:

  1. The first sub topic => suite
  2. The sub topic of suite => test case title
  3. The sub topic of test case => test step
  4. The sub topic of test step => expected result

v2 rules

Latest update: xmind2testlink will auto detect v1 and v2 rules by checking if descendants of testcase node (3rd level nodes) still have priority maker. If yes, this file will be processed by v2 rule, else by v1 rule.

V2 xmind looks like this:

xmind2testlink_v2

The output:

xmind2testlink_v2_out

Rules:

  1. Mark root topic with a star marker, this means v2 xmind file. (no matter what color of star maker, optional)
  2. First sub topic => it is still converted to suite
  3. Test case title will be combined by sub topics, until:
    1. Child topic is marked with priority
    2. Current topic is end topic

By default, the title parts are connected by blank space, you can define the connector by last char of root topic, like this.

xmind2testlink_v2_sep

Then the output will be changed to:

xmind2testlink_v2_sep_out

Note: only valid chars can be used as a connector.

More detail

  1. Notes for a test suite => details in TestLink.
  2. Notes for a test case => summary in TestLink.
  3. Comments for a test case => preconditions in TestLink.
  4. Priority maker for a test case => importance in TestLink.
  5. flag-green maker for a test case => execution type in TestLink.
  6. Sub topics for a test case will be treated as test steps.
    • It is okay to design test step with action but without expected results.
  7. Use ! to ignore any test suite / test case / test step that you don't want to convert.
  8. Root topic will not be converted, just treat it as target suite node in TestLink.
  9. Free topic and notes will not be converted.
  10. Only the first sheet in xmind will be converted.

XmindZen Update

Now xmind2testlink support xmind zen files, remember one thing, you cannot add comments for a topic in xmind zen, so we cannot create preconditions for ZEN!

Download the sample xmind files:

Guide: Import into TestLink

Go to your TestLink website, import the xml into your target test suite step by step.

testlink_import_1

To avoid duplicates, you might want to Update date on Latest version.

testlink_import_2

Once you click on the Upload file button, all the tests will be imported as they listed in xmind.

testlink_import_3

The field mapping looks like below figure.

testlink_import_4

Advanced usage

1. Use from browser

A simple web page to host this feature also has been built in web folder. To start the website, here is the command:

# clone this git repo ahead
cd /path/to/xmind2testlink/web
pip install -r requirements.txt -U
python application.py

* Running on http://127.0.0.1:5001/ (Press CTRL+C to quit)
* Restarting with stat

Start a browser, then you will be able to convert xmind to TestLink via http://127.0.0.1:5001. I am not good at web design, but I am trying my best to provide a friendly interface :-)

xmind2testlink_web

If you wan to deploy this application to a web server, please checkout Flask Deployment.

3. Run in Docker

If you have docker installed, you just need 1 line code to run xmind2testlink.

docker run -d --name xmind2testlink --restart always -p 3000:5001 tobyqin/xmind2testlink

Now go to http://localhost:3000 you will able to use xmind2testlink in browser.

Build and run your docker engine:

cd web
docker build -t xmind2testlink:latest .
docker run -d --name xmind2testlink --restart always -p 3000:5001 tobyqin/xmind2testlink

3. Batch on Windows

It is okay to batch convert all xmind files in a folder, copy the xmind2testlink_all.bat to your folder, then you will be able to convert all files by double clicking on it.

@echo off
@echo off
echo Batch xmind to testlink...

python -m pip install xmind2testlink -U >NUL
python -c "import glob, os;[os.system('xmind2testlink ""{}""'.format(f)) for f in glob.glob('*.xmind')]"

echo OK!

More Repositories

1

kog-money

一个王者荣耀刷金币的小外挂。
Python
356
star
2

xmindparser

Parse xmind file to programmable data type (e.g. json, xml), support xmind legacy and xmind zen file types.
Python
169
star
3

Typora-Portable

The portable version of typora, 绿色免安装版Typora。
137
star
4

wpath

WPath is a library to select Windows UI automatin element like XPath.
C#
27
star
5

testcube

Testcube is a platform to manage and monitor automation test results.
JavaScript
27
star
6

tampermonkey_vue

Demo to use vue in tampermonkey.
JavaScript
24
star
7

photodup

Find duplicate photos (or other file types) on your computer.
Python
20
star
8

flask_api_doc

A demo to auto document Flask api / endpoints.
Python
17
star
9

chrome_vue_ext_demo

A demo to use Vuejs in Chrome extension.
JavaScript
9
star
10

python_decorator

To tell how to use python decorator.
Python
7
star
11

toolbox

我的小工具箱
Lua
4
star
12

tobyqin.github.io.mm.bak

My github blog pages.
JavaScript
2
star
13

blog_hexo

Source code of my hexo blog, not in used anymore.
JavaScript
2
star
14

ccnet.tfsrevisionlabeller

TFS revision labller for CruiseControl.NET
C#
1
star
15

docs

Some documentation
JavaScript
1
star
16

hello-k8s

Python
1
star
17

pytools

A handy tool library for Python programming, to save my day!
Python
1
star
18

yo

Example of click command line tool
Python
1
star
19

opencv-automation-demo

A demo to use opencv to do UI automated testing.
Python
1
star
20

testcube-client

A python client for testcube.
Python
1
star
21

python_underscore

Shows how to use underscore in python.
Python
1
star
22

tobyqin.github.io

JavaScript
1
star
23

python_automation_utils

Some utility functions for Python automation testing.
Python
1
star
24

KeepScreenAlive

A small tool to keep screen alive, it will be helpful for UI automation or some specific situations.
C#
1
star