百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Robot Framework自动化测试框架(自动化测试框架工具)

off999 2024-11-03 14:15 28 浏览 0 评论

RF测试框架

RF(Robot Framework)是一个通用的开源自动化测试框架,通常使用python/java进行集成。简单的讲,RF可以把python中的函数名当成关键字,直接在RF框架中调用。

RF框架 --------> Python脚本 --------> 被测程序

网站链接

RF官网地址:https://robotframework.org/

RF使用指导:https://robotframework.org/robotframework/latest/RobotFrameworkUserGuide.html

RF下载地址:https://pypi.org/project/robotframework/

下载安装

python -m pip install robotframework

使用方法

robot [options] <paths>

示例:

robot mytest.robot
robot -l NONE -r NONE -o NONE mytest.robot
robot --loglevel=DEBUG -s ovs myconf.robot

options是选项,其中-l NONE是禁用html的log输出,-r NONE是禁用html的报告输出,-o NONE是禁用XML的日志输出,--loglevel指定日志的级别,-s指定测试套(测试用例所在目录)。paths是一般是项目的配置文件,也可以是测试用例文件,均为.robot后缀。使用robot --help可以查看更多的帮助信息。

工程目录

一般的工程目录结构如下(只包含robot配置文件和robot测试用例,不包含python脚本):

my_project/
    test_configs/
        config1.robot
        config2.robot
        ...
    test_scripts/
        script1.py
        script2.py
        ...
    test_suite1/
        __init__.robot
        my_test1.robot
        my_test2.robot
        ...
    test_suite2
        __init__.robot
        my_test3.robot
        ...

变量类型

${}表示标准变量

&{}表示字典变量

@{}表示链表变量

脚本调用

RF的一个非常有用的特性是,在.robot文件中可以直接调用.py文件的函数。比如在 `mylib.py` 中有如下函数:

def add_numbers(a, b):
    return a + b

只需要在.robot文件中导入mylib.py:

*** Settings ***
Library    mylib.py

就可以通过如下方式调用(忽略大小写、忽略空格、忽略下划线):

*** Test Cases ***
mytest
    ${sum}=    add_numbers    3    4
    ${sum}=    Add_Numbers    3    4
    ${sum}=    addnumbers_    3    4
    ${sum}=    _addnumbers    3    4
    ${sum}=    aDd_nUMbers    3    4
    ${sum}=    add numbers    3    4
    ${sum}=    ADD NUMBERS    3    4

注意:RF的log关键字和python中的print具有同样的效果,都将内容打印到output.xml中。

使用举例

以下代码使用Python的`signal`和`scapy`库来实现UDP数据包的捕获和发送,并利用多线程来实现并发执行:

`captured`用于记录已捕获的数据包数量,

`stop`用于通知捕获数据包的线程停止执行,

`stop_event()`函数用于判断停止事件是否触发。

`handle_packets()`函数用于处理捕获到的数据包,此处我们只关心UDP协议,并且只对目标端口为12580的数据包进行计数。

`send_packets()`函数用于发送UDP数据包,这里我们使用`sendp()`函数来发送500个UDP数据包。

`sniff_packets()`函数用于捕获数据包,内部调用`sniff()`函数,并通过`filter`参数指定过滤条件,`prn`参数指定回调函数,`stop_filter`参数指定是否停止抓包。

`test_udp`函数是测试主函数,它创建了两个线程,分别用于捕获数据包和发送数据包。然后通过调用`start()`方法启动线程,实现并发执行。最后,调用`join()`方法等待发送数据包的线程结束后再执行后续代码,并将`stop`变量设置为1,通知捕获数据包的线程停止执行。

from signal import *
from scapy.all import *
import threading
captured = 0
stop = 0

def stop_event(event):
    global stop
    return stop == 1

def handle_packets(packet):
    global captured
    if packet.haslayer(UDP):
        if (packet[UDP].dport == 12580):
            captured += 1

def send_packets():
    sendp(Ether()/IP(dst='127.0.0.1')/UDP(dport=12580), inter=0.01, count=500, verbose=False)

def sniff_packets():
    sniff(filter='udp', prn=handle_packets, stop_filter=stop_event)

def test_udp():
    global stop
    sniffer = threading.Thread(target=sniff_packets)
    sniffer.start()
    sender = threading.Thread(target=send_packets)
    sender.start()
    sender.join()
    stop = 1
    sniffer.join()
    return captured

robot自动化

*** Settings ***
Library    testlib.py
Library    String

*** Test Cases ***
Example Test
    ${result}=    test_udp
    Should Be Equal As Strings    ${result}    500

内置关键字

参考RF使用指导:https://robotframework.org/robotframework/latest/RobotFrameworkUserGuide.html

Call Method
Catenate
Comment
Continue For Loop
Continue For Loop If
Convert To Binary
Convert To Boolean
Convert To Bytes
Convert To Hex
Convert To Integer
Convert To Number
Convert To Octal
Convert To String
Create Dictionary
Create List
Evaluate
Exit For Loop
Exit For Loop If
Fail
Fatal Error
Get Count
Get Length
Get Library Instance
Get Time
Get Variable Value
Get Variables
Import Library
Import Resource
Import Variables
Keyword Should Exist
Length Should Be
Log
Log Many
Log To Console
Log Variables
No Operation
Pass Execution
Pass Execution If
Regexp Escape
Reload Library
Remove Tags
Repeat Keyword
Replace Variables
Return From Keyword
Return From Keyword If
Run Keyword
Run Keyword And Continue On Failure
Run Keyword And Expect Error
Run Keyword And Ignore Error
Run Keyword And Return
Run Keyword And Return If
Run Keyword And Return Status
Run Keyword And Warn On Failure
Run Keyword If
Run Keyword If All Tests Passed
Run Keyword If Any Tests Failed
Run Keyword If Test Failed
Run Keyword If Test Passed
Run Keyword If Timeout Occurred
Run Keyword Unless
Run Keywords
Set Global Variable
Set Library Search Order
Set Local Variable
Set Log Level
Set Suite Documentation
Set Suite Metadata
Set Suite Variable
Set Tags
Set Task Variable
Set Test Documentation
Set Test Message
Set Test Variable
Set Variable
Set Variable If
Should Be Empty
Should Be Equal
Should Be Equal As Integers
Should Be Equal As Numbers
Should Be Equal As Strings
Should Be True
Should Contain
Should Contain Any
Should Contain X Times
Should End With
Should Match
Should Match Regexp
Should Not Be Empty
Should Not Be Equal
Should Not Be Equal As Integers
Should Not Be Equal As Numbers
Should Not Be Equal As Strings
Should Not Be True
Should Not Contain
Should Not Contain Any
Should Not End With
Should Not Match
Should Not Match Regexp
Should Not Start With
Should Start With
Skip
Skip If
Sleep
Variable Should Exist
Variable Should Not Exist
Wait Until Keyword Succeeds

相关推荐

阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?

TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...

高流量大并发Linux TCP性能调优_linux 高并发网络编程

其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...

性能测试100集(12)性能指标资源使用率

在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...

Linux 服务器常见的性能调优_linux高性能服务端编程

一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...

Nginx性能优化实战:手把手教你提升10倍性能!

关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...

高并发场景下,Spring Cloud Gateway如何抗住百万QPS?

关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...

Kubernetes 高并发处理实战(可落地案例 + 源码)

目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...

高并发场景下,Nginx如何扛住千万级请求?

Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...

Spring Boot+Vue全栈开发实战,中文版高清PDF资源

SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...

Docker-基础操作_docker基础实战教程二

一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...

你有空吗?跟我一起搭个服务器好不好?

来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...

部署你自己的 SaaS_saas如何部署

部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...

Docker Compose_dockercompose安装

DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...

京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统

前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...

Kubernetes (k8s) 入门学习指南_k8s kubeproxy

Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...

取消回复欢迎 发表评论: