RobotFramework测试框架(11)--变量文件

2024-04-06 01:36

本文主要是介绍RobotFramework测试框架(11)--变量文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Variable files包含的variables可以用于test data中(即测试用例)中。Variables可以使用Variables section或者从命令行设置。
但是也允许动态创建。

变量文件通常使用模块实现,有两种实现方式。

1、直接从模块中获取变量

变量被指定为模块的属性。在简单的情况下,语法是如此简单,以至于不需要真正的编程。例如,创建一个变量,其值为指定的文本。这种方法的一个限制是它不允许使用参数。

MY_VAR = 'my value'

${MY_VAR}

2、从特殊函数获取变量

变量文件可以有一个特殊的方法(例如 get_variablesgetVariables),它返回一个作为映射的变量。因为这个方法可以接收参数,所以这种方法非常灵活。

另一种实现变量文件的方式是作为类,由框架来实例化这些类。在这种情况下,同样可以将变量创建为属性,或者从方法中动态获取它们。此外,变量文件也可以以YAML和JSON格式创建。例如,可以使用get_variables方法来获取这些变量。

使用变量文件

Setting section

所有的测试用例文件,可以在Setting section中使用Variables setting来导入变量文件。

*** Settings ***
Variables    myvariables.py
Variables    ../data/variables.py
Variables    ${RESOURCES}/common.yaml

命令行

--variablefile myvariables.py
--variablefile path/variables.py
--variablefile /absolute/path/common.py
--variablefile variablemodule
--variablefile arguments.py:arg1:arg2
--variablefile rootmodule.Variables:arg1:arg2

Getting variables directly from a module

基础语法

VARIABLE = "An example string"
ANOTHER_VARIABLE = "This is pretty easy!"
INTEGER = 42
STRINGS = ["one", "two", "kolme", "four"]
NUMBERS = [1, INTEGER, 3.14]
MAPPING = {"one": 1, "two": 2, "three": 3}

Using objects as values

变量文件中的变量不仅限于只包含字符串或其他基本类型作为值,就像变量部分一样。相反,它们的变量可以包含任何对象。在下面的示例中,变量包含一个Python字典,并且还有两个从同一文件中实现的自定义对象创建的变量。

MAPPING = {'one': 1, 'two': 2}class MyObject:def __init__(self, name):self.name = nameOBJ1 = MyObject('John')
OBJ2 = MyObject('Jane')

Creating variables dynamically

import os
import random
import timeUSER = os.getlogin()                # current login name
RANDOM_INT = random.randint(0, 10)  # random integer in range [0,10]
CURRENT_TIME = time.asctime()       # timestamp like 'Thu Apr  6 12:45:21 2006'
if time.localtime()[3] > 12:AFTERNOON = True
else:AFTERNOON = False

Selecting which variables to include

当Robot Framework处理变量文件时,它期望所有不以下划线开头的属性都是变量。这意味着在变量文件中创建或从其他地方导入的函数或类也被视为变量。例如,在之前的示例中,除了MY_DICT、MY_PERSON、MY_INT、MY_FLOAT和MY_LIST这些变量之外,如果变量文件中还定义了math函数或get_area函数,以及AREA1和AREA2变量,它们也会被当作变量处理。

通常,这些额外的变量不会造成问题,但它们可能会覆盖其他变量,导致难以调试的错误。为了避免这种情况,一种可能的做法是给不想作为变量的属性加上下划线前缀。这样,Robot Framework就会忽略这些以下划线开头的属性,不会将它们当作变量来处理。

import math as _mathdef _get_area(diameter):radius = diameter / 2.0area = _math.pi * radius * radiusreturn areaAREA1 = _get_area(1)
AREA2 = _get_area(2)

Getting variables from a special function

另一种获取变量的方法是在变量文件中定义一个特殊函数(也可以使用驼峰命名法)。如果这样的函数存在,Robot Framework会调用它,并期望它返回一个Python字典,其中键是变量名,值是变量值。创建的变量可以像直接从模块中获取变量一样,作为标量、列表和字典使用。此外,还可以使用LIST__和DICT__前缀来更明确地创建列表和字典变量。下面的示例在功能上等同于第一个直接从模块获取变量的示例。

def get_variables():variables = {"VARIABLE ": "An example string","ANOTHER VARIABLE": "This is pretty easy!","INTEGER": 42,"STRINGS": ["one", "two", "kolme", "four"],"NUMBERS": [1, 42, 3.14],"MAPPING": {"one": 1, "two": 2, "three": 3}}return variables

get_variables 函数也可以接受参数,这有助于改变实际创建的变量。函数的参数就像任何 Python 函数的参数一样设置。当使用变量文件时,参数在变量文件路径之后指定,在命令行中它们用冒号或分号与路径分隔。

以下是一个简单的示例,展示了如何使用带参数的变量文件。在一个更实际的例子中,参数可能是指向外部文本文件或数据库的路径,从中读取变量。

variables1 = {'scalar': 'Scalar variable','LIST__list': ['List','variable']}
variables2 = {'scalar' : 'Some other value','LIST__list': ['Some','other','value'],'extra': 'variables1 does not have this at all'}def get_variables(arg):if arg == 'one':return variables1else:return variables2

Implementing variable file as a class

变量文件总是使用文件系统路径来导入,因此类必须与它所在的模块具有相同的名称。

框架将使用无参数的方式创建类的一个实例,并从该实例中获取变量。与模块类似,变量可以直接定义为实例的属性,或者从特殊方法 get_variables 中获取。

当变量直接在实例中定义时,所有包含可调用值的属性都会被忽略,以避免从实例可能具有的方法中创建变量。如果你确实需要可调用的变量,你需要使用其他方法来创建变量文件。

在实践中,这意味着如果你的变量文件名为 example_variables.py,那么它应该包含一个名为 ExampleVariables 的类。当 Robot Framework 导入这个变量文件时,它会创建一个 ExampleVariables 类的实例,并从该实例中读取变量。

如果你选择使用 get_variables 方法来返回变量字典,你可以在该方法内定义任何逻辑来生成变量,包括读取外部文件、查询数据库或执行其他计算。然而,直接在类实例中定义变量通常更简单直接,但需要注意避免将方法作为变量暴露出来。

以下是一个简单的例子,展示了如何在变量文件的类实例中直接定义变量

The first examples create variables from attributes. It creates variables and from class attributes and from an instance attribute. V A R I A B L E @ L I S T {VARIABLE}@{LIST} VARIABLE@LIST{ANOTHER VARIABLE}

class StaticExample:variable = 'value'LIST__list = [1, 2, 3]_not_variable = 'starts with an underscore'def __init__(self):self.another_variable = 'another value'

The second examples utilizes dynamic approach for getting variables. It creates only one variable .${DYNAMIC VARIABLE}

class DynamicExample:def get_variables(self, *args):return {'dynamic variable': ' '.join(args)}

Variable file as YAML

string:   Hello, world!
integer:  42
list:- one- two
dict:one: yksitwo: kaksiwith spaces: kolme
*** Variables ***
${STRING}     Hello, world!
${INTEGER}    ${42}
@{LIST}       one         two
&{DICT}       one=yksi    two=kaksi    with spaces=kolme

Variable file as JSON

变量文件也可以实现为 JSON 文件。与上一节讨论的 YAML 类似,JSON 是一种数据序列化格式,旨在供人类和机器使用。它基于 JavaScript 语法,虽然不如 YAML 那么易于人类阅读,但仍然相对容易理解和修改。以下示例包含与前面 YAML 示例完全相同的数据:

{"string": "Hello, world!","integer": 42,"list": ["one","two"],"dict": {"one": "yksi","two": "kaksi","with spaces": "kolme"}
}

JSON 变量文件因其 .json 扩展名而自动被识别,并且它们可以像 YAML 变量文件一样使用。它们在结构、编码等方面的要求也完全相同。与 YAML 不同,Python 内置了对 JSON 的支持,因此无需安装任何额外的模块。

使用 JSON 变量文件时,你只需创建一个包含所需变量的 JSON 对象,并确保该文件具有 .json 扩展名。然后,在 Robot Framework 的命令行中指定该文件的路径,Robot Framework 将自动加载该文件,并将 JSON 对象中的键值对解析为可在测试用例中使用的变量。

例如,假设你有一个名为 variables.json 的 JSON 变量文件,内容如下:

{"USERNAME": "robot_user","PASSWORD": "secret_password","SERVER": "http://example.com"
}

你可以通过以下命令在 Robot Framework 中使用它:

robot --variablefile variables.json my_test_suite.robot

my_test_suite.robot 测试用例中,你可以直接使用 ${USERNAME}${PASSWORD}${SERVER} 这些变量。

由于 JSON 是一种广泛使用的数据交换格式,它非常适合用于在不同系统和工具之间传递变量。同时,由于其简单性和明确性,JSON 文件也更容易被非开发人员阅读和编辑。然而,如果你需要更复杂的逻辑或动态生成变量,Python 变量文件可能更加合适。

这篇关于RobotFramework测试框架(11)--变量文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878675

相关文章

C# 中变量未赋值能用吗,各种类型的初始值是什么

对于一个局部变量,如果未赋值,是不能使用的 对于属性,未赋值,也能使用有系统默认值,默认值如下: 对于 int 类型,默认值是 0;对于 int? 类型,默认值是 null;对于 bool 类型,默认值是 false;对于 bool? 类型,默认值是 null;对于 string 类型,默认值是 null;对于 string? 类型,哈哈,没有这种写法,会出错;对于 DateTime 类型,默

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

将一维机械振动信号构造为训练集和测试集(Python)

从如下链接中下载轴承数据集。 https://www.sciencedirect.com/science/article/pii/S2352340918314124 import numpy as npimport scipy.io as sioimport matplotlib.pyplot as pltimport statistics as statsimport pandas

js小题:通过字符串执行同名变量怎么做

在JavaScript中,你不能直接使用一个字符串来直接引用一个变量,因为JavaScript是一种静态类型语言(尽管它的类型在运行时可以变化),变量的名字在编译时就被确定了。但是,有几种方法可以实现类似的功能: 使用对象(或Map)来存储变量: 你可以使用一个对象来存储你的变量,然后使用字符串作为键来访问这些变量。 let myVars = { 'var1': 'Hello', 'var

[分布式网络通讯框架]----Zookeeper客户端基本操作----ls、get、create、set、delete

Zookeeper数据结构 zk客户端常用命令 进入客户端 在bin目录下输入./zkCli.sh 查看根目录下数据ls / 注意:要查看哪一个节点,必须把路径写全 查看节点数据信息 get /第一行代码数据,没有的话表示没有数据 创建节点create /sl 20 /sl为节点的路径,20为节点的数据 注意,不能跨越创建,也就是说,创建sl2的时候,必须确保sl

【服务器08】之【游戏框架】之【加载主角】

首先简单了解一下帧率 FixedUpdate( )   >   Update( )   >   LateUpdate( ) 首先FixedUpdate的设置值 默认一秒运行50次 虽然默认是0.02秒,但FiexedUpdate并不是真的0.02秒调用一次,因为在脚本的生命周期内,FixedUpdate有一个小循环,这个循环也是通过物理时间累计看是不是大于0.02了,然后调用一次。有

Java中的集合框架使用技巧

Java中的集合框架使用技巧 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们将深入探讨Java中集合框架的使用技巧,这些技巧能够帮助我们更高效地处理数据和优化程序性能。 Java集合框架概述 Java集合框架提供了一组实现了各种集合接口的类和接口,用于存储和操作数据。它包括列表、集合、队列和映射等数据结构,能够满足不

编译测试后出现“发现不明确的匹配”错误

原文链接:http://blog.163.com/zhaoyanping_1125/blog/static/201329153201204218533/ 错误提示: 【“/”应用程序中的服务器错误。  分析器错误 说明: 在分析向此请求提供服务所需资源时出错。请检查下列特定分析错误详细信息并适当地修改源文件。  分析器错误信息: 发现不明确的匹配。】   这个问题发生原因一般情况是

[分布式网络通讯框架]----ZooKeeper下载以及Linux环境下安装与单机模式部署(附带每一步截图)

首先进入apache官网 点击中间的see all Projects->Project List菜单项进入页面 找到zookeeper,进入 在Zookeeper主页的顶部点击菜单Project->Releases,进入Zookeeper发布版本信息页面,如下图: 找到需要下载的版本 进行下载既可,这里我已经下载过3.4.10,所以以下使用3.4.10进行演示其他的步骤。

C# 日志框架Serilog使用

1、框架和说明        C#日志框架Serilog支持多种场景输出,简单验证了一下,比较方便        包的安装,推荐直接使用“推荐NuGet包管理器”安装Serilog.AspNetCore,常见的组件都已经集成在一个包中,使用比较方便 2、配置文件        Serilog可以由配置文件来定义行为,而且配置文件的修改即时生效。参考配置文件如下: {"Serilog":