基于Ruby的watir-webdriver自动化测试方案与实施(四)

接着基于Ruby的watir-webdriver自动化测试方案与实施(三)
继续 ... ...
 
首先回忆下我们的系统架构,然后谈谈具体的实现。
 

该自动化测试框架分三个模块:Test用例、Control控制层、Tools工具类、model总控

Test用例

  1. 基于ruby的watir-webdriver开发
  2. 统一预置参数输入规则,提供规则模板,做到一个用例一个类,一个方法一个输出。(一个类可以多个方法)
  3. 统一输出规则,比如:①[info]②TiStone ③Login successful!④001011

    ①   [Info]:代表该用例执行成功![error]代表失败![warn]代表警告!

    ②   TiStone:代表执行用例名称

    ③   Login successful!:描述或捕获的value值,以“!”结尾

    ④   001011:返回码

  4.统一用例名称,应与输出②保持一致

Control控制层

  1. 一个用例对应一个Control
  2. 效验输出,判断用例执行成败,根据规则关联Linux服务器捕获相关日志、配置文件等分析失败原因,缩减定位区域范围。
  3. 对比数据,关联MySql查询数据,对比web捕获value值。

Tools工具类

  1. 封装工具类
  2. 关联Linux与MySql
  3. 提供测试用例支持,降低用例开发难度

Index总控

  1. 控制用例执行与展示

方案设计

Test用例

涉及依赖:

require ‘watir-webdriver‘
require ‘watir-webdriver-performance‘

页面加载性能监控

1.times do 

b.goto("https://192.168.10.1/web")

load_secs = b.performance.summary[:response_time]/1000

puts "Load Time: #{load_secs} seconds."

End

 

功能成败判别

if b.text.include? ‘T_100M‘
            #捕获web属性value值
            #后续操作
            puts "①[info]②TiStone ③Login successful!000000"
 else
            #后续操作
            #输出错误码
            puts "①[error]②TiStone ③Login failed!001011"
 end

 

参数化提取

class BasicNumber
    def initialize(number,name)
        @number = number
        @name = name
    end
    def add(x)
        @number + x
    end
end

Control控制层

涉及依赖:

load ‘Linux.rb‘
load ‘MySql.rb‘

 

具体实现与Tools通信,做一个信息传输的枢纽。

Tools工具类

涉及依赖:

require ‘net/ssh‘
require ‘scp/ssh‘
require "test/unit"

 

关联Linux

#ip/用户名/密码

host = "192.168.48.233"

username = "root"

password = "root"

#调用linux命令

server_cmd1 = ‘tail -1000 /home/log/web.log  | grep ERROR‘

server_shell= ‘sh /home/wyong/w.sh‘

 

关联MySql

具体实现略…

 

单元测试

class TC_MyTest  < Test::Unit::TestCase

         def test_add

                   n=BasicNumber.new(10)

                   assert_equal(134,n.add(4),"This test about add is failure!")  

    end

end

model总控

涉及依赖:

load Control_用例名称.rb‘

 

统一调用

t = Control_用例名称.new

test_methods = t.public_methods.grep(/^test_/)

test_methods.each do |test|

  t.send(test) 

end

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。