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

相关文章

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb