51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2570|回复: 0
打印 上一主题 下一主题

RobotFramework的奇淫技巧——变量

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2018-6-21 13:48:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
背景

在使用RobotFramework的过程中,会发现写起来跟写代码有点类似,但是比起直接写代码,RobotFra
mework又有点奇怪,这里总结一下RobotFramework的使用过程中的一些奇淫技巧,本文主要涉及的是
变量。

标量和链表

在RobotFramework中,标量指的是${},链表指的是@{},大括号中间的变量名如果是一样的,那么就是
一个变量,不过有一个很明显的区别,当使用标量时,整个值就会是一个整体,而使用链表的时候,则
是一个个分散的个体。


举个例子:

在写脚本的过程中,经常会遇到要写FOR循环,比如下面一个例子:

*** Test Cases ***
test
    ${t}    create list     abcde   fghijk
    :FOR    ${x}    IN      ${t}
    \   log     ${x}
然而,你会发现这样执行是错的,并没有吧${t}给迭代出来。正确的姿势应该是这样:

*** Test Cases ***
test
    ${t}    create list     abcde   fghijk
    :FOR    ${x}    IN      @{t}
    \   log     ${x}
第一个脚本中,For循环迭代的是一个标量,也就是一个整体,执行结果就会把整个list打印出来,而第
二个脚本中,迭代的是一个链表,也就是分散的个体,所以在循环的时候会被全部迭代出来打印。

再看一个直观的例子。

*** Settings ***
Library     Collections

*** Variables ***
@{t}    1   2   3

*** Test Cases ***
test
    log list    @{t}
上面的例子看脚本没毛病,直接打印定义的list变量@{t},但是执行的时候你会发现,执行失败了,报
错Keyword 'Collections.Log List' expected 1 to 2 arguments, got 3.,这里的@{t}使用的是链表,所
以相当于这个位置你给了1,2,3三个参数,而log list方法只能接受两个参数,所以这里报错了。

变量标识

${}这个表示定义一个变量,当然,在定义数字的时候,加上这个标识才是数值类型,比如:

*** Test Cases ***
test
    ${a}    set variable    ${4}
    ${b}    set variable    4
其中a获得的是数字4,b获得的是字符串4。在json中的提现就是{“a”: 4, "b": "4"}

布尔值真假用的是${true}和${false}

空格用的是${SPACE}

空变量用的是${EMPTY}

变量扩展

RobotFramework的变量可以很好的支持扩展,使用得当可以事半功倍。

变量拼接

*** Test Cases ***
test
    ${ip}       set variable    192.168.9.1
    ${a}        set variable  p
    log     ${i${a}}
====>   192.168.9.1   
上面的拼接方式中,RobotFramework会首先解析${a}这个变量,然后变量就变成了${ip},最终结果
打印的就是${ip}.

字典列表元素值的获取

字典取值示例
*** Test Cases ***
test
    ${a}    create dictionary   a=1     b=2
    log     ${a['a']}
====>   1   
RobotFramework的字典值的获取方式非常简单,跟Python是一个套路,

列表取值示例
*** Test Cases ***
test
    ${a}    create list   a     b
    log     ${a[0]}
====>   a   
当然,字典和列表是可以串在一起取值的,比如这样:

*** Test Cases ***
test
    ${b}    create dictionary   a=1
    ${c}    create dictionary   b=2
    ${a}    create list   ${b}  ${c}
    log     ${a[0]['a']}

====>   1   
变量文件

常用的变量文件的定义方式主要是在*.robot文件中定义Variable,值得一提的是,*.py是可以作为R
obotFramework的变量文件的。相比于RobotFramework,Python的格式定义更清晰一些,而且也是
支持字段和列表类型,例如:

test.py

OBJ = 'TEST'
DICT = {
    "CONFIG": "TEST"
}
LIST = [1, 2, 3, 4]
*** Settings ***
Variables  test.py

*** Test Cases ***
test
    log     ${OBJ}
    log     ${DICT['CONFIG']}
    log     ${LIST[0]}

====>
TEST
TEST
1   
如果只是这样,那么变量文件用*.py就没意义了,引入py的变量文件的意义在于,能够动态的获取
数据,举个例子:

test.py

import random

OBJ = random.randint(1, 100)
*** Settings ***
Variables  test.py

*** Test Cases ***
test
    log     ${OBJ}
每次执行时,获取的值都是1到100之间的随机数。同理,也可以自定义返回的规则,这种方式在某些
报文字段生成时,可以非常方便的给自己的规则。

如果你定义的是一个对象,那么还可以直接执行对象里面的方法。

  1. <p>test.py</p><p>
  2. </p><p>import random</p><p>
  3. </p><p>class Test(object):</p><p>    def __init__(self):</p><p>        pass</p><p>
  4. </p><p>    def random(self):</p><p>        return random.randint(1, 100)</p><p>
  5. </p><p>OBJ = Test()</p><p>*** Settings ***</p><p>Variables  test.py</p><p>
  6. </p><p>*** Test Cases ***</p><p>test</p><p>    log     ${OBJ.random()}</p>
复制代码




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-23 04:16 , Processed in 0.064202 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表