lib/capybara/spec/session/find_field_spec.rb in capybara-3.3.1 vs lib/capybara/spec/session/find_field_spec.rb in capybara-3.4.0

- old
+ new

@@ -3,109 +3,111 @@ Capybara::SpecHelper.spec '#find_field' do before do @session.visit('/form') end - it "should find any field" do + it 'should find any field' do + Capybara.test_id = 'data-test-id' expect(@session.find_field('Dog').value).to eq('dog') expect(@session.find_field('form_description').value).to eq('Descriptive text goes here') expect(@session.find_field('Region')[:name]).to eq('form[region]') expect(@session.find_field('With Asterisk*')).to be_truthy + expect(@session.find_field('my_test_id')).to be_truthy end - context "aria_label attribute with Capybara.enable_aria_label" do - it "should find when true" do + context 'aria_label attribute with Capybara.enable_aria_label' do + it 'should find when true' do Capybara.enable_aria_label = true expect(@session.find_field('Unlabelled Input')[:name]).to eq('form[which_form]') # expect(@session.find_field('Emergency Number')[:id]).to eq('html5_tel') end - it "should not find when false" do + it 'should not find when false' do Capybara.enable_aria_label = false expect { @session.find_field('Unlabelled Input') }.to raise_error(Capybara::ElementNotFound) # expect { @session.find_field('Emergency Number') }.to raise_error(Capybara::ElementNotFound) end end - it "casts to string" do + it 'casts to string' do expect(@session.find_field(:Dog).value).to eq('dog') end it "should raise error if the field doesn't exist" do expect do @session.find_field('Does not exist') end.to raise_error(Capybara::ElementNotFound) end - it "should raise error if filter option is invalid" do + it 'should raise error if filter option is invalid' do expect do @session.find_field('Dog', disabled: nil) - end.to raise_error ArgumentError, "Invalid value nil passed to NodeFilter disabled" + end.to raise_error ArgumentError, 'Invalid value nil passed to NodeFilter disabled' end - context "with :exact option" do - it "should accept partial matches when false" do - expect(@session.find_field("Explanation", exact: false)[:name]).to eq("form[name_explanation]") + context 'with :exact option' do + it 'should accept partial matches when false' do + expect(@session.find_field('Explanation', exact: false)[:name]).to eq('form[name_explanation]') end - it "should not accept partial matches when true" do + it 'should not accept partial matches when true' do expect do - @session.find_field("Explanation", exact: true) + @session.find_field('Explanation', exact: true) end.to raise_error(Capybara::ElementNotFound) end end - context "with :disabled option" do - it "should find disabled fields when true" do - expect(@session.find_field("Disabled Checkbox", disabled: true)[:name]).to eq("form[disabled_checkbox]") - expect(@session.find_field("form_disabled_fieldset_child", disabled: true)[:name]).to eq("form[disabled_fieldset_child]") - expect(@session.find_field("form_disabled_fieldset_descendant", disabled: true)[:name]).to eq("form[disabled_fieldset_descendant]") + context 'with :disabled option' do + it 'should find disabled fields when true' do + expect(@session.find_field('Disabled Checkbox', disabled: true)[:name]).to eq('form[disabled_checkbox]') + expect(@session.find_field('form_disabled_fieldset_child', disabled: true)[:name]).to eq('form[disabled_fieldset_child]') + expect(@session.find_field('form_disabled_fieldset_descendant', disabled: true)[:name]).to eq('form[disabled_fieldset_descendant]') end - it "should not find disabled fields when false" do + it 'should not find disabled fields when false' do expect do - @session.find_field("Disabled Checkbox", disabled: false) + @session.find_field('Disabled Checkbox', disabled: false) end.to raise_error(Capybara::ElementNotFound) end - it "should not find disabled fields by default" do + it 'should not find disabled fields by default' do expect do - @session.find_field("Disabled Checkbox") + @session.find_field('Disabled Checkbox') end.to raise_error(Capybara::ElementNotFound) end - it "should find disabled fields when :all" do - expect(@session.find_field("Disabled Checkbox", disabled: :all)[:name]).to eq("form[disabled_checkbox]") + it 'should find disabled fields when :all' do + expect(@session.find_field('Disabled Checkbox', disabled: :all)[:name]).to eq('form[disabled_checkbox]') end - it "should find enabled fields when :all" do + it 'should find enabled fields when :all' do expect(@session.find_field('Dog', disabled: :all).value).to eq('dog') end end context 'with :readonly option' do - it "should find readonly fields when true" do + it 'should find readonly fields when true' do expect(@session.find_field('form[readonly_test]', readonly: true)[:id]).to eq 'readonly' end - it "should not find readonly fields when false" do + it 'should not find readonly fields when false' do expect(@session.find_field('form[readonly_test]', readonly: false)[:id]).to eq 'not_readonly' end - it "should ignore readonly by default" do + it 'should ignore readonly by default' do expect do @session.find_field('form[readonly_test]') end.to raise_error(Capybara::Ambiguous, /found 2 elements/) end end context 'with no locator' do it 'should use options to find the field' do - expect(@session.find_field(with: 'dog')['id']).to eq "form_pets_dog" + expect(@session.find_field(with: 'dog')['id']).to eq 'form_pets_dog' end end - it "should accept an optional filter block" do + it 'should accept an optional filter block' do # this would be better done with the :with option but this is just a test - expect(@session.find_field('form[pets][]') { |node| node.value == 'dog' }[:id]).to eq "form_pets_dog" + expect(@session.find_field('form[pets][]') { |node| node.value == 'dog' }[:id]).to eq 'form_pets_dog' end end