适用于Mac端的Testlink测试用例批量转化工具

项目背景

公司的测试用例采用Testlink进行管理,项目组的成员习惯不同,有些喜欢直接在testlink上写case,有些又喜欢先在excel写了再导入,公司已经提供了一个用例转化的工具,不过是适用于windows的,现在都切换到mac办公以后,就没法适用了,就想着自己写一个吧,惠己及人,真拿这群孩子没办法(手动摊手~)

需求分析

简言之,就是:将excel写的用例文件转化成testlink支持上传的格式文件,批量导入到testlink

需求肢解:

1.testlink支持上传的文件类型是什么------XML

我们在testlink上创建好项目计划-版本后,新建一个测试用例集,点击用例集的设置按钮,有一些操作,其中一个叫“导入用例集”,点击导入用例集,进入到的页面,可以看到可选的导入文件类型为XML,如图:


用例集-设置

支持导入的文件类型

2.明确了支持导入的文件类型,接下来就需要明确具体以怎样的格式才能正确导入。

我们点击“查看支持文件格式”,查看官方给出的file-formats:


importAexport.png

可以看到,文档中明确给出了可以导入和导出测试项目、测试用例集、单个测试用例等等...我这里要做的就是导入测试用例集,先就Test suite进行分析,其他类型的续签可以类推...

这里有2种方式,一种带keywords,一种不带keywords,就拿带keywords的来说:


suiteWkeywords.png

根元素必须是testsuite,它标识这是一个测试用例集,每对testcase子元素代表一条测试用例case,每个case包含子元素:summary描述、steps操作步骤、expectedresults预期结果、keywords关键词等。由于官方文档维护记录最近只到10年,这个应该是比较老的结构了,我在做的时候遇到了些坑,按着搞了半天都不对,最后直接简单粗暴现在testlink上创建一个用例集,内建几条case,然后再导出来对它的xml格式进行分析,拿到我想要的形式。嗯...我的excel用例模板like this:


用例模板.png

testlink导出的xml模板like this:
testlink导出的xml.png

这里面有很多是我不需要的,将之剔除,只保留关键的精华部分,整理了一下,我需要的格式like this:


最终形式.png

这就是我最终要转化成的格式~

明确了要实现什么,接下来就是怎么实现的问题了~

实现

解决一个问题的方法有千万种,每种都有各自的优缺点,关键是看你想怎么做,具体问题具体分析,这里我语言选择python(暂时只会这个和shell哈哈~)。

要用到的库:

1.操作excel,读取数据:xlrd
2.处理xml:python内置的xml模块
3.我要如何提供友好的交互性供团队成员使用?这里用到:Tkinter。支持本地选择文件

简单粗暴,上代码:

#!/usr/bin/python
# -*- coding:utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding("utf-8")

import xlrd
from xml.dom.minidom import Document
import Tkinter,tkFileDialog
import os

class excel_to_xml():

    def __init__(self):
        pass

    def get_filepath(self):
        """
        提供文件选择对话框,从本地选择要转化的excel文件,返回文件路径
        """
        root = Tkinter.Tk()
        root.withdraw()
        filepath = tkFileDialog.askopenfilename()
        return filepath


    def read_excel(self,path):
        """
        读取excel内容,返回所有用例值
        """
        # 打开文件
        file = xlrd.open_workbook(path)
        # 获取第一个sheet(按索引)
        sheet1 = file.sheet_by_index(0)

        # 获取行数和列数
        nrows = sheet1.nrows
        ncols = sheet1.ncols

        print nrows,ncols

        # 获取单元格内容
        nclosvalue = []
        for j in range(1,nrows):
            nrowsvalue = []
            for i in range(ncols):
                cellvalue = sheet1.cell(j,i)
                nrowsvalue.append(cellvalue)
                i +=1


            nclosvalue.append(nrowsvalue)
            j += 1

        return nclosvalue


    def to_xml(self):
        """
        处理数据,转化成xml格式,并将文件保存在用例同路径下
        """
        path1 = self.get_filepath()
        doc = Document()  # 创建DOM文档对象

        testcases = doc.createElement('testcases')
        doc.appendChild(testcases)

        excle_results = self.read_excel(path1)
        print(len(excle_results))
        for i in range(len(excle_results)):
            print"第"+str(i+1)+"个用例为:\n"
            print(excle_results[i])

            testcase = doc.createElement('testcase')
            testcase.setAttribute('name', "%s" % excle_results[i][0].value)
            testcases.appendChild(testcase)

            summary = doc.createElement('summary')
            summary_text = doc.createTextNode('%s' % excle_results[i][1].value)
            summary.appendChild(summary_text)
            testcase.appendChild(summary)

            steps = doc.createElement('steps')
            testcase.appendChild(steps)

            step = doc.createElement('step')
            steps.appendChild(step)

            step_number = doc.createElement('step_number')
            step_number_text = doc.createTextNode('1')
            step_number.appendChild(step_number_text)
            step.appendChild(step_number)

            actions = doc.createElement('actions')
            actions_text = doc.createTextNode('%s' % excle_results[i][2].value)
            actions.appendChild(actions_text)
            step.appendChild(actions)

            expectedresults = doc.createElement('expectedresults')
            expectedresults_text = doc.createTextNode('%s' % excle_results[i][3].value)
            expectedresults.appendChild(expectedresults_text)
            step.appendChild(expectedresults)

            i += 1

        # 要生成的xml文件名
        xml_name = path1.strip().split('.')[0] + '.xml'

        # 要生成的xml文件到目录(绝对路径)
        dir = path1.strip().split('/')[-2]
        xml_dir = os.path.join(('%s') % dir,xml_name)

        try:
            f = open(xml_dir,'w')
            doc.writexml(f, indent='\t', newl='\n', addindent='\t', encoding='utf-8')
            f.close()
        except:
            print("您没有选择任何文件!")




change = excel_to_xml()
change.to_xml()

最后,要以怎样的形式供团队成员使用?
扔给成员一个脚本?可以,但是需要成员也配置环境、安装库,操作麻烦;
这里我选择打包成一个mac端的dmg应用程序,成员只需双击即可从本地文件选择要转化的文件。方法有很多,这里不赘述,我用的py2app,打包后生产dmg包:


dmg.png

添加到电脑应用程序就可以双击使用啦~


1547799945753.jpg
选择对话框.png

写在最后,要做一个东西真不容易啊~
呼呼~完

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容