所以我已经为此苦苦挣扎了很长一段时间,我似乎无法弄清楚我们出了什么问题,也找不到太多可能导致这个问题的原因。
我对 Ruby 和 Rails 以及测试/行为驱动的开发相对较新,并且正在尝试使用 Rspec 和 Capybara 通过 Poltergeist 使用 PhantomJS 编写一些验收(浏览器)测试。我相信有些人也称此为集成测试(他们可能是从某种角度来看),但这是另一回事。
我有一个非常简单的功能,我无法做我想做的事:
require 'feature_helper'
feature 'Logging in', :js => true do
scenario 'with incorrect credentials' do
visit '/login'
puts page.html
save_and_open_page
page.driver.render('_screenshot.png', :full => true)
page.html.should have_selector("title", :text => "hi")
end
end
所以。很简单,对。它应该只是/login
将 HTML 内容扔给我,我也想使用 来查看页面save_and_open_page
,并且我希望它截取屏幕截图。为了让测试失败,我添加了一个简单should have_selector
的方法,试图获得更多反馈。
my 的相关内容feature_helper.rb
:
require 'spec_helper'
require 'capybara/rspec'
require 'capybara/rails'
require 'capybara/poltergeist'
include Capybara::DSL
Capybara.register_driver :poltergeist do |app|
Capybara::Poltergeist::Driver.new(app, {
:debug => true,
:inspector => true
})
end
Capybara.default_driver = :poltergeist
Capybara.javascript_driver = :poltergeist
FakeWeb.allow_net_connect = %r[^https?://(127.0.0.1|localhost)] # allow phantomjs/poltergeist requests
DatabaseCleaner.strategy = :truncation
RSpec.configure do |config|
config.before :each do
# Set the hostname to something with test
@host = "test.iome:3003"
host! @host
Capybara.default_host = Capybara.app_host = "http://#{@host}/"
Capybara.server_port = 3003
Capybara.reset_sessions!
# Start the database cleaner
config.use_transactional_fixtures = false
DatabaseCleaner.start
end
config.after :each do
DatabaseCleaner.clean
end
end
还有我的spec_helper.rb
:
# This file is copied to spec/ when you run 'rails generate rspec:install'
ENV["RAILS_ENV"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'
require 'pry'
require 'fakeweb'
FakeWeb.allow_net_connect = false
这一切都相当简单。
现在,在我的控制台中,我看到以下内容:
{"name"=>"visit", "args"=>["http://test.iome:3003//login"]}
{"response"=>{"status"=>"fail"}}
{"name"=>"body", "args"=>[]}
{"response"=>"<html><head></head><body></body></html>"}
<html><head></head><body></body></html>
{"name"=>"body", "args"=>[]}
{"response"=>"<html><head></head><body></body></html>"}
{"name"=>"render", "args"=>["_screenshot.png", true]}
{"response"=>true}
{"name"=>"body", "args"=>[]}
{"response"=>"<html><head></head><body></body></html>"}
此外,屏幕截图只是一个白色的空白页面。当我跟踪我的log/test.log
文件时,我没有看到正在执行请求。我尝试将方法更改visit
为get
,这将发出请求,但不会更改任何结果。
我已经完全没有想到这可能是什么,这相当令人沮丧:(
然后是关于版本的最终信息:
- rspec 2.10.0
- 水豚 1.1.4
- 闹鬼 1.0.3
- 红宝石 1.8.7
- 导轨 3.2.13
不幸的是,我们仍处于 ruby 1.8.7,但正在努力提高该版本。不过,我认为这不应该影响测试。
任何帮助将不胜感激!