The following test passed first time (after rake db:test:prepare
) but failed gave error on subsequent run.
Capybara::ElementNotFound: Unable to find css "#sale_payment_btn"
require "test_helper"
DatabaseCleaner.strategy = :transaction
class SaleFeatureTest < Capybara::Rails::TestCase
include Warden::Test::Helpers
Warden.test_mode!
self.use_transactional_fixtures = false
setup do
login_as users(:admin), scope: :user
Capybara.current_driver = :selenium #:webkit
DatabaseCleaner.start
end
teardown do
DatabaseCleaner.clean
Warden.test_reset!
end
test "Sale" do
visit(new_sale_path) # create new sale and redirect to it
assert page.has_css?('#sale_payment_btn') # gave error at second time
find(:css, '#sale_payment_btn').click # this create payment
end
As I used selenium with chrome, I could see the ID of the sale. I noticed that the ID was the same for subsequent test. i.e. 980190963
My theory is that
database_cleaner
not functioning as expected. (Although I see DB cleaning sql commands ontest.log
file, I saw data remained in database)visit
does not create new@sale
(as stated here though I use minitest) because#sal_payment_btn
is not rendered (sale already haspayment
on first run).
I'm pulling my hair around for half day now. I have tried
webkit
driver- different cleaning strategy
truncation
,deletion
and I still can't pass the test on second run. It is running okay on manual test.
What and where did I do wrong?
P.S. I'm using the following gems
minitest-rails-capybara
selenium-webdriver
chromedriver-helper
database_cleaner
minitest-around
pg
I have read the following
- http://blog.berylliumwork.com/2013/07/rails-4-devise-3-minitest-and-capybara.html
- Database Cleaner not working in minitest rails
- Rails minitest, database cleaner how to turn use_transactional_fixtures = false