spec/watirspec/elements/button_spec.rb in watir-6.13.0 vs spec/watirspec/elements/button_spec.rb in watir-6.14.0

- old
+ new

@@ -1,212 +1,211 @@ -require "watirspec_helper" +require 'watirspec_helper' -describe "Button" do - +describe 'Button' do before :each do - browser.goto(WatirSpec.url_for("forms_with_input_elements.html")) + browser.goto(WatirSpec.url_for('forms_with_input_elements.html')) end # Exists method - describe "#exists?" do - it "returns true if the button exists (tag = :input)" do - expect(browser.button(id: "new_user_submit")).to exist + describe '#exists?' do + it 'returns true if the button exists (tag = :input)' do + expect(browser.button(id: 'new_user_submit')).to exist expect(browser.button(id: /new_user_submit/)).to exist - expect(browser.button(name: "new_user_reset")).to exist + expect(browser.button(name: 'new_user_reset')).to exist expect(browser.button(name: /new_user_reset/)).to exist - expect(browser.button(value: "Button")).to exist + expect(browser.button(value: 'Button')).to exist expect(browser.button(value: /Button/)).to exist not_compliant_on :internet_explorer do - expect(browser.button(src: "images/button.png")).to exist + expect(browser.button(src: 'images/button.png')).to exist end expect(browser.button(src: /button\.png/)).to exist - expect(browser.button(text: "Button 2")).to exist + expect(browser.button(text: 'Button 2')).to exist expect(browser.button(text: /Button 2/)).to exist - expect(browser.button(class: "image")).to exist + expect(browser.button(class: 'image')).to exist expect(browser.button(class: /image/)).to exist expect(browser.button(index: 0)).to exist expect(browser.button(xpath: "//input[@id='new_user_submit']")).to exist - expect(browser.button(alt: "Create a new user")).to exist + expect(browser.button(alt: 'Create a new user')).to exist expect(browser.button(alt: /Create a/)).to exist end - it "returns true if the button exists (tag = :button)" do - expect(browser.button(name: "new_user_button_2")).to exist + it 'returns true if the button exists (tag = :button)' do + expect(browser.button(name: 'new_user_button_2')).to exist expect(browser.button(name: /new_user_button_2/)).to exist - expect(browser.button(value: "button_2")).to exist + expect(browser.button(value: 'button_2')).to exist expect(browser.button(value: /button_2/)).to exist expect(browser.button(text: 'Button 2')).to exist expect(browser.button(text: /Button 2/)).to exist expect(browser.button(value: 'Button 2')).to exist expect(browser.button(value: /Button 2/)).to exist end - it "returns true if the button exists (how = :caption)" do - expect(browser.button(caption: "Button 2")).to exist + it 'returns true if the button exists (how = :caption)' do + expect(browser.button(caption: 'Button 2')).to exist expect(browser.button(caption: /Button 2/)).to exist end - it "returns the first button if given no args" do + it 'returns the first button if given no args' do expect(browser.button).to exist end - it "returns true for element with upper case type" do - expect(browser.button(id: "new_user_button_preview")).to exist + it 'returns true for element with upper case type' do + expect(browser.button(id: 'new_user_button_preview')).to exist end it "returns false if the button doesn't exist" do - expect(browser.button(id: "no_such_id")).to_not exist + expect(browser.button(id: 'no_such_id')).to_not exist expect(browser.button(id: /no_such_id/)).to_not exist - expect(browser.button(name: "no_such_name")).to_not exist + expect(browser.button(name: 'no_such_name')).to_not exist expect(browser.button(name: /no_such_name/)).to_not exist - expect(browser.button(value: "no_such_value")).to_not exist + expect(browser.button(value: 'no_such_value')).to_not exist expect(browser.button(value: /no_such_value/)).to_not exist - expect(browser.button(src: "no_such_src")).to_not exist + expect(browser.button(src: 'no_such_src')).to_not exist expect(browser.button(src: /no_such_src/)).to_not exist - expect(browser.button(text: "no_such_text")).to_not exist + expect(browser.button(text: 'no_such_text')).to_not exist expect(browser.button(text: /no_such_text/)).to_not exist - expect(browser.button(class: "no_such_class")).to_not exist + expect(browser.button(class: 'no_such_class')).to_not exist expect(browser.button(class: /no_such_class/)).to_not exist expect(browser.button(index: 1337)).to_not exist expect(browser.button(xpath: "//input[@id='no_such_id']")).to_not exist end - it "checks the tag name and type attribute when locating by xpath" do + it 'checks the tag name and type attribute when locating by xpath' do expect(browser.button(xpath: "//input[@type='text']")).to_not exist expect(browser.button(xpath: "//input[@type='button']")).to exist end - it "matches the specific type when locating by type" do - expect(browser.button(type: "button").type).to eq "button" - expect(browser.button(type: "reset").type).to eq "reset" - expect(browser.button(type: "submit").type).to eq "submit" - expect(browser.button(type: "image").type).to eq "image" + it 'matches the specific type when locating by type' do + expect(browser.button(type: 'button').type).to eq 'button' + expect(browser.button(type: 'reset').type).to eq 'reset' + expect(browser.button(type: 'submit').type).to eq 'submit' + expect(browser.button(type: 'image').type).to eq 'image' end - it "matches valid input types when type is boolean" do - expect(browser.buttons(type: false).map(&:tag_name)).to all eq("button") + it 'matches valid input types when type is boolean' do + expect(browser.buttons(type: false).map(&:tag_name)).to all eq('button') - input_buttons = browser.buttons(type: true).select { |e| e.tag_name == "input" } + input_buttons = browser.buttons(type: true).select { |e| e.tag_name == 'input' } expect(input_buttons.map(&:type).uniq).to match_array(Watir::Button::VALID_TYPES) end it "raises TypeError when 'what' argument is invalid" do expect { browser.button(id: 3.14).exists? }.to raise_error(TypeError) end end # Attribute methods - describe "#class_name" do - it "returns the class name of the button" do - expect(browser.button(name: "new_user_image").class_name).to eq "image" + describe '#class_name' do + it 'returns the class name of the button' do + expect(browser.button(name: 'new_user_image').class_name).to eq 'image' end - it "returns an empty string if the button has no class name" do - expect(browser.button(name: "new_user_submit").class_name).to eq "" + it 'returns an empty string if the button has no class name' do + expect(browser.button(name: 'new_user_submit').class_name).to eq '' end end - describe "#id" do - it "returns the id if the button exists" do + describe '#id' do + it 'returns the id if the button exists' do expect(browser.button(index: 0).id).to eq 'new_user_submit' expect(browser.button(index: 1).id).to eq 'new_user_reset' expect(browser.button(index: 2).id).to eq 'new_user_button' end - it "raises UnknownObjectException if button does not exist" do + it 'raises UnknownObjectException if button does not exist' do expect { browser.button(index: 1337).id }.to raise_unknown_object_exception end end - describe "#name" do - it "returns the name if button exists" do + describe '#name' do + it 'returns the name if button exists' do expect(browser.button(index: 0).name).to eq 'new_user_submit' expect(browser.button(index: 1).name).to eq 'new_user_reset' expect(browser.button(index: 2).name).to eq 'new_user_button' end - it "raises UnknownObjectException if the button does not exist" do - expect { browser.button(name: "no_such_name").name }.to raise_unknown_object_exception + it 'raises UnknownObjectException if the button does not exist' do + expect { browser.button(name: 'no_such_name').name }.to raise_unknown_object_exception end end - describe "#src" do - it "returns the src attribute for the button image" do + describe '#src' do + it 'returns the src attribute for the button image' do # varies between browsers - expect(browser.button(name: "new_user_image").src).to include("images/button.png") + expect(browser.button(name: 'new_user_image').src).to include('images/button.png') end - it "raises UnknownObjectException if the button does not exist" do - expect { browser.button(name: "no_such_name").src }.to raise_unknown_object_exception + it 'raises UnknownObjectException if the button does not exist' do + expect { browser.button(name: 'no_such_name').src }.to raise_unknown_object_exception end end - describe "#style" do + describe '#style' do not_compliant_on :internet_explorer do - it "returns the style attribute if the button exists" do - expect(browser.button(id: 'delete_user_submit').style).to eq "border: 4px solid red;" + it 'returns the style attribute if the button exists' do + expect(browser.button(id: 'delete_user_submit').style).to eq 'border: 4px solid red;' end end it "returns an empty string if the element exists and the attribute doesn't exist" do - expect(browser.button(id: 'new_user_submit').style).to eq "" + expect(browser.button(id: 'new_user_submit').style).to eq '' end - it "raises UnknownObjectException if the button does not exist" do - expect { browser.button(name: "no_such_name").style }.to raise_unknown_object_exception + it 'raises UnknownObjectException if the button does not exist' do + expect { browser.button(name: 'no_such_name').style }.to raise_unknown_object_exception end end - describe "#title" do - it "returns the title of the button" do + describe '#title' do + it 'returns the title of the button' do expect(browser.button(index: 0).title).to eq 'Submit the form' end - it "returns an empty string for button without title" do + it 'returns an empty string for button without title' do expect(browser.button(index: 1).title).to eq '' end end - describe "#type" do - it "returns the type if button exists" do + describe '#type' do + it 'returns the type if button exists' do expect(browser.button(index: 0).type).to eq 'submit' expect(browser.button(index: 1).type).to eq 'reset' expect(browser.button(index: 2).type).to eq 'button' end - it "raises UnknownObjectException if button does not exist" do - expect { browser.button(name: "no_such_name").type }.to raise_unknown_object_exception + it 'raises UnknownObjectException if button does not exist' do + expect { browser.button(name: 'no_such_name').type }.to raise_unknown_object_exception end end - describe "#value" do - it "returns the value if button exists" do + describe '#value' do + it 'returns the value if button exists' do expect(browser.button(index: 0).value).to eq 'Submit' expect(browser.button(index: 1).value).to eq 'Reset' expect(browser.button(index: 2).value).to eq 'Button' end - it "raises UnknownObjectException if button does not exist" do - expect { browser.button(name: "no_such_name").value }.to raise_unknown_object_exception + it 'raises UnknownObjectException if button does not exist' do + expect { browser.button(name: 'no_such_name').value }.to raise_unknown_object_exception end end - describe "#text" do - it "returns the text of the button" do + describe '#text' do + it 'returns the text of the button' do expect(browser.button(index: 0).text).to eq 'Submit' expect(browser.button(index: 1).text).to eq 'Reset' expect(browser.button(index: 2).text).to eq 'Button' expect(browser.button(index: 3).text).to eq 'Preview' end - it "raises UnknownObjectException if the element does not exist" do - expect { browser.button(id: "no_such_id").text }.to raise_unknown_object_exception + it 'raises UnknownObjectException if the element does not exist' do + expect { browser.button(id: 'no_such_id').text }.to raise_unknown_object_exception end end - describe "#respond_to?" do - it "returns true for all attribute methods" do + describe '#respond_to?' do + it 'returns true for all attribute methods' do expect(browser.button(index: 0)).to respond_to(:class_name) expect(browser.button(index: 0)).to respond_to(:id) expect(browser.button(index: 0)).to respond_to(:name) expect(browser.button(index: 0)).to respond_to(:src) expect(browser.button(index: 0)).to respond_to(:style) @@ -215,63 +214,61 @@ expect(browser.button(index: 0)).to respond_to(:value) end end # Access methods - describe "#enabled?" do - it "returns true if the button is enabled" do + describe '#enabled?' do + it 'returns true if the button is enabled' do expect(browser.button(name: 'new_user_submit')).to be_enabled end - it "returns false if the button is disabled" do + it 'returns false if the button is disabled' do expect(browser.button(name: 'new_user_submit_disabled')).to_not be_enabled end it "raises UnknownObjectException if the button doesn't exist" do - expect { browser.button(name: "no_such_name").enabled? }.to raise_unknown_object_exception + expect { browser.button(name: 'no_such_name').enabled? }.to raise_unknown_object_exception end - it "raises ObjectDisabledException if disabled button is clicked" do - expect { browser.button(name: "new_user_submit_disabled").click }.to raise_object_disabled_exception + it 'raises ObjectDisabledException if disabled button is clicked' do + expect { browser.button(name: 'new_user_submit_disabled').click }.to raise_object_disabled_exception end end - describe "#disabled?" do - it "returns false when button is enabled" do + describe '#disabled?' do + it 'returns false when button is enabled' do expect(browser.button(name: 'new_user_submit')).to_not be_disabled end - it "returns true when button is disabled" do + it 'returns true when button is disabled' do expect(browser.button(name: 'new_user_submit_disabled')).to be_disabled end - it "raises UnknownObjectException if button does not exist" do - expect { browser.button(name: "no_such_name").disabled? }.to raise_unknown_object_exception + it 'raises UnknownObjectException if button does not exist' do + expect { browser.button(name: 'no_such_name').disabled? }.to raise_unknown_object_exception end end # Manipulation methods - describe "#click" do - it "clicks the button if it exists" do - browser.goto(WatirSpec.url_for("forms_with_input_elements.html")) + describe '#click' do + it 'clicks the button if it exists' do + browser.goto(WatirSpec.url_for('forms_with_input_elements.html')) browser.button(id: 'delete_user_submit').click - Watir::Wait.until { !browser.url.include? 'forms_with_input_elements.html'} - expect(browser.text).to include("Semantic table") + Watir::Wait.until { !browser.url.include? 'forms_with_input_elements.html' } + expect(browser.text).to include('Semantic table') end - it "fires events" do + it 'fires events' do browser.button(id: 'new_user_button').click expect(browser.button(id: 'new_user_button').value).to eq 'new_value_set_by_onclick_event' end it "raises UnknownObjectException when clicking a button that doesn't exist" do - expect { browser.button(value: "no_such_value").click }.to raise_unknown_object_exception - expect { browser.button(id: "no_such_id").click }.to raise_unknown_object_exception + expect { browser.button(value: 'no_such_value').click }.to raise_unknown_object_exception + expect { browser.button(id: 'no_such_id').click }.to raise_unknown_object_exception end - it "raises ObjectDisabledException when clicking a disabled button" do - expect { browser.button(value: "Disabled").click }.to raise_object_disabled_exception + it 'raises ObjectDisabledException when clicking a disabled button' do + expect { browser.button(value: 'Disabled').click }.to raise_object_disabled_exception end end - - end