移动端自动化测试

Robot Framework13-RF共享变量

2019-07-29  本文已影响0人  筱媛媛

上节内容讲述了如何如何减少web窗口打开的次数,但是将用户名和密码写在用户关键字中则失去了代码的灵活性。对于这一类型的数据我们如何进行解决呢?本篇将对RF共享变量进行展开讲解,包括“py文件申明变量,测试套件文件申明变量,资源文件申明变量”。希望感兴趣的小伙伴可以坚持看下去同时欢迎提出宝贵的意见让我们一起进步!

01:本节内容介绍
RF共享变量思维导图.png
02:RF共享变量概述

1)引入目的:某些数据根据不同的环境可能会改变,若这些数据都散落在各个测试脚本文件中非常不利于统一修改
数据类型:任意python数据类型
2)解决办法:写在配置文件中variables表,即变量表中申明变量。

03:py文件申明变量

1)概述:使用python模块文件提供公共变量给RF使用。只需要直接定义变量就可以(语法和python一样)

2)
如何定义(cfg.py文件中

#定义变量
MgrLoginUrl=  ‘http://localhost/mgr/login/login.html’
#定义列表
database =     ['127.0.0.1', '3306']
#定义字典
user =         {'name':'auto','pw':'sdfsdfsdf'}

3)RF中声明变量文件并使用(Variables

*** Settings ***
Variables   cfg.py
case01
log to console  ${MgrLoginUrl}
log to console  ${database[0]}
log to console  ${database[1]}
log to console  &{user}[name]
log to console  &{user}[pw]

4)注意事项:

①变量申明的时候:可以使用绝对路径,也可以使用相对路径

②使用相对路径的时候,rf搜索规则和资源文件搜索规则一样

  • 先在相对当前文件的目录,匹配搜索。测试套件和py文件在同一目录:Variables cfg.py
  • 在python的模块搜索路径中搜索,测试套件文件和py文件不同目录:可以用 --pythonpath参数。比如:

cfg和t1文件在不同目录:导入时Variables ../cfg/cfg.py;执行时robot tc/t1.robot

对于目录经常发生变化也可以直接写(根据RF根目录来指定相对目录):robot --pythonpath . tc

命令行参数指定变量文件☆☆☆(使用此方法不需要在robot文件中单独声明,更灵活可以直接指定配置文件)比如:

cfg文件和t1文夹在同一目录(执行命令时的目录)robot --variablefile cfg.py t1.robotrobot --V cfg.py t1.robot

04:测试套件文件申明变量

1)概述:在测试套件文件变量表中声明的变量,对整个套件文件里面所有的测试用例都有效

2)数据类型:
如何定义(robot文件中)并使用

*** Variables ***
#定义变量
${MgrLoginUrl}  http://localhost/mgr/login/login.html
#定义列表
@{database}     127.0.0.1   3306
#定义字典
&{user}        name=auto   pw=sdfsdfsdf
*** Test Cases ***
case02
log to console  ${MgrLoginUrl}
log to console  ${database[0]}
log to console  ${database[1]}
log to console  &{user}[name]
log to console  &{user}[pw]

3)缺点:其作用范围只作用于该测试套件文件

3)改进:在资源文件申明变量

05:资源文件申明变量

1)概述:在资源文件变量表中声明的变量,只要导入对整个资源文件里面所有的测试用例都有效

2)数据类型:
如何定义

#定义变量
${MgrLoginUrl}  http://localhost/mgr/login/login.html
#定义列表
@{database}     127.0.0.1   3306
#定义字典
&{user}        name=auto   pw=sdfsdfsdf

3)RF中声明变量文件并使用

*** Settings ***
Resource  rc2.robot
*** Test Cases ***
case03
log to console  ${MgrLoginUrl}
log to console  ${database[0]}
log to console  ${database[1]}
log to console  &{user}[name]
log to console  &{user}[pw]
上一篇 下一篇

猜你喜欢

热点阅读