04- 创建测试库--基础概念

Robot Framework 实际的测试能力是由测试库提供的。

***** 支持的编程语言

  • Robot Framework 自身是用 Python 编写的,能使用 Python 扩展测试库。
  • 如果在 Jython 运行Robot Framework 的话,那么测试库也可以用 Java 来实现。
  • 也可以通过 Python C API 使用 C 语言来实现测试库。

***** 不同的测试库 API

Robot Framework 有三种不同的测试库 API:
 
--- 静态API
这是最简单的方法。
采用一个 Python 的 module 或者 Class,提供一系列的关键字。
module 或 class 的方法名和关键字相匹配,关键字和方法具有同样的参数。
这些关键字可以通报异常,输出日志,返回需要的值等等。
 
--- 动态 API
作为动态API的 Class,要实现两个方法:
一个用来获取它们自己实现了的关键字的名字,另外一个用来执行这些关键字。
关键字具体实现及运行,是在运行期决定的。
这些关键字可以通报异常,输出日志,返回需要的值。
 
--- 混合API
相比静态API,作为混合API的Class ,多了一个方法用来发现实现了哪些关键字,这些关键字可以直接使用。
其他的一切都跟静态 API 一模一样。
 

05- 创建测试库Class或者Module

***** 测试库名称

测试库以.py为后缀名,文件名与实现该测试库的模块名或者类名相同。
Python 类总是被写在一个模块中的。
  • 如果实现一个库的类的名称跟它所在的模块同名,则 Robot Framework允许引入它的时候去掉模块名。
  • 如果模块名和类名不同,使用测试库要同时使用模块名和类名。
  • 如果测试库名称真的太长了,推荐通过 WITH NAME语法给测试库添加一个简短的别名。

***** 提供参数给测试库

所有实现测试库的类都可以带参数。但是,如果库是用模块来实现的,则不能带任何参数。
测试库需要的参数个数跟它的构造器接收的参数个数相同。默认值和可变个数参数也能工作。
参数被传递给测试库时,可以通过变量。

***** 测试库的范围

Robot Framework默认地为每个测试用例创建测试库的新实例,让测试用例之间保持独立。
属性 ROBOT_LIBRARY_SCOPE,测试库可以控制新的库什么时候被创建。
这个属性必须是字符串,并且它只有以下三个值:
  • TEST CASE ---- 为每个测试用例创建一个新的实例。
  • TEST SUITE ---- 为每个测试集创建一个新的实例。
  • GLOBAL ---- 在整个测试执行过程中,只有 1 个实例被创建,被所有测试用例和测试集共享。

***** 声明测试库的版本

属性 ROBOT_LIBRARY_VERSION,声明测试库的版本。
如果 ROBOT_LIBRARY_VERSION 不存在,就尝试读取__version__属性。
这些属性必须是类或者模块的属性。
 

示例: LibraryExampleA.py

# -*- coding: utf-8 -*-

###创建测试库Class或者Module

class LibraryExampleA():

    ROBOT_LIBRARY_SCOPE = 'TEST SUITE'  #测试库的范围
__version__ = '0.1' #声明测试库的版本
def __init__(self):
self._counter = 0
def count(self):
self._counter += 1
print self._counter
def clear_counter(self):
self._counter = 0
## def keyword(self):
## pass

06- 创建测试库--创建静态关键字

***** 关键字名称

在测试数据中使用的关键字名称不区分方法名的大小写,空格和下划线也会被忽略。

***** 关键字参数

在静态和混合库 API 中,一个关键字需要多少参数,取决于实现它的方法。
最通用也是最简单的情况是,当一个关键字需要的参数是固定个数的。

***** 带有默认值的参数

在 Python 中,带有默认值的参数可以声明在方法签名中。

***** 可变数量的参数

Robot Framework支持带有可变数量参数的关键字。
Python 支持方法接收可变数量的参数。同样的语法也可以在测试库中使用。

***** 参数的类型

通常情况下,关键字参数是作为字符串传给 Robot Framework 的。
如果关键字需要其他类型的参数,要么就使用变量,要么利用内建关键字将字符串转换成需要的类型。
参数的数量正确,调用关键字时将会成功;参数类型不匹配,执行关键字时失败。
在 Python 中,可以很简单的将参数转换为合适的类型,例如:port = int(PortNumber)。

示例: LibraryExampleB.py

# -*- coding: utf-8 -*-

###创建静态关键字

class LibraryExampleB():

#关键字名称
def hello(self,name):
print "Hello, %s!" % name
def do_nothing(self):
pass
#关键字参数
def no_arguments(self):
print "Keyword got no arguments."
def one_argument(self,arg):
print "Keyword got one argument '%s'." % arg
def multiple_arguments(self,a1, a2, a3):
print "Keyword got three arguments '%s', '%s' and '%s'." % (a1, a2, a3)
#带有默认值的参数
def one_default(self,arg='default'):
print "Argument has value %s" % arg
def multiple_defaults(self,arg1, arg2='default 1', arg3='default 2'):
print "Got arguments %s, %s and %s" % (arg1, arg2, arg3)
#可变数量的参数
def any_arguments(self,*args):
print "Got arguments:"
for arg in args:
print arg
def one_required(self,required, *others):
print "Required: %s\nOthers:" % required
for arg in others:
print arg
def also_defaults(self,req, def1="default 1", def2="default 2", *rest):
print req, def1, def2, rest
#参数的类型
def connect_to_host(self,address, port=25):
port = int(port)
print address, port

07- 创建测试库--与RobotFramework通信

***** 报告关键字的状态

如果一个被执行的方法抛出一个异常,该关键字的状态就是 FAIL,如果它正常返回了,则状态为 PASS。
错误信息包含了异常的类型和信息,它被显示在日志、报告和控制台中。
异常的跟踪可以通过 DEBUG 日志级别来输出日志。这些信息在日志文件中默认是不可见的。

***** 停止测试执行

可以通过让一个测试用例失败来停止整个测试运行。
属性ROBOT_EXIT_ON_FAILURE (值为 True)设置到关键字抛出的异常中,就能达到这种目的。

***** 不管失败继续执行

可以让整个测试执行在出现了 failure 的时候继续执行。
属性ROBOT_CONTINUE_ON_FAILURE (值为 True)设置到关键字抛出的异常中,就能达到这种目的。

***** 输出日志信息

默认地,一个方法写入标准输出的一切信息都会被当作 INFO 级别输出到日志文件中。
要使用其他的日志级别(非 INFO)或者创建一些信息,可以通过将级别绑定到信息中。
格式: *LEVEL*Actual log message
*LEVEL*必须位于信息的头部,并且 LEVEL 的值必须是 TRACE、 DEBUG、 INFO、 WARN 、HTML 其中之一。

***** 警告

警告(WARN)级别的信息会自动被写入控制台和日志文件中单独的测试执行错误那一节。
使用警告来报告一下重要而不危险的问题给用户。

***** 输出 HTML 格式的日志

如果测试库想要使用格式、超链接、图片等等,它们可以使用特殊的日志级别 HTML。

***** 日志级别

大多数情况下, INFO 级别已经足够。
DEBUG 和 TRACE,可以很容易的调试测试库自身可能存在的问题。
WARN 级别可以让信息更加可见,HTML 级别对于需要其他格式时很有用。

***** 返回值

返回值可以赋给测试数据中的变量,然后这个变量又作为其他关键字的输入。
返回值在 Python中采用 return 语句。
一般地,一个值被赋给一个标量变量。
关键字能通过多个标量变量或者构成一个列表变量返回多个值。 对于Python, 返回值必须是列表或者元组。

示例: LibraryExampleC.py

# -*- coding: utf-8 -*-

###与RobotFramework通信

import base64

class LibraryExampleC():

#返回值
def return_string(self):
return 'Hello, world!'
def return_object(self,info):
return base64.b64encode(info)
def return_two_values(self):
return 'first value', 'second value'
def return_multiple_values(self):
return ['a', 'list', 'of', 'strings'] #日志例子
def log_example(self):
print 'Hello from a library.'
print '*WARN* Warning from a library.'
print '*INFO* Hello again!'
print 'This will be part of the previous message.'
print '*INFO* This is a new message.'
print '*INFO* This is <b>normal text</b>.'
print '*HTML* This is <b>bold</b>.'
print '*HTML* <a href="http://robotframework.org">Robot Framework</a>'

Robot Framework - 2 - 创建测试库的更多相关文章

  1. Robot Framework(十四) 扩展RobotFramework框架——创建测试库

    4.1创建测试库 Robot Framework的实际测试功能由测试库提供.有许多现有的库,其中一些甚至与核心框架捆绑在一起,但仍然经常需要创建新的库.这个任务并不复杂,因为正如本章所示,Robot ...

  2. 关于Django启动创建测试库的问题

    最近项目迁移到别的机器上进行开发,启动Django的时候,有如下提示: Creating test database for alias 'default' 其实这个可能是在Django启动按钮的设置 ...

  3. Robot Framework - 4 - 创建和扩展测试库的示例

    创建和扩展Library的示例 示例:Check status on Linux OS 创建与使用library的基本步骤:           1--- library实现的内容和实现的方式     ...

  4. Robot Framework - 5 - 创建测试数据

    Creating test data User Guide - Creating test data:http://robotframework.org/robotframework/latest/R ...

  5. Robot Framework常用的操作库列表

    标准库是Robot Framework可以直接导入使用的库,包含以下几类: Builtin:包含经常需要的关键字.自动导入无需import,因此总是可用的 Dialogs:提供了暂停测试执行和从用户的 ...

  6. Robot Framework - 建立本地测试环境

    注意:本文内容是以“在Window7系统中安装本地RobotFrmamework自动化测试环境”为例. Robot Framework简介 HomePage:http://robotframework ...

  7. Robot Framework - 基础关键字 BuiltIn 库(二)

    本篇教程,我们继续接着上篇内容进行讲解,我们本节教程讲解的是Robot Framework 机器人框架中的变量中使用判断.字符串的拼接.Evaluate的用法.调用Python文件.条件分支语句.以及 ...

  8. Robot Framework - 基础关键字 BuiltIn 库(一)

    今天给大家分享的是Robot Framework 机器人框架中 BuiltIn 基础库的使用...BuiltIn 库里面提供了很多基础方法助力于我们在自动化测试领域中做的更好!——本系列教程是教会大家 ...

  9. 学习Robot Framework必须掌握的库—-BuiltIn库

    作为一门表格语言,为了保持简单的结构,RF没有像别的高级语言那样提供类似if else while等内置关键字来实现各种逻辑功能,而是提供给了用户BuiltIn库.如果用户想在测试用例中实现比较复杂的 ...

随机推荐

  1. canvas的使用方法

    了解canvas:canvas标签是用作图形绘制,但是通过js脚本来实现的,canvas标签其实只是一个容器 ,最终实现绘制功能肯定是通过js脚本实现. 首先肯定要定义一个canvas标签当做容器 & ...

  2. rpm --rebuilddb

    rpm -ivh .....rpm 报Bus Error rpm --rebuilddb

  3. Eclipse Maven: Cannot change version of project facet Dynamic web to 3.0 的解决方法

    在 Eclipse 中创建 Maven web 项目的时候使用 maven-artchetype-webapp 骨架,但是这个 catalog 比较老,用的 servlet 还是 2.3 在 Proj ...

  4. django2.0 + python3.6 在centos7 下部署生产环境的一些注意事项

    一:mysql 与环境选用的坑 目前, 在生产环境部署django有三种方式: 1. apache + mod_wsgi 2. nginx + uwsigi 3. nginx + supervisor ...

  5. Spring Ioc 常用注解

    在开发中spring ioc的配置方式有多种方式,常用的一般都是byName.byType .以及其自动装配可以查看http://www.cnblogs.com/gubai/p/9140840.htm ...

  6. Desktop Central 的移动设备管理功能

    Desktop Central 的移动设备管理功能1.移动应用程序管理设备管理不会仅仅只是配置策略.检索资产信息和保护设备.应用程序管理与设置员工的移动设备一样重要.使用 Desktop Centre ...

  7. String常用类

    一.String类String类在java.lang包中,java使用String类创建一个字符串变量,字符串变量属于对象.java把String类声明的final类,不能有类.String类对象创建 ...

  8. Exp3 免杀原理与实践_05齐帅

    Exp3 免杀原理与实践 20154305_齐帅 想要弄懂免杀,一定得先把基础问题弄明白啊~~ 一.基础问题回答 (1)杀软是如何检测出恶意代码的? - -检测特征码: 依靠分析总结出计算机病毒中常出 ...

  9. 怎样用git上传代码到github以及如何更新代码

    上传代码: 1.进入指定文件夹: cd 指定文件夹 2.初始化git仓库: git init 3.将项目所有文件添加到暂存区: git add . 4.提交到仓库: git commit -m &qu ...

  10. submit与execute区别

    1.可以接受的任务类型 submit: execute: 可以看出: execute只能接受Runnable类型的任务 submit不管是Runnable还是Callable类型的任务都可以接受,但是 ...