脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Ruby - Windows下Ruby+Watir自动化测试的环境搭建及数据读取

Windows下Ruby+Watir自动化测试的环境搭建及数据读取

2020-05-07 11:06像风一样的自由 Ruby

这篇文章主要介绍了Windows下Ruby+Watir自动化测试的环境搭建及数据读取,Watir是一个使用Ruby实现的开源Web自动化测试框架,需要的朋友可以参考下

Watir的使用环境搭建

1、watir环境工具安装包:

1) ruby186-26.exe下载地址:http://files.rubyforge.vm.bytemark.co.uk/rubyinstaller/
2) watir-1.5.2.gem下载地址:http://rubyforge.org/frs/?group_id=104&release_id=28016
3)rubygems-update-1.3.7.gem下载地址:http://rubyforge.org/frs/?group_id=126

2、firewatir环境工具安装包:

1)步骤1中的软件包
2)Firefox2.0下载地址:http://www.hacker.cn/Get/gjrj/06102608545293311.shtml
3)firefox插件:firbug1.05,JSSh。Jssh下载地址:地址
4)Firewatir-1.1下载地址:http://rubyforge.org/frs/?group_id=104&release_id=28017

3、watir安装
1)安装ruby186-26.exe;
2)升级gem,把gem包拷贝到ruby安装目录,在命令行输入命令:gem install rubygems-update 1.3.7.gem(gem包名)。提醒:安装完后进入ruby目录:lib\ruby\gems\1.8\gems\rubygems-update-1.3.4,点击这个文件夹中的文件:setup.rb,升级gem即可
3) 安装watir包,把watir包拷贝到ruby安装目录,使用命令行进入ruby安装的目录,输入命令:gem install watir-1.5.2.gem。
4)使用命令gem list查看是否安装成功。

4、安装firewatir

1)安装firefox和firebug,Jssh插件,安装方法:打开firefox浏览器,点击“文件”/“打开”,选择插件文件名,安装即可。

2)安装firewatir,使用命令行进入ruby安装的目录,输入命令:gem install firewatir-1.1.gem

5、测试firewatir是否安装成功?

使用命令行进入firewatir安装路径下(\ruby\lib\ruby\gems\1.8\gems\firewatir-1.1),进入unittests文件夹,输入命令:ruby mozilla_all_tests.rb,如果可以正确执行程序,说明安装正确没有问题,到此可以开始自动化测试开发的旅程了。

6、在安装watir过程出现'nmake' 不是内部或外部命令,也不是可运行的程序或批处理文件。

使用命令

?
1
gem install --local watir-1.5.2.gem

就安装成功了!


读取各种数据源中的测试参数化数据
自动化测试时常用到的技术就是参数化,不支持参数化的测试框架是痛苦的。QTP自身本来就有,但是类似ruby的watir,以及selenium等都不是天然支持的,因为这些个框架只提供了最基础的自动化驱动类库,而驱动以外的执行管理、数据管理等又是一个课题。大部分的selenium和watir类似项目用的执行框架都是单元测试的框架,天然也不支持参数化。现在只有junit4版本支持参数化,以及testNG默认支持多种参数化。如果你开始项目的话可以优先考虑兼容这些类似框架的语言来做自动化。
watir虽然本身不支持参数化,ruby的单元测试也不支持,但是参数化也要做啊,没办法只能想想变通的法子。所以单独写了一个参数化的类,来补充一下参数化功能的不足。其工作方式是提供统一的测试数据源的数据读取,在单元测试中调用这个接口,但是不指定具体的参数行,这个参数行在单独的配置文件里配置。这个就可以统一的管理每次测试执行时所取用的参数行内容了。下面的代码是用来取用各种数据源里面的测试数据的。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#encoding: utf-8
require 'DBI'
require 'odbc_utf8'
 
def generate_sql(table, what=nil, where=nil)
 what="*" unless what
 where="1=1" unless where
 "select %s from %s where %s" % [what, table, where]
end
 
def generate_hash(header, all_data)
 t_arr = []
 all_data.each do | row |
 t_hash = {}
 for i in 0..header.size-1 do
  t_hash[header[i]] = row[i]
 end
 t_arr << t_hash
 end
 t_arr
end
 
def select_hash_db(dsn,user,password,db,sql)
 begin
 dbh = DBI.connect(dsn, user, password)
 dbh.do("use #{db}")
 dbh.do("SET NAMES UTF8") if dsn.split(':')[1] == "Mysql"
 sth = dbh.execute(sql)
 arr = Array.new
 sth.fetch_hash do | row |
  arr << row
 end
 sth.finish
 arr
 rescue DBI::DatabaseError => e
 puts "An error occurred"
 puts "Error code: #{e.err}"
 puts "Error message: #{e.errstr}"
 ensure
 dbh.disconnect if dbh
 end
end
 
class Text_Adapter
 
 def initialize(file_path, sep=" ", col_num=nil, row_num=nil)
 
 end
 
 def get_pars(row=nil)
 
 end
 
end
 
class Mysql_Adapter
 def initialize(ds_connector, table_name, what=nil, where=nil)
 @sql_str = generate_sql(table_name, what, where)
 @ds_connector = ds_connector
 end
 
 def get_pars(row=nil)
 dsc_arr = @ds_connector.split("#")
 all_data = select_hash_db(dsc_arr[0],dsc_arr[1],dsc_arr[2],dsc_arr[3],@sql_str)
 if row.class==Fixnum
  all_data[row]
 else
  all_data
 end
 end
end
 
class Excel_Adapter
 
 def initialize(ds_connector, table_name, what=nil, where=nil)
 @connection = WIN32OLE.new('ADODB.Connection')
 @record_set = WIN32OLE.new('ADODB.Recordset')
 @ds_connector = ds_connector
 @sql_str = generate_sql(table_name, what, where)
 end
 
 def get_pars(row=nil)
 t_arr = []
 @connection.Open(@ds_connector)
 @record_set.Open(@sql_str, @connection)
 @record_set.Fields.count.times do | i |
  t_arr << @record_set.Fields.Item(i).name
 end
 all_data = @record_set.GetRows.transpose
 all_data = generate_hash(t_arr, all_data)
 if row.class==Fixnum
  all_data[row]
 else
  all_data
 end
 end
end
 
 
class Parameter
 def initialize(ds_connector, table_name, what=nil, where=nil)
 dsc_arr = ds_connector.split("#", 2)
 eval("@adp = #{dsc_arr[0]}.new dsc_arr[1], table_name, what, where")
 end
 
 def get_pars(row=nil)
 @adp.get_pars(row)
 end
end

调用方法:

?
1
2
par = Parameter.new(Ds_mysql_connector, 'demo')
p par.get_pars(0)

配置文件配置:

?
1
2
3
4
5
6
7
##链接excel中数据库的串
EXCEL_DSN = %{Excel_Adapter#Provider=MicroSoft.Jet.OLEDB.4.0;Data Source=%s;Extended Properties=Excel 5.0;}
EXCEL_FILE = %{D:\\1.xlsx}
##链接mysql的串
Ds_mysql_connector = %{Mysql_Adapter#DBI:Mysql:shoppingcart:127.0.0.1#root#password#shoppingcart}
##指定当次运行侧事故参数的行号,从0开始
PAR_ROW = 1

相应的文件指向路径、ip地址、数据库名、用户名、密码等需要修改

延伸 · 阅读

精彩推荐
  • RubyRuby设计模式编程中使用Builder建造者模式的实例

    Ruby设计模式编程中使用Builder建造者模式的实例

    这篇文章主要介绍了Ruby设计模式编程中使用Builder建造者模式的实例,建造者模式将一个复杂对象的构造与它的表示分离,使同样的构建过程可以创建不同的表...

    范孝鹏2192020-05-07
  • RubyCentOS中配置Ruby on Rails环境

    CentOS中配置Ruby on Rails环境

    经过一个上午的折腾,终于把ROR环境在CentOS中搞定,绕了很多弯路,把文章写下来总结一下 ...

    可乐加糖4762020-04-12
  • Ruby简要说明Ruby中的迭代器

    简要说明Ruby中的迭代器

    这篇文章主要介绍了Ruby中的迭代器,迭代器的概念在动态语言的编程中十分重要,文章中介绍了Ruby中的each迭代器和collect迭代器,需要的朋友可以参考下 ...

    goldensun2772020-04-25
  • RubyRuby迭代器的7种技巧分享

    Ruby迭代器的7种技巧分享

    这篇文章主要介绍了Ruby迭代器的7种技巧分享,Ruby中的迭代器非常人性化,本文既是讲解了7个技巧也是讲解了7种迭代器,需要的朋友可以参考下 ...

    脚本之家4782020-04-20
  • RubyRuby简洁学习笔记(一):字符串、数字、类和对象

    Ruby简洁学习笔记(一):字符串、数字、类和对象

    这篇文章主要介绍了Ruby简洁学习笔记(一):字符串、数字、类和对象,本文是学习笔记第一篇,需要的朋友可以参考下 ...

    脚本之家2472020-04-20
  • RubyRuby进行文件信息输出实例代码

    Ruby进行文件信息输出实例代码

    Ruby进行文件信息输出实例代码,数据是随机的,所以每次的记录都会不同。 ...

    ruby教程网2962020-04-10
  • RubyRuby环境下安装使用bundler来管理多版本的gem

    Ruby环境下安装使用bundler来管理多版本的gem

    这篇文章主要介绍了Ruby环境下安装使用bundler来管理多版本的gem的方法,举了Ruby On Rails中的应用实例来进行演示,需要的朋友可以参考下 ...

    日拱一卒4332020-05-10
  • Ruby剖析 Ruby 访问控制

    剖析 Ruby 访问控制

    前面,我们说 Ruby 没有函数,只有方法.而且实际上有不止一种方法.这一节我们介绍 访问控制 (accesscontrols). 想想当我们在最高层而不是在一个类的定义里定义...

    ruby教程网3572020-04-08