Capybara is confusing me. If I use Capybara in combination with Ruby on Rails 3 and RSpec 2, then in RSpec request tests, the following matcher works:
response.body.should have_selector "div.some_class"
The response object has the class ActionDispatch::TestResponse. But the following line, which should work officially, does not work:
page.should have_selector "div.some_class"
The page object has the class Capybara::Session. In which cases do you have to use the response.body object and when do you have to use a page object ?
So I just ran into similar, and this is I think what’s going on:
It depends on code you didn’t include here of how you visit the page. I’m writing an rspec request spec.
If I retrieve the page with rspec’s own:
then response.body.should have_selector works as you say, but page.should does not.
To make Capybara ‘page’ work (and to make Capybara interactions like click_button or fill_in work), instead of retrieving with rspec’s ‘get’, you need to retrieve with Capybara’s ‘visit’:
‘page’, a capybara method, only gets set when using ‘visit’, a capybara method.
This does get confusing, all the mixing and matching of different libraries involved in rails testing.