Railsにこれから初めて触れる肩を対象にしたチュートリアルです
Rails/Rubyのコミッターであるa_matsudaさんが制作されているheavens_doorをRailsに導入するチュートリアルです
まずは、rails new
でheavens_door
を試すサンプルアプリを作ります
rails new heavens_door
次に、作成したRailsアプリのディレクトリに移動します
cd heavens_door
先ほどのrails new
でsqlite3
のインストールがエラーになっている場合は、以下のようにバージョンを指定してください
gem 'sqlite3', '1.3.13'
その後、bundle install
を実行します
bundle install
テストするためのCRUDを作成します
rails g scaffold post title content
その後、rails db:migrate
を実行します
rails db:migrate RAILS_ENV=test
rails db:migrate RAILS_ENV=test
でマイグレーションが実行できない場合は、Gemfile
のgem 'chromedriver-helper'
をコメントアウトします
heavens_door
を導入したいと思います!
Gemfile
にheavens_door
を追加します
gem 'heavens_door', group: :development
bundle install
でgem
をインストールします
bundle install
最後に、heavens_door
を使ってみましょう!
まず、test/intgration/posts_test.rb
を作成し、以下のようにします
require 'capybara/rails'
require 'capybara/minitest'
class ActionDispatch::IntegrationTest
include Capybara::DSL
include Capybara::Minitest::Assertions
def heavens_door
end
end
その後、rails s
でローカルサーバを起動し、localhost:3000/posts
にアクセスします
rails s
あとは画面右上に表示されているボタンをクリックするとUI操作の記録がはじまります
適当に操作したあと、バインダーマークをクリックするとUIテストのコードがクリップされます
あとは、test/intgration/posts_test.rb
にクリップしたコードを貼り付けます
require 'capybara/rails'
require 'capybara/minitest'
class ActionDispatch::IntegrationTest
# Make the Capybara DSL available in all integration tests
include Capybara::DSL
# Make `assert_*` methods behave like Minitest assertions
include Capybara::Minitest::Assertions
# Reset sessions and driver between tests
# Use super wherever this method is redefined in your individual test classes
def heavens_door
scenario 'GENERATED' do
visit '/posts'
click_link 'New Post'
fill_in 'Title', with: 'test'
fill_in 'Content', with: 'aaaaaaaaaaaaaaaaaaaaaaaaa'
click_button 'Create Post'
click_link 'Back'
end
end
end
最後に、rails test
を実行してください
rails test
テストが実行されていればOKです!
これでRailsアプリにHeavens Door
を導入できました!