使用simple_form Rails时测试HTML 5表单验证

时间:2013-06-29 20:32:51

标签: ruby-on-rails-3 capybara simple-form

我在我的待办事项列表应用中使用了devise和simple_form。现在,我的用户/ edit.html.erb

有以下代码
<%= content_for :title,'Edit profile' %>
<h2>Edit profile</h2>
<%= simple_form_for current_user, class: 'form-horizontal' do |f| %>
  <%= f.input :nick_name %>
  <%= f.submit 'Update profile' %>
<% end %>

我的user.rb看起来像这样:

class User < ActiveRecord::Base  
 devise :database_authenticatable, :registerable,
     :recoverable, :rememberable, :trackable, :validatable
 attr_accessible :email,:nick_name, :password, :password_confirmation, :remember_me
 validates :nick_name, presence: true    # the other fields already validated by devise
 has_many :lists , dependent: :destroy
end

现在,当我点击带有空nick_name字段的提交按钮时,我会收到一个弹出式警报。它不像普通的浏览器警报,我认为它是一个HTML5功能。我将此消息Please fill out this field作为空字段下方的弹出窗口。我已禁用javascript,但它仍显示相同的消息。 这是我的nick_name输入字段:

<input class="string required" id="user_nick_name" name="user[nick_name]" required="required" size="50" type="text">

现在,当我在模型中删除nick_name的状态验证时,此弹出窗口不会显示。当验证行被注释掉时,

<input class="string optional" id="user_nick_name" name="user[nick_name]" size="50" type="text">

simple_form是否在幕后做了一些魔术?

由于此弹出窗口没有显示任何html代码的痕迹,如何在capybara / rspec中测试此验证?

2 个答案:

答案 0 :(得分:3)

实际上,您可以通过使用以下代码示例查找html属性required="required"来测试它:

expect(page).to have_xpath("//input[@required='required']")

答案 1 :(得分:1)

由于您使用的是headers: { "Accept": "application/json; odata=verbose", "X-RequestDigest": $("#__REQUESTDIGEST").val() }, 属性,因此会触发HTML5验证。

测试一下: required="required"