Testing HTML Content Retrieval Methods in teamcapybara/capybara
This test suite validates Capybara’s HTML content retrieval methods including html(), source(), and body(). It ensures proper page content extraction and dynamic content handling in both static and JavaScript-enabled environments.
Test Coverage Overview
Implementation Analysis
Technical Details
Best Practices Demonstrated
teamcapybara/capybara
lib/capybara/spec/session/html_spec.rb
# frozen_string_literal: true
# NOTE: This file uses `sleep` to sync up parts of the tests. This is only implemented like this
# because of the methods being tested. In tests using Capybara this type of behavior should be implemented
# using Capybara provided assertions with builtin waiting behavior.
Capybara::SpecHelper.spec '#html' do
it 'should return the unmodified page body' do
@session.visit('/')
expect(@session.html).to include('Hello world!')
end
it 'should return the current state of the page', requires: [:js] do
@session.visit('/with_js')
sleep 1
expect(@session.html).to include('I changed it')
expect(@session.html).not_to include('This is text')
end
end
Capybara::SpecHelper.spec '#source' do
it 'should return the unmodified page source' do
@session.visit('/')
expect(@session.source).to include('Hello world!')
end
it 'should return the current state of the page', requires: [:js] do
@session.visit('/with_js')
sleep 1
expect(@session.source).to include('I changed it')
expect(@session.source).not_to include('This is text')
end
end
Capybara::SpecHelper.spec '#body' do
it 'should return the unmodified page source' do
@session.visit('/')
expect(@session.body).to include('Hello world!')
end
it 'should return the current state of the page', requires: [:js] do
@session.visit('/with_js')
sleep 1
expect(@session.body).to include('I changed it')
expect(@session.body).not_to include('This is text')
end
end