导轨 3
我在表单中有一个列表:
<%= form_for @article do |f| %>
  <ul>
    <% @product.each do |p| %>
      <li id="product_<%=p.id%>">
        <div>
         <%= f.radio_button(:p_id, p.id, class: 'hidden') %>
        </div>
      </li>
    <% end %>
  </ul>
  <%= f.submit 'submit', :id=>"submit_category", :class=>'hide' %>
<% end %>
我添加了一个 javascript 函数,以便当用户单击 li 元素时,选择单选按钮并提交表单。
<script type="text/javascript">
  $('li').click(function() {
    $(this).find('input[type=radio]').attr('checked', true);
    $('#submit_category').click();
  });
</script>
这在生产,开发中完美运行,但测试环境失败:表单已提交,但未选中单选按钮,因此出现验证错误。
我的测试是用 Cucumber + Selenium + Capybara 完成的。测试线:
When /^I click on the "(.*?)" product$/ do |product_name|
  @product = Product.find_by_name(product_name)
  page.find('li', id: "product_#{@p.id}").click
end