こんにちは、tsu-nera です.
Headless Chrome を使った RSpec の UI テストについて紹介します。 なぜ Headless かというと、Docker 内でブラウザテストをやりたいから。 同じ方法は、CircleCI などの継続的インテグレーションでも使えます。
Capybara 準備
UI テストには、capybara を使います。Gemfile に以下を追記。
group :test do
gem 'capybara'
end
spec/rails_helper.rb に、以下を追記。
require 'capybara/rspec'
Headless Chrome の 準備
まずは Docker に、google-chrome と、webdriver を入れる。Dockerfile に以下を書く。
FROM ruby:2.4.1
RUN apt-get update -qq && apt-get install -y build-essential nodejs unzip
RUN CHROME_DRIVER_VERSION=`curl -sS chromedriver.storage.googleapis.com/LATEST_RELEASE` && \
wget -N https://chromedriver.storage.googleapis.com/$CHROME_DRIVER_VERSION/chromedriver_linux64.zip -P ~/ && \
unzip ~/chromedriver_linux64.zip -d ~/ && \
rm ~/chromedriver_linux64.zip && \
chown root:root ~/chromedriver && \
chmod 755 ~/chromedriver && \
mv ~/chromedriver /usr/bin/chromedriver && \
sh -c 'wget -q -O - https://dl-ssl.google.com/linux/linux_signing_key.pub | apt-key add -' && \
sh -c 'echo "deb [arch=amd64] https://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google-chrome.list' && \
apt-get update && apt-get install -y google-chrome-stable
RUN mkdir /app
WORKDIR /app
COPY Gemfile /app/Gemfile
COPY Gemfile.lock /app/Gemfile.lock
RUN bundle install
COPY . /app
以下を Gemfile に書く。
group :test do
gem 'capybara', '~> 2.15.4'
gem 'selenium-webdriver'
gem 'chromedriver-helper'
gem 'launchy', '~> 2.4.3'
end
spec/support/capybara.rb
に 以下を追記。
Capybara.register_driver :chrome_headless do |app|
options = ::Selenium::WebDriver::Chrome::Options.new
options.add_argument('--headless')
options.add_argument('--no-sandbox')
options.add_argument('--disable-dev-shm-usage')
options.add_argument('--window-size=1400,1400')
Capybara::Selenium::Driver.new(app, browser: :chrome, options: options)
end
Capybara.javascript_driver = :chrome_headless
以前は、PhantomJS を使っていた人も、Headless Chrome を試してみよう!