使用capybara-webkit测试jquery对话框

时间:2011-09-30 21:06:42

标签: webkit rspec integration-testing capybara jquery-dialog

我想测试一个用户单击链接的交互,然后弹出一个jquery对话框(http://jqueryui.com/demos/dialog/)。

我想测试一下:

  1. 对话框显示
  2. 对话框中的文字正确
  3. 用户可以点击“x”
  4. 退出

    我手动测试了对话框并且它有效,但我对如何编写实际规范感兴趣。我想使用Capybara-webkit来做这件事,但是我无法找到实际使用Capybara-webkit的代码示例。

    我使用的是Capybara-webkit和规格,但不是黄瓜。

1 个答案:

答案 0 :(得分:1)

以下是如何执行此操作:

资源

安装

确保您的Gemfile包含capybara-webkit,rspec-rails和database_cleaner:

group :development, :test do
  gem 'rspec-rails', '~> 2.7.0'
  gem 'capybara-webkit', '~> 0.7.2'
  gem 'database_cleaner', '~> 0.6.7'
end

您需要database_cleaner,因为除了Rack :: Test之外,数据库事务与rspec驱动程序不兼容:

RSpec.configure do |config|

#...

  config.use_transactional_fixtures = false

  config.before(:suite) do
    DatabaseCleaner.strategy = :truncation
  end

  config.before(:each) do
    DatabaseCleaner.start
  end

  config.after(:each) do
    DatabaseCleaner.clean
  end

end

您仍然必须使用:js =>你的测试中的真旗。事实证明,它不仅仅是一种硒功能:

describe "Something" do
  it "uses javascript", :js => true do
     pending "write a test"
  end
end

当然,require 'capybara/rspec'并在您的spec_helper中设置Capybara.javascript_driver = :webkit

#...

ENV["RAILS_ENV"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'
require 'capybara/rspec'
Capybara.javascript_driver = :webkit

#...

这应该是让capybara-webkit和rspec启动并运行所需的全部内容。