rails3-jquery-autocomplete:如何使用RSpec和Capybara进行测试?

前端之家收集整理的这篇文章主要介绍了rails3-jquery-autocomplete:如何使用RSpec和Capybara进行测试?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用Rails 3.2.8

> gem’jquery-rails’,’2.1.2′
> gem’trail3-jquery-autocomplete’,’1.0.9′
> gem’rspec-rails’,’2.11.4′
> gem’capybara’,’1.1.3′
> gem’capybara-webkit’,’0.12.1′

我最近将选择下拉列表转换为自动完成(使用rails3-jquery-autocomplete),并且我正在尝试更新我的请求规范以填写自动完成功能.

我的方法是创建一个帮助器,如this gist所示:

def fill_autocomplete(field,options = {})
  fill_in field,:with => options[:with]

  selector = "ul.ui-autocomplete a:contains('#{options[:select]}')"

  page.should have_selector selector
  page.execute_script "$(\"#{selector}\").mouseenter().click()"
end

如果我使用Webkit测试,测试将失败并显示以下消息:

expected css "ul.ui-autocomplete a:contains('Firstname Lastname')" to return something.

如果我使用Selenium测试,当我在Firefox中观察测试时,我看不到下拉选择列表出现.添加睡眠3以等待下拉也无济于事.

我看到here与capybara-webkit有一个相关但有些旧的问题,关于何时填写字段,它立即模糊,这当然会阻止自动完成选择列表出现.但这似乎与那些已经开始工作的人并不相符.

目前是否可以使用RSpec和Capybara测试包含rails3-jquery-autocomplete字段的表单?怎么样?如果没有,有没有办法手动填写相应的,隐藏的id字段,所以我仍然可以测试表单创建正确的数据?

解决方法

最后,自动完成测试至少使用Selenium驱动程序.

解决方案是将重点放在该领域并发出keydown事件.

我首先在浏览器中通过手动测试确认了这一点.如果我使用鼠标(而不是Ctrl-V)将搜索词粘贴到自动填充字段中,则不会发生任何事情 – 不会显示下拉选择列表.这显然等同于Capybara发送fill_in命令时发生的情况.但是,在该字段处于该字段之后,当焦点仍然在该字段上时,如果我触摸任何键,例如Shift键,出现选择列表.显然,选择列表仅在按下键时出现.

选项1

一种解决方案是将功能从原始问题扩展如下:

def fill_autocomplete(field,:with => options[:with]

  page.execute_script %Q{ $('##{field}').trigger("focus") }
  page.execute_script %Q{ $('##{field}').trigger("keydown") }
  selector = "ul.ui-autocomplete a:contains('#{options[:select]}')"

  page.should have_selector selector
  page.execute_script "$(\"#{selector}\").mouseenter().click()"
end

然后像这样调用它:

fill_autocomplete "to_contact_name",with: "Jone",select: "Bob Jones"

选项2

一个类似的方法,改编自主rails3-jquery-autocomplete gem中的Steak test,使用标准fill_in,然后是choose_autocomplete_result:

def choose_autocomplete_result(item_text,input_selector="input[data-autocomplete]")
  page.execute_script %Q{ $('#{input_selector}').trigger("focus") }
  page.execute_script %Q{ $('#{input_selector}').trigger("keydown") }
  # Set up a selector,wait for it to appear on the page,then use it.
  item_selector = "ul.ui-autocomplete li.ui-menu-item a:contains('#{item_text}')"
  page.should have_selector item_selector
  page.execute_script %Q{ $("#{item_selector}").trigger("mouseenter").trigger("click"); }
end

这被称为:

fill_in "to_contact_name",:with => "Jone"
choose_autocomplete_result "Bob Jones","#to_contact_name"

我采用了第二种方法进行测试.它似乎与Selenium相当可靠但不适用于webkit,这太糟糕了,因为相比之下Selenium测试相当慢.在webkit下运行的解决方案将受到欢迎!

原文链接:https://www.f2er.com/jquery/177427.html

猜你在找的jQuery相关文章