当前位置: 首页 > news >正文

通用开源自动化测试框架 - Robot Framework

一、什么是 Robot Framework?

1. Robot Framework 的历史由来

Robot Framework是一种通用的自动化测试框架,最早由Pekka Klärck在2005年开发,并由Nokia Networks作为内部工具使用。后来,该项目以开源形式发布,并得到了广泛的社区支持和贡献。

2.官方介绍:

Robot Framework is a generic open source automation framework. It can be used for test automation and robotic process automation (RPA).
Robot Framework 是一个通用的开源自动化框架。它可用于测试自动化和机器人流程自动化 (RPA)。

Robot Framework is supported by Robot Framework Foundation. Many industry-leading companies use the tool in their software development.
Robot Framework 由 Robot Framework Foundation 提供支持。许多行业领先的公司在其软件开发中使用该工具。

Robot Framework is open and extensible. Robot Framework can be integrated with virtually any other tool to create powerful and flexible automation solutions. Robot Framework is free to use without licensing costs.
机器人框架是开放且可扩展的。Robot Framework几乎可以与任何其他工具集成,以创建强大而灵活的自动化解决方案。Robot Framework 可免费使用,无需许可费用。

Robot Framework has an easy syntax, utilizing human-readable keywords. Its capabilities can be extended by libraries implemented with Python, Java or many other programming languages. Robot Framework has a rich ecosystem around it, consisting of libraries and tools that are developed as separate projects.
Robot Framework 具有简单的语法,使用人类可读的关键字。它的功能可以通过使用 Python、Java 或许多其他编程语言实现的库来扩展。Robot Framework 拥有丰富的生态系统,由作为独立项目开发的库和工具组成。

3. 基本语法

  • 测试用例以*** Test Cases ***开头,后跟一个或多个测试用例。
  • 关键字定义以*** Keywords ***开头,后跟一个或多个关键字定义。
  • 测试用例和关键字定义使用缩进来表示层次结构。
  • 关键字和关键字参数之间使用制表符或多个空格分隔。

4. Code is worth a thousand words代码胜过千言万语

简单示例
此示例包含用户登录的单个测试用例。它使用模拟的后端 API 进行用户管理。该测试套件TestSuite.robot包含两个测试用例“使用密码登录用户”和“使用错误密码拒绝登录”。此测试用例从资源文件 keywords.resource 调用关键字。

TestSuite.robot:

*** Settings ***
Documentation     A test suite for valid login.
...
...               Keywords are imported from the resource file
Resource          keywords.resource
Default Tags      positive*** Test Cases ***
Login User with PasswordConnect to ServerLogin User            ironman    1234567890Verify Valid Login    Tony Stark[Teardown]    Close Server ConnectionDenied Login with Wrong Password[Tags]    negativeConnect to ServerRun Keyword And Expect Error    *Invalid Password    Login User    ironman    123Verify Unauthorised Access[Teardown]    Close Server Connection

Resource File 资源文件
keywords.resource 包含关键字定义。资源文件还使用库 CustomLibrary.py 中基于 python 的关键字来实现更专业的功能。存在无数社区制作的库,它们以各种方式扩展了机器人框架!

keywords.resource:

*** Settings ***
Documentation     This is a resource file, that can contain variables and keywords.
...               Keywords defined here can be used where this Keywords.resource in loaded.
Library           CustomLibrary.py*** Keywords ***
Connect to ServerConnect    fe80::aede:48ff:fe00:1122Close Server ConnectionDisconnectLogin User[Arguments]    ${login}    ${password}Set Login Name    ${login}Set Password    ${password}Execute LoginVerify Valid Login[Arguments]    ${exp_full_name}${version}=    Get Server VersionShould Not Be Empty    ${version}${name}=    Get User NameShould Be Equal    ${name}    ${exp_full_name}Verify Unauthorised AccessRun Keyword And Expect Error    PermissionError*    Get Server VersionLogin Admin[Documentation]    'Login Admin' is a Keyword....                It calls 'Login User' from 'CustomLibrary.py'Login User    admin    @RBTFRMWRK@Verify Valid Login    Administrator

CustomLibrary.py:

from TestObject import TestObject
from robot.api.logger import info, debug, trace, consoleclass CustomLibrary:'''This is a user written keyword library.These libraries can be pretty handy for more complex tasks an typicallymore efficiant to implement compare to Resource files.However, they are less simple in syntax and less transparent in test protocols.The TestObject object (t) has the following public functions:class TestObject:def authenticate(self, login: str, password: str) -> str: ...def logout(self, token): ...def get_version(self, token) -> str: ...def get_user_id(self, token, login) -> str: ...def get_user_name(self, token, user_id) -> str: ...def get_user(self, token, user_id=None) -> Dict[str, str]: ...def get_user_all(self, token) -> List[Dict[str, str]]: ...def delete_user(self, token, userid): ...def get_logout(self, token): ...def put_user_password(self, token, new_password, user_id=None): ...def put_user_name(self, token, name, user_id=None): ...def put_user_right(self, token, right, user_id): ...def post_new_user(self, token, name, login) -> str: ...'''ROBOT_LIBRARY_SCOPE = 'SUITE'def __init__(self) -> None:self._session = Noneself.login = ''self.password = ''self._connection: TestObject = Nonedef connect(self, ip):self._connection = TestObject(ip)def disconnect(self):self._connection = None@propertydef connection(self):if not self._connection:raise SystemError('No Connection established! Connect to server first!')return self._connection@propertydef session(self):if self._session is None:raise PermissionError('No valid user session. Authenticate first!')return self._sessiondef set_login_name(self, login):'''Sets the users login name and stores it for authentication.'''self.login = logininfo(f'User login set to: {login}')def set_password(self, password):'''Sets the users login name and stores it for authentication.'''self.password = passwordinfo(f'Password set.')def execute_login(self):'''Triggers the authentication process at the backend and stores the session token.'''self._session = self.connection.authenticate(self.login, self.password)if self.session:info(f'User session successfully set.')debug(f'Session token is: {self.session}')self.login = self.password = ''def login_user(self, login, password) -> None:'''`Login User` authenticates a user to the backend.The session will be stored during this test suite.'''self._session = self.connection.authenticate(login, password)def logout_user(self):'''Logs out the current user.'''self.connection.logout(self.session)def create_new_user(self, name, login, password, right):'''Creates a new user with the give data.'''user_id = self.connection.post_new_user(self.session, name, login)self.connection.put_user_password(self.session, password, user_id=user_id)self.connection.put_user_right(self.session, right, user_id)def change_own_password(self, new_password, old_password):'''Changes the own password given the new and current one.'''self.connection.put_user_password(self.session, new_password, old_password)def change_users_password(self, login, new_password):'''Changes the password of a user by its name.Requires Admin priviliges!'''user_id = self.get_user_id(login)self.connection.put_user_password(self.session, new_password, user_id=user_id)def get_all_users(self):'''`Get All Users` does return a list of user-dictionaries.A user dictionary has the keys `name`, `login`, `right` and `active`.This keyword need Admin privileges.Example:`{'name': 'Peter Parker', 'login': 'spider', 'right': 'user', 'active': True}`'''return self.connection.get_user_all(self.session)def get_user_details(self, user_id=None):'''Returs the user details of the given user_id or if None the own user data.'''return self.connection.get_user(self.session, user_id)def get_user_id(self, login):'''Returns the user_id based on login.'''return self.connection.get_user_id(self.session, login)def get_username(self, user_id=None):'''Returns the users full name of the given user_id or if None the own user data.'''return self.connection.get_user_name(self.session, user_id)def get_server_version(self):return self.connection.get_version(self.session)

二、为什么选择 Robot Framework

Robot Framework支持插件化的架构,可以使用许多内置库和第三方库来扩展功能,例如SeleniumLibrary用于Web自动化测试,RequestsLibrary用于API测试等。

1. Robot Framework 的常见用法

Robot Framework可用于各种自动化测试任务,包括:

  • Web应用测试
  • API测试
  • 数据库测试
  • 移动应用测试
  • 自动化任务和流程
  • 持续集成和部署

2. 常见关键字库

Robot Framework有广泛的关键字库可供使用,以下是一些常见的关键字库:

  • SeleniumLibrary:用于Web应用测试,包括页面操作、表单填写、页面验证等。
  • RequestsLibrary:用于发送HTTP请求,进行API测试。
  • DatabaseLibrary:用于数据库测试,支持各种数据库操作。
  • SSHLibrary:用于通过SSH执行命令和操作远程服务器。
  • ExcelLibrary:用于读写Excel文件。
  • DateTimeLibrary:用于日期和时间相关操作。

3. 技术架构和原理

Robot Framework的技术架构基于关键字驱动的测试方法。它使用Python语言编写,通过解析测试用例文件和执行测试步骤来实现自动化测试。

Robot Framework的核心原理如下:

  1. 测试用例文件(通常使用.robot扩展名)包含测试用例、关键字定义和设置。
  2. 测试执行器(test runner)读取并解析测试用例文件。
  3. 测试执行器调用相应的关键字库(如SeleniumLibrary、RequestsLibrary等)执行测试步骤。
  4. 关键字库提供了一组关键字(如打开浏览器、点击按钮等)来操作被测试的系统。
  5. 执行结果被记录下来,并生成报告和日志文件。

三、怎么使用 Robot Framework

1. Robot Framework的安装方法

1. 安装Python

Robot Framework是基于Python的,所以首先需要安装Python。你可以从Python官方网站(https://www.python.org)下载适合你操作系统的Python安装程序,并按照官方指南进行安装。

2. 安装Robot Framework

一旦Python安装完成,你可以使用Python的包管理工具pip来安装Robot Framework。打开终端或命令提示符窗口,并执行以下命令:

pip install robotframework

这将下载并安装最新版本的Robot Framework及其依赖项。

3. 安装额外的关键字库

根据你的测试需求,你可能需要安装额外的关键字库。例如,如果你需要进行Web应用测试,可以安装SeleniumLibrary。以安装SeleniumLibrary为例,执行以下命令:

pip install robotframework-seleniumlibrary

类似地,你可以使用pip命令安装其他关键字库,具体取决于你的需求。

4. 验证安装

安装完成后,你可以验证Robot Framework是否成功安装。在终端或命令提示符窗口中执行以下命令:

robot --version

如果成功安装,它将显示安装的Robot Framework的版本号。

2. 自动化测试用例常见实例代码

示例1:Web应用测试

*** Settings ***
Library    SeleniumLibrary*** Test Cases ***
Open Browser and Verify TitleOpen Browser    https://www.example.com    chromeTitle Should Be    Example DomainClose Browser

示例2:API测试

*** Settings ***
Library    RequestsLibrary*** Test Cases ***
Get User DetailsCreate Session    Example API    https://api.example.com${response}    Get Request    Example API    /users/123Should Be Equal As Strings    ${response.status_code}    200${user_details}    Set Variable    ${response.json()}Log    ${user_details}Delete All Sessions

示例3:数据库测试

*** Settings ***
Library    DatabaseLibrary
Library    Collections*** Test Cases ***
Verify User in DatabaseConnect To Database    pymysql    mydatabase    myusername    mypassword@{query_result}    Query    SELECT * FROM users WHERE id = '123'Should Contain    ${query_result}    username=JohnDisconnect From Database

示例4:SSH操作

*** Settings ***
Library    SSHLibrary*** Test Cases ***
Execute Command on Remote ServerOpen Connection    192.168.1.100    username=myusername    password=mypassword${output}    Execute Command    ls /path/to/directoryShould Contain    ${output}    myfile.txtClose Connection

示例5:Excel操作

*** Settings ***
Library    ExcelLibrary*** Test Cases ***
Read Data From ExcelOpen Excel    path/to/excel/file.xlsx${cell_value}    Read Cell Data By Name    Sheet1    A1Log    ${cell_value}Close Excel

四、相关链接

  • Robot Framework官方网站
  • Robot Framework用户指南
  • Robot Framework论坛
  • Robot Framework Github

RobotFramework基金会成员
RobotFramework基金会成员

相关文章:

通用开源自动化测试框架 - Robot Framework

一、什么是 Robot Framework? 1. Robot Framework 的历史由来 Robot Framework是一种通用的自动化测试框架,最早由Pekka Klrck在2005年开发,并由Nokia Networks作为内部工具使用。后来,该项目以开源形式发布,并得到了…...

css position属性与js滚动

“视口”就是浏览器窗口中实际显示文档内容的区域,不包含浏览器的“外框”,如菜单、工具条和标签。文档则是指整个网页。 1 css 的position static 正常定位,是元素position属性的默认值,元素遵循常规流。 relative 相对定位&…...

python内置模块hashlib对于字符串的加密解密加盐

hash是一类算法而hashlib模块是Python的一个内置模块,主要功能是使用对应的hash算法,加密二进制内容解密二进制内容 常见的hash算法有md5、sha1,sha256, sha512等 特点 1.内容敏感,那怕一个很小的字符发生改变都很明显 2.不可逆,不能逆向求值…...

获取客户端请求IP及IP所属城市

添加pom依赖 <dependency> <groupId>org.lionsoul</groupId> <artifactId>ip2region</artifactId> <version>2.6.5</version> </dependency> public class IpUtil { private…...

【洛谷 P1106】删数问题 题解(贪心+字符串)

删数问题 题目描述 键盘输入一个高精度的正整数 N N N&#xff08;不超过 250 250 250 位&#xff09;&#xff0c;去掉其中任意 k k k 个数字后剩下的数字按原左右次序将组成一个新的非负整数。编程对给定的 N N N 和 k k k&#xff0c;寻找一种方案使得剩下的数字组成…...

【Python · PyTorch】线性代数 微积分

本文采用Python及PyTorch版本如下&#xff1a; Python&#xff1a;3.9.0 PyTorch&#xff1a;2.0.1cpu 本文为博主自用知识点提纲&#xff0c;无过于具体介绍&#xff0c;详细内容请参考其他文章。 线性代数 & 微积分 1. 线性代数1.1 基础1.1.1 标量1.1.2 向量长度&…...

建模和图表工具:Software Ideas Modeler Crack

用于图表、软件设计和分析的 CASE 工具 Software Ideas Modeler 是一款智能CASE 工具和 图表软件&#xff0c;支持 UML、SysML、ERD、BPMN、ArchiMate、流程图、用户故事、线框图。 提升用户体验和人工智能集成 - Software Ideas Modeler 14.05 最近发布的 14.05 版本带来了一…...

Android开发,车载通讯应用——binder通讯原理解析

Binder简单理解 简单来说&#xff0c;Binder 就是用来Client 端和 Server 端通信的。并且 Client 端和 Server 端 可以在一个进程也可以不在同一个进程&#xff0c;Client 可以向 Server 端发起远程调用&#xff0c;也可以向Server传输数据&#xff08;当作函数参数来传&#…...

[算法]求n!在m进制下末尾有多少个0

参考链接&#xff1a;求n&#xff01;在m进制下末尾0的个数_.!零n,,m-CSDN博客 我们这里和参考链接不同 使用结构体去存储每个因数的信息 然后使用变量index作为索引&#xff0c;其最终值为因数的个数 具体原理&#xff1a; 例子1&#xff1a;求9&#xff01;在10进制下的…...

mysql之用户管理、权限管理、密码管理

用户管理 创建用户create user 杨20.0.0.13 identified by 123; 用户重命名rename user 杨20.0.0.13 to yang20.0.0.13; 删除用户drop user 杨20.0.0.13; 权限管理 查看用户权限show grants for 杨20.0.0.13; 赋予用户权限grant all privileges on *.* to 杨localhost id…...

图情档核心期刊 | 北大核心、CSSCI、CSCD

中文核心期刊要目总览&#xff08;A Guide to the Core Journal of China&#xff0c; 简称北大核心&#xff09;&#xff1a; 主办单位&#xff1a;北京大学图书馆更新频率&#xff1a;北大核心在2008年之前每4年更新研究和编制出版一次&#xff0c;2008年之后&#xff0c;改为…...

Mac上具好用的屏幕录像工具(Omi录屏专家)Screen Recorder By Omi Mac 下载安装详细教程

Omi 录屏专家 是 Mac 上的一款出色的录音工具&#xff0c;它让您能够在Mac电脑上轻松录制和保存高质量音频。这款应用拥有简单直观的操作界面&#xff0c;无论我们水平如何&#xff0c;都可以轻松捕捉录制卓越的音质和录像视频。 该版本的 Omi 安装后可以直接支持最高 4K 60帧…...

牛客网刷题-(8)

&#x1f308;write in front&#x1f308; &#x1f9f8;大家好&#xff0c;我是Aileen&#x1f9f8;.希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流. &#x1f194;本文由Aileen_0v0&#x1f9f8; 原创 CSDN首发&#x1f412; 如…...

oracle 重启步骤及踩坑经验

oracle 重启步骤及踩坑经验 标准重启步骤 切换到oracle用户 su - oracle关闭监听 lsnrctl stop杀掉oracle有关进程 ps -ef|grep $ORACLE_SID|grep -v ora_|grep LOCALNO|awk {print $2}|xargs kill -9#查询pid ps -ef|grep $ORACLE_SID|grep -v ora_|grep LOCALNO|awk {p…...

处理mysql数据量大查询缓慢问题(最少百万才有差别)

我建了两个表&#xff0c;一个售后单表&#xff0c;一个售后商品明细表&#xff0c;都是五十个字段。 select * FROM (select id, as_id, as_date, outer_as_id, so_id, type, created, modified, status, status_name, shop_status, shop_status_name, remark, question_type,…...

element-plus走马灯不显示

问题描述 依赖正确&#xff0c;代码用法正确&#xff0c;但是element-plu走马灯就是不显示&#xff01;&#xff01; <div class"content"><el-carousel height"150px" width"200px"><el-carousel-item v-for"item in 4&qu…...

【精】UML及软件管理工具汇总

目录 1 老七工具&#xff08;规划质量&#xff09; 1.1 因果图&#xff08;鱼骨图、石川图&#xff09; 1.2 控制图 1.3 流程图:也称过程图 1.4 核查表:又称计数表 1.5 直方图 1.6 帕累托图 1.7 散点图&#xf…...

【uniapp+vue3】scroll-view实现纵向自动滚动及swiper实现纵向自动滚动

scroll-view本身不支持自动滚动&#xff0c;通过scroll-top属性控制滚动&#xff0c;但是不可以循环滚动 <scroll-view class"notice-bar" scroll-y"true" ref"scrollViewRef" :scroll-top"data.scrollViewTop"scroll-with-animati…...

this.refs[‘tagInput‘].refs.input.focus()和this.$refs[‘tagInput‘].focus()区别

this.$refs[tagInput].$refs.input.focus()和this.$refs[tagInput].focus()两者之间的选择取决于你的组件结构和如何访问DOM元素。 1.this.$refs[tagInput].$refs.input.focus(): 2.这种语法假设你的this.$refs[tagInput]是一个组件实例&#xff0c;并且这个组件实例有一个名为…...

电脑硬件坏了,如何维修?

在电子设备日益普及的今天&#xff0c;电脑已成为很多人生活和工作中不可或缺的工具&#xff0c;然而在使用过程中很容易遇见电脑故障之类的问题&#xff0c;这些问题十有八九来自硬件&#xff0c;那么针对电脑硬件问题&#xff0c;该如何维修&#xff1f; 一般来说&#xff0c…...

逻辑回归:给不确定性划界的分类大师

想象你是一名医生。面对患者的检查报告&#xff08;肿瘤大小、血液指标&#xff09;&#xff0c;你需要做出一个**决定性判断**&#xff1a;恶性还是良性&#xff1f;这种“非黑即白”的抉择&#xff0c;正是**逻辑回归&#xff08;Logistic Regression&#xff09;** 的战场&a…...

django filter 统计数量 按属性去重

在Django中&#xff0c;如果你想要根据某个属性对查询集进行去重并统计数量&#xff0c;你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求&#xff1a; 方法1&#xff1a;使用annotate()和Count 假设你有一个模型Item&#xff0c;并且你想…...

什么是库存周转?如何用进销存系统提高库存周转率?

你可能听说过这样一句话&#xff1a; “利润不是赚出来的&#xff0c;是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业&#xff0c;很多企业看着销售不错&#xff0c;账上却没钱、利润也不见了&#xff0c;一翻库存才发现&#xff1a; 一堆卖不动的旧货…...

Rust 异步编程

Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

AI编程--插件对比分析:CodeRider、GitHub Copilot及其他

AI编程插件对比分析&#xff1a;CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展&#xff0c;AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者&#xff0c;分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

laravel8+vue3.0+element-plus搭建方法

创建 laravel8 项目 composer create-project --prefer-dist laravel/laravel laravel8 8.* 安装 laravel/ui composer require laravel/ui 修改 package.json 文件 "devDependencies": {"vue/compiler-sfc": "^3.0.7","axios": …...

LeetCode - 199. 二叉树的右视图

题目 199. 二叉树的右视图 - 力扣&#xff08;LeetCode&#xff09; 思路 右视图是指从树的右侧看&#xff0c;对于每一层&#xff0c;只能看到该层最右边的节点。实现思路是&#xff1a; 使用深度优先搜索(DFS)按照"根-右-左"的顺序遍历树记录每个节点的深度对于…...

Ubuntu系统多网卡多相机IP设置方法

目录 1、硬件情况 2、如何设置网卡和相机IP 2.1 万兆网卡连接交换机&#xff0c;交换机再连相机 2.1.1 网卡设置 2.1.2 相机设置 2.3 万兆网卡直连相机 1、硬件情况 2个网卡n个相机 电脑系统信息&#xff0c;系统版本&#xff1a;Ubuntu22.04.5 LTS&#xff1b;内核版本…...

手动给中文分词和 直接用神经网络RNN做有什么区别

手动分词和基于神经网络&#xff08;如 RNN&#xff09;的自动分词在原理、实现方式和效果上有显著差异&#xff0c;以下是核心对比&#xff1a; 1. 实现原理对比 对比维度手动分词&#xff08;规则 / 词典驱动&#xff09;神经网络 RNN 分词&#xff08;数据驱动&#xff09…...