• Watir 能够为你做什么?


    为了提高自己的工作效率,我曾经对Watir进行了系统性的学习,比起学习C++ Java等始终不得门,Watir还是学进去了,能够完整搭建出一个自己很容易理解的自动化架构。

    之后我想继续在自动化测试方明提高自己,就把Ruby语言从头到尾走了一遍,还是有些收获的,虽然现在脑海里面也记不起来多少东西,但是就自动化测试这一方面来说,还是很有自信的。

    WatirRuby能够很大程度上提高测试效率,这点是毋庸置疑的,印象深刻的是,以下场景下,WatirRuby帮了我的忙。

     

    场景1:重现一些难以重现的Bug

    公司产品有一个功能,用户可以在google地图上画一条路线,然后可以在这条路线上跑步健身,从而进行一些统计工作,用户还可以保存这条路线,分享给别人。

    这个功能后来出现了一个大bug:当这种路线分享的多了,点击访问的就多了,达到一定程度之后,服务器将会崩溃。现在,如何重现它?

    如果是手动点击,可能要先访问10000条不同的路线,然后Bug可能会出现,这对于测试人员来说,这项任务非常艰巨。

    但是通过Watir脚本就很简单了:

    1) 通过Watir操作IE/Firefox/Chrome,复制创建10000Route

    2) 遍历当前页面所有的Route链接,直到Route内容完全加载之后,点击分页功能的下标, 再遍历下一个页面所有的Route链接,持续下去,每次成功访问,返回一个1,失败返回0

    3) 直到连续多次返回0,就停止脚步的执行,Bug页面将会重现。

    这个场景完整脚本的书写不会超过1个小时,执行倒是要花费多个小时。

     

    场景2

    为用户插入私有数据。

    公司产品发现了一个Bug,数据库某个字段默认为0,有些用户通过页面操作设置为1了,现在需要把所有为0的字段都改为1,但是只能通过页面来修改,不能通过数据库来修改。而想到达该页面,需要登录,但是客户的私有信息,测试开发人员是无法获取的。

    1) 开发人员沟通,最后寻找了一个解决方案,就是通过浏览器,访问加密的URL,从而把用户数据传输到数据库。

    2) 把几千条URL依次输入浏览器,点击回车,等待正确响应,然后再下一条。

    然后对于手工操作来说,也许真的很简单,但是也会耗费一个小时以上,而且很容易出现失误的情况。

    通过Watir脚本,只需要一个读取文件函数(链接存在文件里面),一个goto函数,一个watir_until函数,一个返回值,事情就解决了,可以一劳永逸。

     

    这些场景在测试工作中是非常多的,这里就不再罗列了。

    我就罗列一个最近工作中常做的事:造数据!

    现在我要给数据库中插入1W条网络图片路径,数据库的字段之间还有依赖关系,当系统启动的时候,这些网络路径的图片需要正常访问。

    如果通过手工,给数据库中插入那么多数据,基本上是不可能完成的任务。

    但是通过脚本就教简单了。

    1) 遍历某个大型图片展示网站,通过ie.links.collect可以把链接存储下来;

    2) 当进入某个链接页面之后,就需要把所有的图片资源的网络访问路径爬下来,这个可以通过ie.images.collect来简单实现,把这些图片资源网络路径存储起来;

    3) 进入SQL,找到我们需要插入数据的表,通过SQL脚本自动生成功能,就可以获取一片SQL Insert脚本;

    4) 对这些脚本进行定制,生成1W条相应的脚本,每条脚本指向的图片URL都不一样;

    5) 新建SQL查询,把文档中保存的脚本放入其中,执行即可。

  • 相关阅读:
    mysql慢查询日志功能的使用
    回顾JavsScript对象的克隆
    JavaScript的几种继承方式
    再谈JavaScript中的闭包
    重温JavaScript预编译的四个步骤
    PHP常用设计模式
    编译 php-memcache 扩展时提示Cannot find autoconf
    CentOS 7 下编译安装lnmp之PHP篇详解
    CentOS 7 下编译安装lnmp之MySQL篇详解
    MySQL的转义符 ` 作用
  • 原文地址:https://www.cnblogs.com/autotest/p/3262462.html
Copyright © 2020-2023  润新知