通过RF来跑selenium的脚本,正常运行一遍都没有问题,但如果要多次运行,提高脚本的稳定性,那么应该如何做呢?
 当然有时候最简单最简单的方法就是直接通过sleep来等待,虽然简单粗暴,但会带来效率的下降
 这一阶段一直在搞几个场景的脚本,记录下当中可能遇到的问题
1 绝对不能每一步都去判断等待,重试
     虽然通过方法,我们可以让页面等待元素出现,可以直接去判断每一步是否执行成功,然后通过每一步是否执行成功来判断是否需要重试
    但没有效率,而且也没有必要
    实际感觉即使不加判断等待,可能八成的脚本都是可以正常执行通过的
    如一般简单的文本框中输入文字,这些不需要太关注
    在RF中,可以通过统一添加

   wait until keyword succeeds
   就是如果执行不成功,则多次尝试点击,但这个如果失败,就直接执行失败了

2 一些场景尤其需要注意判断,像查询
   如查询,因为查询之后一定会需要一段时间去加载等待,而且这个等待时间可能是不固定的,如果你不是采用固定等待的方法,那么就需要去考虑我如何判断查询已经成功返回
   如果查询返回的是一个table,,那么可以通过判断table的行数的变化,或者table中一些属性的变化
   尽量去比较下,当查询前,和查询后到底有什么区别,如果找到区别,就可以通过wait语句去等待这个变化的出现
   在RF中,可以用比较粗暴的方法,用一段FOR结构,循环判断,如果出现了退出的条件,则退出循环,然后固定等待sleep 1
   这样的结构,最多可能就等待5s,10s,而且可控,又不是把等待完全交给语句
   FOR   ${i}     IN  RANGE   1    10
         判断是否成功的元素,如等待或者获取
         exit for loop   退出的条件
         sleep 1 
 
3  最稳妥的判断
   如果点击出现一个对话框,但执行的时候,可能不出现,可能出现
   如果不应该出现的时候出现了,可能就会导致脚本直接失败
   如果要最稳妥的处理,那么可以通过  Run Keyword And Ignore Error
  来判断,这个语句可以返回执行的结果是PASS还是FAIL
  那么可以先   ${result}     Run Keyword And Ignore Error   等待控件   如等待对话框出现 
 后面就根据这个result,如果出现,那么点击,如果不出现不点击
 Run Keyword And Ignore Error 不影响脚本的执行结果,不会把结果变成失败
 
4  RF中的IF
  RF中的IF结构非常不好写,随意尽量不要添加复杂的判断
  官网的例子
   

  如果遇到字符串判断,可以给变量添加“”
  如  ”${status}“ == “PASS”

5 数据异常
  其实出现异常,还有一种可能是数据
  如原来已有数据了,可能你添加就会报重复,可能有的提示就不会出现
   这时候要注意数据,当然最好是通过数据库直接来复制或者检查,在执行前进行数据整理,在执行后数据清理
   有一些数据可能从UI中是无法删除,那么可能就需要直接从库中删除
   但所有处理都会花费太多的时间和成本
   如果比较简单,可能就执行前人工看下
 
6  无法避免的异常
    实际执行中即使你加了再多的判断,还是可能会出现一些无法想到的意外
    如遇到过,执行的时候,直接返回接口异常
    所以自动化的前提,还是系统本身是稳定的,如果本身系统就不够强壮,你可能遇到的异常就越多

7  每次执行,遇到异常都要分析
    可能刚调试好的脚本,你执行一次没有问题,那多执行几次,如果出现了异常,就要去分析异常出现的可能
    只要出现过一次异常,那么下一次就有可能会再次出现
    实际总,运行,判断查询,虽然已经加了判断,但有一次出现了不正常
    后来修改了判断,加强了判断,也许下次就不会再出现
   所以所谓的稳定就是在一次次的运行中,分析,修改,加强
 
8  判断脚本的稳定
     最简单的方法,就是不断重复运行
     如果保证网络正常,浏览器正常
    可以制定一个指标,如跑10,或者20,都没有异常,则认为脚本是可以的
    毕竟没有可视化的所谓稳定,还是需要通过直观的数据去判断
 =========================================================
 这只是在用RF+Selenium做几个脚本时的思考
 毕竟有时候,我们看一些课程都是百度查询,那个都太简单了,基本不会遇到什么异常
 但实际中会遇到各种可能性
 
 

RobotFramework+Selenium如何提高脚本稳定性的更多相关文章

  1. Selenium执行测试脚本稳定性的一些经验分享交流

    Selenium执行测试脚本稳定性的一些经验分享交流 公司的自动化WEB测试框架IATA已上线运行了一段时间,期间发现一些脚本稳定性的问题,与大家分享一下. CASE执行游览器:ie firefox ...

  2. 连载三:RobotFramework+Selenium+Jenkins分布式构建

    目标:Jenkins安装在服务器上,而使用Jenkins调用本机的脚本并在本机执行. 步骤: (1)需要有RobotFrameWork+Selenium的运行环境: python2.7,Robotfr ...

  3. selenium基础(脚本模块化)

    selenium基础(脚本模块化)

  4. Selenium执行JavaScript脚本

    JavaScript是运行在客户端(浏览器)和服务器端的脚本语言,允许将静态网页转换为交互式网页.可以通过 Python Selenium WebDriver 执行 JavaScript 语句,在We ...

  5. 使用Python的selenium库制作脚本,支持后台运行

    本文介绍如何使用Python的selenium库制作脚本.概念:       Selenium是一个用于测试网站的自动化测试工具,支持各种浏览器包括Chrome.Firefox.Safari等主流界面 ...

  6. Selenium 脚本稳定性问题

    运行一个星期前升至更久前的脚本,,,出现如下错误提示 elementNotVisibleException was unhandled by user code. 经过询问大侠,说我的脚本不够健全,也 ...

  7. 树莓派Raspberry中成功安装RobotFramework+Selenium

    [原创链接]:http://www.cnblogs.com/atsats/p/6666848.html 一般RobotFramework都是安装在Windows/Linux的PC机上,这里将简单介绍在 ...

  8. robotframework+selenium搭配chrome浏览器,web测试案例(搭建篇)

    这两天发布版本 做的事情有点多,都没有时间努力学习了,先给自己个差评,今天折腾了一天, 把robotframework 和 selenium 还有appnium 都研究了一下 ,大概有个谱,先说说we ...

  9. robotframework - selenium 分层思路

    前言: 对于每一条用例来说,调用“百度搜索”关键字,输入搜索内容,输入预期结果即可.不同关心用例是如何执行的.如果百度输入框的定位发生了变化,只用去修改“百度搜索”关键字即可,不用对每一条用例做任何修 ...

随机推荐

  1. 在C++中使用openmp进行多线程编程

    在C++中使用openmp进行多线程编程 一.前言 多线程在实际的编程中的重要性不言而喻.对于C++而言,当我们需要使用多线程时,可以使用boost::thread库或者自从C++ 11开始支持的st ...

  2. TDSQL-A与CK的对比

    CK介绍 CK是目前社区里面比较热门的,应用场景也比较广泛. 首先,在架构上,集群内划分为多个分片,通过分片的线性扩展能力,支持海量数据的分布式存储计算,每个分片内包含一定数量的节点Node,即进程, ...

  3. Python3-sqlalchemy-orm 回滚

    #-*-coding:utf-8-*- #__author__ = "logan.xu" import sqlalchemy from sqlalchemy import crea ...

  4. Python中的私有属性私有方法、类属性类方法以及单例设计模式

    私有属性是对象不希望公开的属性,私有方法是对象不希望公开的方法.在定义私有属性和私有方法时,在属性或者方法前,加上__(两个下划线) 公有方法可以通过对象名直接调用,私有方法不能通过对象名直接调用,只 ...

  5. openresty(nginx) 配置 http与https使用同一个端口,禁止 IP 直接访问

    准备好工作目录 mkdir work cd work mkdir conf logs 准备好 conf/nginx.conf 配置文件, 把 your.domain 换成你自己的域名 user abc ...

  6. Hopper Disassembler系列之Sublime Text 3 爆破

    https://www.52pojie.cn/thread-793069-1-1.html 当参数少于7个时, 参数从左到右放入寄存器: rdi, rsi, rdx, rcx, r8, r9. 当参数 ...

  7. Python之requests模块-session

    http协议本身是无状态的,为了让请求之间保持状态,有了session和cookie机制.requests也提供了相应的方法去操纵它们. requests中的session对象能够让我们跨http请求 ...

  8. springboot通过AOP和自定义注解实现权限校验

    自定义注解 PermissionCheck: package com.mgdd.sys.annotation; import java.lang.annotation.*; /** * @author ...

  9. LCT 小记

    全程 Link-Cut Tree,是解决动态树问题的有力科技 --题记 简单实现 LCT 的形态直观上是一堆 Splay 的合体,每个 Splay 以时间戳为关键字,各个 Splay 通过虚边相连,可 ...

  10. 基于python2.7 Tkinter 做一个小工具

    1.源码:先写一个界面出来,放需要放入的点击事件的函数 # -*- coding:utf-8 -*- import Tkinter from Tkinter import * import Excle ...