Rubyonrails开发从头来(windows)(二十三)-功能测试的约定

上篇随笔里测试了login_controller,我们使用了很多rails内建的断言和get,put等方法来进行测试。这次来看看rails在功能测试方面的一些约定。

1.HTTP请求的方法(HTTP request method)

下面的方法用来模拟HTTP请求并得到一个回应(response)

get()put()post()delete()head()

这五个函数每一个都有同样的四个参数,以get()为例:

get(action, parameters = nil, session = nil, flash = nil)

向指定的Action发出一个HTTP GET请求,并且设定Response,四个参数的含义分别为:

action:HTTP请求所指定的某个控制器(controller)的一个Action。

Parameters:可选的Hash,作为request的参数。

Session:可选的,Session的Hash。

Flash:可选的,flash的Hash。

下面是例子:

get :indexget :add_to_cart, :id => @version_control_book.idget :add_to_cart, :id => @version_control_book.id,:session_key => 'session_value', :message => "Success!"

2.断言(assertion)

除了有Test:Unit提供的一些基本的断言(assertion),功能测试还可以在执行请求后使用一些自定义的断言。例如下面的:

l  assert_response(type, message=nil)

判断得到的HTTP响应是一个数字型的状态值或者下面列举的标记,这些标记覆盖了HTTP响应值,例如:redirect对应300-399。

:success:redirect:missing:error

例子:

assert_response :successassert_response 200

l  assert_redirected_to(options = {}, message=nil)

判断最后一个请求的Action是否被重定向到其他的controller,action或页面,例如:

assert_redirected_to :controller => ‘login’

assert_redirected_to :controller => ‘login’, :action => ‘index’

assert_redirected_to “http://my.host/index.html”

l  assert_template(expected=nil, message=nil)

判断一个请求是否使用了指定的template来描画(render)

例如:

assert_template ‘sTore/index’

l  assert_tag(conditions)

判断在一个响应的body内是否有符合指定条件的tag,条件的参数必须是下面的keys中的一个或多个。

:tag,节点的类型

assert_tag :tag => ‘html’

:content,判断节点的content的值

assert_tag :content => “Pragprog Books Online STore”

:attributes,一组条件,用来判断节点的属性

assert_tag :tag => “div”, :attributes => { :class => “fieldWithErrors” }

:parent,一组条件,判断节点的父节点

assert_tag :tag => “head”, :parent => { :tag => “html” }

:child,一组条件,判断当前节点的最近的一个直属的child

assert_tag :tag => “html”, :child => { :tag => “head” }

:ancesTor,一组条件,判断当前节点的最近的一个祖先

assert_tag :tag => “div”, :ancesTor => { :tag => “html” }

:descendant,一组条件,判断当前节点的最近的一个子孙

assert_tag :tag => “html”, :descendant => { :tag => “div” }

:children,一组条件,判断节点的children的数量,使用下面的key中的任意一个或一组

:count,一个数字或一个范围,指定要match的children的编号。

:less_than,children的编号必须小于指定的数字。

:greater_than,children的编号必须大于指定的数字。

:only,当计算children的数量是使用的一组条件。

例子:

assert_tag :tag => “ul”,:children => { :count => 1..3,:only => { :tag => “li” } }

更多的断言参考:http://api.rubyonrails.com/classes/Test/Unit/Assertions.html.

3.变量

当一个请求(request)被执行,可以依靠下面的变量来进行断言。

l  assigns(key=nil)

由最后一个action赋值的实例变量。

assert_not_nil assigns[“items”]

assigns必须被指定一个字符串作为索引,但是上面的assert_not_nil assigns[“items”]却不会起作用,因为items是一个关键字,可以使用一方法调用来代替:

assert_not_nil assigns(:items)

l  session

session的一个hash对象:

assert_equal 2, session[:cart].items

l  flash

在session里存放的flash的hash对象

assert_equal “Danger!”, flash[:notice]

l  cookies

用户使用的cookies的hash对象。

assert_equal “Fred”, cookies[:name]

l  redirect_to_url

上一个action重定向的完整的url

assert_equal “http://test.host/login”, redirect_to_url

OK,这次就到这里,下次继续会到controller的测试。

从此便踏上征途,也许会孤独一程。

Rubyonrails开发从头来(windows)(二十三)-功能测试的约定

相关文章:

你感兴趣的文章:

标签云: