我一直在使用 Cucumber 和 Webrat 一段时间。我现在需要开始编写涉及 AJAX 交互的行为,所以我想为 Webrat 使用 Selenium 适配器。谁能指出一个简单且更新的分步指南,用于安装和配置 selenium+webrat+cucumber?我希望能够将 javascript 场景与非 javascript 场景混合使用。
问问题
5803 次
1 回答
8
我在我的项目中使用 Selenium 和 rspec,并从 Selenium IDE 的自定义格式化程序生成代码。
Rails 有很多 selenium,但我使用 Selenium-RC http://seleniumhq.org/download/成功,所以下载到你的电脑上。
这是我的步骤:
- 解压并运行> java -jar selenium-server.jar
- 打开 selenium-client-ruby,阅读文档,按照它进行操作,您将获得成功!
- gem install rspec, rspec-rails version 1.2.6(不是,你需要注释 selenium-client 源代码的版本限制)
- 宝石安装硒客户端
- 打开 Selenium-IDE(当然是 Firefox),打开选项 -> 选项 -> 格式
- 单击添加,并将此代码粘贴到http://www.techdarkside.com/rspec_export.txt
现在,您只需为我将规范导出到您的规范文件夹,我使用 spec/features/xxxx_spec.rb 参见下面的代码。
非常相似的方法可以在这里找到
对于 webrat+cucumber,最新的Rspec 书籍将满足您的所有需求。(他们还没有硒+黄瓜章节完成)
例子
require 'rubygems'
gem "rspec", "=1.2.6"
gem "selenium-client", ">=1.2.15"
require "selenium/client"
require "selenium/rspec/spec_helper"
describe "Google Search" do
attr_reader :selenium_driver
alias :page :selenium_driver
before(:all) do
@selenium_driver = Selenium::Client::Driver.new \
:host => "localhost",
:port => 4444,
:browser => "*firefox",
:url => "http://www.google.com",
:timeout_in_second => 60
end
before(:each) do
selenium_driver.start_new_browser_session
end
# The system capture need to happen BEFORE closing the Selenium session
append_after(:each) do
@selenium_driver.close_current_browser_session
end
it "can find Selenium" do
page.open "/"
page.title.should eql("Google")
page.type "q", "Selenium seleniumhq"
page.click "btnG", :wait_for => :page
page.value("q").should eql("Selenium seleniumhq")
page.text?("seleniumhq.org").should be_true
page.title.should eql("Selenium seleniumhq - Google Search")
page.text?("seleniumhq.org").should be_true
page.element?("link=Cached").should be_true
end
end
于 2009-09-04T17:42:14.373 回答