私の Rails 3 アプリでは、iPhone とデスクトップ ブラウザーで異なるレイアウトを使用しています。Cucumber/Capybara を使用して iPhone のレイアウトをテストしようとしています。これまでのところ、リクエストの HTTP ヘッダーに iPhone User-Agent 文字列を設定する試みはすべて失敗しています。
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)