require 'spec_helper'
RSpec.describe Capybara do
describe '.string' do
let :string do
Capybara.string <<-STRING
simple_node
Totally awesome
Yes it is
Secret
STRING
end
it "allows using matchers" do
expect(string).to have_css('#page')
expect(string).not_to have_css('#does-not-exist')
end
it "allows using custom matchers" do
Capybara.add_selector :lifeform do
xpath { |name| "//option[contains(.,'#{name}')]" }
end
expect(string).to have_selector(:id, "page")
expect(string).not_to have_selector(:id, 'does-not-exist')
expect(string).to have_selector(:lifeform, "Monkey")
expect(string).not_to have_selector(:lifeform, "Gorilla")
end
it 'allows custom matcher using css' do
Capybara.add_selector :section do
css { |css_class| "section .#{css_class}" }
end
expect(string).to have_selector(:section, 'subsection')
expect(string).not_to have_selector(:section, 'section_8')
end
it "allows using matchers with text option" do
expect(string).to have_css('h1', :text => 'Totally awesome')
expect(string).not_to have_css('h1', :text => 'Not so awesome')
end
it "allows finding only visible nodes" do
expect(string.all(:css, '#secret', :visible => true)).to be_empty
expect(string.all(:css, '#secret', :visible => false).size).to eq(1)
end
it "allows finding elements and extracting text from them" do
expect(string.find('//h1').text).to eq('Totally awesome')
end
it "allows finding elements and extracting attributes from them" do
expect(string.find('//h1')[:data]).to eq('fantastic')
end
it "allows finding elements and extracting the tag name from them" do
expect(string.find('//h1').tag_name).to eq('h1')
end
it "allows finding elements and extracting the path" do
expect(string.find('//h1').path).to eq('/html/body/div/div[1]/h1')
end
it "allows finding elements and extracting the path" do
expect(string.find('//div/input').value).to eq('bar')
expect(string.find('//select').value).to eq('Capybara')
end
it "allows finding elements and checking if they are visible" do
expect(string.find('//h1')).to be_visible
expect(string.find(:css, "#secret", :visible => false)).not_to be_visible
end
it "allows finding elements and checking if they are disabled" do
expect(string.find('//form/input[@name="bleh"]')).to be_disabled
expect(string.find('//form/input[@name="meh"]')).not_to be_disabled
end
describe "#title" do
it "returns the page title" do
expect(string.title).to eq("simple_node")
end
end
describe "#has_title?" do
it "returns whether the page has the given title" do
expect(string.has_title?('simple_node')).to be_truthy
expect(string.has_title?('monkey')).to be_falsey
end
it "allows regexp matches" do
expect(string.has_title?(/s[a-z]+_node/)).to be_truthy
expect(string.has_title?(/monkey/)).to be_falsey
end
end
describe '#has_no_title?' do
it "returns whether the page does not have the given title" do
expect(string.has_no_title?('simple_node')).to be_falsey
expect(string.has_no_title?('monkey')).to be_truthy
end
it "allows regexp matches" do
expect(string.has_no_title?(/s[a-z]+_node/)).to be_falsey
expect(string.has_no_title?(/monkey/)).to be_truthy
end
end
end
end