快生活 - 生活常识大全

操作内置库操作


  前段时间充忙的学习RF,系统学习完之后就开始动手做各种接口的测试,虽然各类的接口测试基本能跑通了,但是重复造车的问题存在太明显。RF本身内置库就已经比较丰富,比如不需要import直接就加载到内存的BuiltIn库,还有需要import的常用模块String,Collections,XML库。在前面的接口测试中,使用最多的就是这几个内置库,接口返回的数据基本都是xml格式的居多,然后自己也重复造车了,为此特地花了几天时间去学习了下内置库,主要还是学了下XML库,以下的分享都是基于XML库。
  学习XML内置库,我认为需要掌握以下几个知识点:
  第一:内置库的概念?有哪些内置库,大概都有什么关键字?有区分版本吗?跟RF版本有关么?为什么内置库有些需要import,有些不需要import?
  第二:XML内置库使用的是python的哪个标准库?对这个标准库需要有哪些基本的了解?
  第三:内置库是怎么构建起来的?基本关键字是否能灵活的使用?
  第四:有时候可能需要稍微修改下内置库,比如增加一些关键字等,该怎么修改?
  从网上和官网(http://robotframework.org)上搜到一些资料,整理如下:
  第一:内置库的基本概念?
  内置库实际在官网称为standard library,就是标准库。常见的其他库比如Request,SeleniumLibrary库,官网称之为externallibrary,就是外部库,也称第三方库。标准库和外部库首先要正确的进行区分,对于标准库,这些库是直接绑定在RF内的,在
  D:Python27Libsite-packagesobotlibraries(视python安装目录变化) 下可以看到,无须再下载;而外部库,是需要根据个人需要,下载后再安装导入才能使用的。 对于标准库,又分两类,类似BuiltIn库是RF自动加载到内存的,安装后按下F5就能直接使
  用,不需要再次import,而XML库需要再次import才能正常使用。因为BuiltIn library 提供了很多常用的关键字,比如Should Be Equal,Convert To Integer等,所以RF就把这个常用的库自动加载到了内存。
  不同版本的RF,支持不同的内置库而且相同的内置库里的关键字可能也是不一样的,以RF3.0(使用命令robot --version查看RF版本)为例,3.0是目前最新的RF的版本,支持很多的内置库,查看D:Python27Libsite-packagesobot下的py文件,可以看到:
  基本官网写的10个标准库都能在这里面找到相应的py文件。BuiltIn,Collections,DateTime,Dialogs,Process,OperatingSystem,Remote(没有关键字,暂时不算在内),Screenshot,String,Telnet,XML.这11个库,有些是在RF2.0的时候就已经有了的,最晚的DateTime,Process,XML是在RF2.8之后才内置的,也就是说如果当前使用的是RF2.8之前的版本,内置库是无法直接import XML就是使用的,需要下载安装才能使用,这点需要注意下,不同的RF版本,相同的标准库之间也是会细微的区别,这需要仔细的去查看保准库内每个版本的使用文档。
  10个标准库,又都是做什么用的呢,这还真需要了解,而且还需要多花时间去了解每个标准库里面的关键字,这10个标准库,介绍如下:
  这个表的来源是来自官网的,官网的用户手册文档已经描述的非常详细了。学习的时候可以详细的查看官网的相关文档。
  第二:XML内置库的学习。
  从内置库的XML的源码可以看出,RF使用的是ETree来对xml进行解析的,部分源码如下:
  import copyimport reimport ostry:from lxml import etree as lxml_etreeexcept ImportError: lxml_etree = Nonefrom robot.api import loggerfrom robot.libraries.BuiltIn import BuiltInfrom robot.utils import (asserts, ET, ETSource, is_string, is_truthy, plural_or_not as s)from robot.version import get_versionshould_be_equal = asserts.assert_equalshould_match = BuiltIn().should_matchclass XML(object): ROBOT_LIBRARY_SCOPE = "GLOBAL"ROBOT_LIBRARY_VERSION = get_version() _xml_declaration = re.compile("^<!--?xml-->")<!--?xml-->
  def__init__(self,use_lxml=False):
  use_lxml=is_truthy(use_lxml)
  ifuse_lxmlandlxml_etree:
  self.etree=lxml_etree
  self.modern_etree=True
  self.lxml_etree=True
  else:
  self.etree=ET
  self.modern_etree=ET.VERSION&gt;="1.3"
  self.lxml_etree=False
  ifuse_lxmlandnotlxml_etree:
  logger.warn("XMLlibraryrevertedtousestandardElementTree"
  "becauselxmlmoduleisnotinstalled.")
  defparse_xml(self,source,keep_clark_notation=False):
  withETSource(source)assource:
  tree=self.etree.parse(source)
  ifself.lxml_etree:
  strip=(lxml_etree.Comment,lxml_etree.ProcessingInstruction)
  lxml_etree.strip_elements(tree,*strip,**dict(with_tail=False))
  root=tree.getroot()
  ifnotis_truthy(keep_clark_notation):
  NameSpaceStripper().strip(root)
  returnroot
  python提供了几个标准库都可以对xml进行解析,之前我使用的是DOM,基于RF使用的是ETree,便开始学习了下ETree的开发文档。学习对XML文件的操作,那肯定也得对XML本身有最基本的了解,比如XML的用途,树结构,节点类型(DOM),带命名空间的xml。下面是部分的知识点的总结:
  xml是一种可扩展的标记语言。要求标记需要成对的出现(有时候会进行简写<strong>)。一个典型的xml文档如下所示:</strong>
  <example><first id=""1"">text</first><second id=""2""><child></child></second><third><child>more text</child><second id=""child"/"><child><grandchild></grandchild></child></second></third></example>
  A. 整个xml文档是一个文档节点,属于根节点,比如上述文档的<example>节点就是一个根节点,一个xml文件只能有一个根节点,否则解析的时候胡报错的</example>
  B.每个 XML 标签是一个元素节点,比如<first>和<second>,<third>都属于元素节点,却属于<example>的子节点。</example></third></second></first>
  C.attribute值:表示节点元素的属性值,比如first 有一个属性id,属性值为1;second也有id属性,属性值为2,而third没有属性。
  D.Text值:表示元素中的文本内容。比如:first 的text值就为1;second没有,third也没有;
  一个xml还包含其他的内容:比如处理指令和一些注释;在python的etree标准库解析的过程中,是直接把这二个给剔除掉了。有兴趣的可以根据官网给出的开发文档,把常用的一些方法都敲一遍,主要的还是使用2个类Element Objects和ElementTree Objects。
  第三:RF中XML库的学习。
  在使用sudslibrary做soap协议的测试时,返回的xml是带命名空间的,之前一直不理解,对XML库进行整体的学习之后就有了很大的理解。
  XML库主要有以下几个作用(翻译于原文手册):
  A.解析一个XML文件,或一个包含XML的字符串,在一个XML元素结构中,并从中寻找某些元素,用于进一步分析(e.g.Parse XMLandGet Elementkeywords).
  B. 获取元素的文本或属性(e.g.Get Element TextandGet Element Attribute).
  C. 直接验证文本、属性或全部元素(e.gElement Text Should BeandElements Should Be Equal).
  D. 修改和保存它(e.g.Set Element Text,Add ElementandSave XML).
  下面按照关键字的类型大致做了以下的学习:解析的xml都是前面的xml例子
  A.最常用关键字的学习:
  B. 通过xpath来搜素子节点。
  C. 简单的带命名空间的xml的解析
  D. 复杂的命名空间的xml解析(之前soap协议返回的xml的解析部分补充)
  这些操作基本都是围绕着对XML的读写,之前做报文测试的时候,遇到过返回的的xml是没有根元素的,如果直接使用XML库是无法进行解析的,需要加上根节点,再进行解析,于是直接写了用户自定义的库。而且当时需要从xml中读取报文字段,与测试数据组合后,再一起发给服务器,这部分也是XML库没有提供的内容。但是对返回的xml的数据进行解析,xml库做的还是比较到位。如果觉得系统带的xml库功能不够使用,或者想把几个功能整成一个功能使用,通过以上的学习基本可以修改下代码,然后自定义一个库了。
  还有几点的学习,后面还需要对RF有更深刻的了解才能有所感悟,这次的学习给我带来了一些全新的收获,以前我查找资料很少看官方文档,虽然英文过了六级,但是一看英文文档还是会头晕脑胀,这次逼着自己看了官网的标准库的开发文档和用户手册,真感觉很不错,简洁又明了,学习官网手册果然是很不错的学习方法,比去看某些博客收获更全面更权威~~~这个技能get了~~~
网站目录投稿:雨菱