在我的 Rails 3 应用程序中,我对 iPhone 和桌面浏览器有不同的布局。我正在尝试使用 Cucumber/Capybara 测试 iPhone 布局。到目前为止,我在请求的 HTTP 标头中设置 iPhone 用户代理字符串的所有尝试都失败了。
我已经按照使用 Cucumber 和 Capybara教程测试自定义标头和 ssl,但它似乎没有在 HTTP 请求中设置 User-Agent 字符串。
如果我只是使用我的 iPhone 浏览到我的 Rails 应用程序,我会得到正确的布局。我正在使用Rack-Mobile-Detect将 Rails request.format 设置为 :iphone。
关于如何使这项工作的任何想法?我正准备放弃 Capybara 并回到 Webrat。
这是我到目前为止所拥有的:
Feature: Detect Browser
In order to have different layouts for iPhone vs. desktop browsers
As a developer
I want to show different layouts for different browsers
Scenario: Show home page with desktop layout
Given I am using "a desktop browser"
When I go to "the home page"
Then I should see "desktop browser"
Scenario: Show home page with iPhone layout
Given I am using "mobile safari"
When I go to "the home page"
Then show me the page
Then I should see "mobile safari"
Detect_browser_steps.rb
Given /^(?:|I )am using (.+)$/ do |browser|
case browser
when "mobile safari"
agent = "Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_1_2 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7D11 Safari/528.16"
add_headers({'User-Agent' => agent})
else
# don't set a special User-Agent header
end
end
headers_hack.rb
# http://aflatter.de/2010/06/testing-headers-and-ssl-with-cucumber-and-capybara/
# The following solution will work only if you use the :rack_test driver.
module RackTestMixin
def self.included(mod)
mod.class_eval do
# This is where we save additional entries.
def hacked_env
@hacked_env ||= {}
end
# Alias the original method for further use.
alias_method :original_env, :env
# Override the method to merge additional headers.
# Plus this implicitly makes it public.
def env
original_env.merge(hacked_env)
end
end
end
end
Capybara::Driver::RackTest.send :include, RackTestMixin
module HeadersHackHelper
def add_headers(headers)
page.driver.hacked_env.merge!(headers)
end
end
World(HeadersHackHelper)