测试驱动之xml文件的处理

Xml是可扩展标记语言,关于xml的技术本人这里不在介绍,感兴趣的同学可以去w3c看看详细的资料,这里,我仅仅介绍的是如何获取xml文档结构中的数据,并且应用到自动化测试中,仅此而已,因为本文档的核心是学习自动化,本节是学习测试驱动方式。已百度登录为实例,xml的数据如下:

<?xmlversion="1.0" encoding="utf-8"?>

<baidu>

<!--百度账号以及密码-->

<login username="your account"password="your password" />

<!--账号密码为空错误信息-->

<null>请您填写手机/邮箱/用户名</null>

</baidu>

如下函数是分别获取xml文档结构的属性值以及获取标签之间的数据,见如下的代码:

importxml.dom.minidom

#获取标签的属性值

defgetPropertyXml(value1,value2):

#打开文档结构

document=xml.dom.minidom.parse("D:\\Git\PyCharm\\SeleniumTestingWithPython\\DataDriverTest\\baiduXml.xml")

#得到文档元素结构

demo=document.documentElement

itemList=demo.getElementsByTagName(value1)

db=itemList[0]

property=db.getAttribute(value2)

return property

importxml.dom.minidom

'''

获取标签对之间的数据

'''

defgetValueXml(value):

#打开xml的文档

document=xml.dom.minidom.parse("D:\\Git\PyCharm\\SeleniumTestingWithPython\\DataDriverTest\\baiduXml.xml")

#得到文档元素结构

demo=document.documentElement

db=document.getElementsByTagName(value)

data=db[0]

return data.firstChild.data

print getValueXml('null')

使用如上的二个方法,我们分别就可以获取到login结点的属性值以及标签之间的数据,如下,我们通过测试实例代码,来实现账号密码为空的时候,验证返回的错误信息的实例,见如下的代码:

#coding:utf-8

importunittest

fromselenium import webdriver

fromddt import ddt,data,unpack

fromtime import sleep

import vke

@ddt

class developTest(unittest.TestCase):

def setUp(self):

self.driver=webdriver.Firefox()

self.driver.implicitly_wait(30)

self.driver.maximize_window()

self.driver.get('http://www.baidu.com')

self.addCleanup(self.driver.quit)

def testLogin(self,value='null'):

self.driver.find_element_by_link_text(u'登录').click()

self.driver.find_element_by_id('TANGRAM__PSP_8__submit').click()

errorText=self.driver.find_element_by_xpath(".//*[@id='TANGRAM__PSP_8__error']").text

self.assertEqual(errorText , vke.getValueXml(value))

if__name__=='__main__':

unittest.main(verbosity=2)

原文发布于微信公众号 - Python自动化测试(wuya-python)

原文发表时间:2015-09-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏FD的专栏

一步步理解python的异步IO

看到越来越多的大佬都在使用python的异步IO,协程等概念来实现高效的IO处理过程,可是我对这些概念还不太懂,就学习了一下。 因为是初学者,在理解上有很多不到...

19320
来自专栏java一日一条

2017年高频率的互联网校园招聘面试题

参加了2017年校招,面试了阿里、百度、腾讯、滴滴、美团、网易、去哪儿等公司,个人是客户端 Android 方向,总结了面试过程中频率出现较高的题目,希望对大家...

19220
来自专栏技术沉淀

Python: os模块实例详解

20530
来自专栏CSDN技术头条

c++ fstream + string 处理大数据

起因 (1)之前处理文本数据时,各种清洗数据用的都是java的File,FileReader/FileWriter,BufferedReader/Buffer...

25560
来自专栏QQ会员技术团队的专栏

玩转webpack(二):webpack的核心对象

作者介绍:陈柏信,腾讯前端开发,目前主要负责手Q游戏中心业务开发,以及项目相关的技术升级、架构优化等工作。 前言 webpack 是一个强大的模块打包工具,之所...

1.4K80
来自专栏kangvcar

MongoDB 入门极简教程

12010
来自专栏Python、Flask、Django

Python读写Json数据

19120
来自专栏xiaoxi666的专栏

Qt中纯C++项目发布为dll的方法(超详细步骤)

众所周知,我们可以将C++项目中的类以及函数导出,形成 .dll 文件,以供其他程序使用,下面将说明Qt环境下的使用方法。

20310
来自专栏分布式系统进阶

Kafka集群Metadata管理Kafka源码分析-汇总

可以看到是调用了ReplicaManager.maybeUpdateMetadataCache方法, 里面又会调用到MetadataCache.updateCa...

31320
来自专栏xingoo, 一个梦想做发明家的程序员

Elasticsearch聚合 之 Terms

之前总结过metric聚合的内容,本篇来说一下bucket聚合的知识。Bucket可以理解为一个桶,他会遍历文档中的内容,凡是符合要求的就放入按照要求创建的桶...

56060

扫码关注云+社区

领取腾讯云代金券