spec/watirspec/elements/radio_spec.rb in watir-6.10.0 vs spec/watirspec/elements/radio_spec.rb in watir-6.10.1
- old
+ new
@@ -1,273 +1,273 @@
-require "watirspec_helper"
-
-describe "Radio" do
-
- before :each do
- browser.goto(WatirSpec.url_for("forms_with_input_elements.html"))
- end
-
- # Exists method
- describe "#exists?" do
- it "returns true if the radio button exists" do
- expect(browser.radio(id: "new_user_newsletter_yes")).to exist
- expect(browser.radio(id: /new_user_newsletter_yes/)).to exist
- expect(browser.radio(name: "new_user_newsletter")).to exist
- expect(browser.radio(name: /new_user_newsletter/)).to exist
- expect(browser.radio(value: "yes")).to exist
- expect(browser.radio(value: /yes/)).to exist
- expect(browser.radio(text: "Yes")).to exist
- expect(browser.radio(text: /Yes/)).to exist
- expect(browser.radio(class: "huge")).to exist
- expect(browser.radio(class: /huge/)).to exist
- expect(browser.radio(index: 0)).to exist
- expect(browser.radio(xpath: "//input[@id='new_user_newsletter_yes']")).to exist
- end
-
- it "returns the first radio if given no args" do
- expect(browser.radio).to exist
- end
-
- it "returns true if the radio button exists (search by name and value)" do
- expect(browser.radio(name: "new_user_newsletter", value: 'yes')).to exist
- browser.radio(xpath: "//input[@name='new_user_newsletter' and @value='yes']").set
- end
-
- it "returns true for element with upper case type" do
- expect(browser.radio(id: "new_user_newsletter_probably")).to exist
- end
-
- it "returns false if the radio button does not exist" do
- expect(browser.radio(id: "no_such_id")).to_not exist
- expect(browser.radio(id: /no_such_id/)).to_not exist
- expect(browser.radio(name: "no_such_name")).to_not exist
- expect(browser.radio(name: /no_such_name/)).to_not exist
- expect(browser.radio(value: "no_such_value")).to_not exist
- expect(browser.radio(value: /no_such_value/)).to_not exist
- expect(browser.radio(text: "no_such_text")).to_not exist
- expect(browser.radio(text: /no_such_text/)).to_not exist
- expect(browser.radio(class: "no_such_class")).to_not exist
- expect(browser.radio(class: /no_such_class/)).to_not exist
- expect(browser.radio(index: 1337)).to_not exist
- expect(browser.radio(xpath: "input[@id='no_such_id']")).to_not exist
- end
-
- it "returns false if the radio button does not exist (search by name and value)" do
- expect(browser.radio(name: "new_user_newsletter", value: 'no_such_value')).to_not exist
- expect(browser.radio(xpath: "//input[@name='new_user_newsletter' and @value='no_such_value']")).to_not exist
- expect(browser.radio(name: "no_such_name", value: 'yes')).to_not exist
- expect(browser.radio(xpath: "//input[@name='no_such_name' and @value='yes']")).to_not exist
- end
-
- it "returns true for radios with a string value" do
- expect(browser.radio(name: 'new_user_newsletter', value: 'yes')).to exist
- expect(browser.radio(name: 'new_user_newsletter', value: 'no')).to exist
- end
-
- it "raises TypeError when 'what' argument is invalid" do
- expect { browser.radio(id: 3.14).exists? }.to raise_error(TypeError)
- end
- end
-
- # Attribute methods
- describe "#class_name" do
- it "returns the class name if the radio exists and has an attribute" do
- expect(browser.radio(id: "new_user_newsletter_yes").class_name).to eq "huge"
- end
-
- it "returns an empty string if the radio exists and the attribute doesn't" do
- expect(browser.radio(id: "new_user_newsletter_no").class_name).to eq ""
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(id: "no_such_id").class_name }.to raise_unknown_object_exception
- end
- end
-
- describe "#id" do
- it "returns the id attribute if the radio exists and has an attribute" do
- expect(browser.radio(index: 0).id).to eq "new_user_newsletter_yes"
- end
-
- it "returns an empty string if the radio exists and the attribute doesn't" do
- expect(browser.radio(index: 2).id).to eq ""
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).id }.to raise_unknown_object_exception
- end
- end
-
- describe "#name" do
- it "returns the name attribute if the radio exists" do
- expect(browser.radio(id: 'new_user_newsletter_yes').name).to eq "new_user_newsletter"
- end
-
- it "returns an empty string if the radio exists and the attribute doesn't" do
- expect(browser.radio(id: 'new_user_newsletter_absolutely').name).to eq ""
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).name }.to raise_unknown_object_exception
- end
- end
-
- describe "#text" do
- it "returns the text if the radio exists" do
- expect(browser.radio(id: 'new_user_newsletter_yes').text).to eq "Yes"
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).text }.to raise_unknown_object_exception
- end
-
- it "returns empty string when there is no label" do
- form = browser.form(id: "new_user")
- expect(form.radio(index: 2).text).to eq ''
- end
- end
-
- describe "#title" do
- it "returns the title attribute if the radio exists" do
- expect(browser.radio(id: "new_user_newsletter_no").title).to eq "Traitor!"
- end
-
- it "returns an empty string if the radio exists and the attribute doesn't" do
- expect(browser.radio(id: "new_user_newsletter_yes").title).to eq ""
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).title }.to raise_unknown_object_exception
- end
- end
-
- describe "#type" do
- it "returns the type attribute if the radio exists" do
- expect(browser.radio(index: 0).type).to eq "radio"
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).type }.to raise_unknown_object_exception
- end
- end
-
- describe "#value" do
- it "returns the value attribute if the radio exists" do
- expect(browser.radio(id: 'new_user_newsletter_yes').value).to eq 'yes'
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).value}.to raise_unknown_object_exception
- end
- end
-
- describe "#respond_to?" do
- it "returns true for all attribute methods" do
- expect(browser.radio(index: 0)).to respond_to(:class_name)
- expect(browser.radio(index: 0)).to respond_to(:id)
- expect(browser.radio(index: 0)).to respond_to(:name)
- expect(browser.radio(index: 0)).to respond_to(:title)
- expect(browser.radio(index: 0)).to respond_to(:type)
- expect(browser.radio(index: 0)).to respond_to(:value)
- end
- end
-
- # Access methods
- describe "#enabled?" do
- it "returns true if the radio button is enabled" do
- expect(browser.radio(id: "new_user_newsletter_yes")).to be_enabled
- expect(browser.radio(xpath: "//input[@id='new_user_newsletter_yes']")).to be_enabled
- end
-
- it "returns false if the radio button is disabled" do
- expect(browser.radio(id: "new_user_newsletter_nah")).to_not be_enabled
- expect(browser.radio(xpath: "//input[@id='new_user_newsletter_nah']")).to_not be_enabled
- end
-
- it "raises UnknownObjectException if the radio button doesn't exist" do
- expect { browser.radio(id: "no_such_id").enabled? }.to raise_unknown_object_exception
- expect { browser.radio(xpath: "//input[@id='no_such_id']").enabled? }.to raise_unknown_object_exception
- end
- end
-
- describe "#disabled?" do
- it "returns true if the radio is disabled" do
- expect(browser.radio(id: 'new_user_newsletter_nah')).to be_disabled
- end
-
- it "returns false if the radio is enabled" do
- expect(browser.radio(id: 'new_user_newsletter_yes')).to_not be_disabled
- end
-
- it "raises UnknownObjectException if the radio doesn't exist" do
- expect { browser.radio(index: 1337).disabled? }.to raise_unknown_object_exception
- end
- end
-
- describe "#set" do
- it "sets the radio button" do
- browser.radio(id: "new_user_newsletter_no").set
- expect(browser.radio(id: "new_user_newsletter_no")).to be_set
- end
-
- it "sets the radio button when found by :xpath" do
- browser.radio(xpath: "//input[@id='new_user_newsletter_no']").set
- expect(browser.radio(xpath: "//input[@id='new_user_newsletter_no']")).to be_set
- end
-
- it "fires the onclick event" do
- browser.radio(id: "new_user_newsletter_no").set
- browser.radio(id: "new_user_newsletter_yes").set
- expect(messages).to eq ["clicked: new_user_newsletter_no", "clicked: new_user_newsletter_yes"]
- end
-
- # http://webbugtrack.blogspot.com/2007/11/bug-193-onchange-does-not-fire-properly.html
- not_compliant_on :internet_explorer do
- it "fires the onchange event" do
- browser.radio(value: 'certainly').set
- expect(messages).to eq ["changed: new_user_newsletter"]
-
- browser.radio(value: 'certainly').set
- expect(messages).to eq ["changed: new_user_newsletter"] # no event fired here - didn't change
-
- browser.radio(value: 'yes').set
- browser.radio(value: 'certainly').set
- expect(messages).to eq ["changed: new_user_newsletter", "clicked: new_user_newsletter_yes", "changed: new_user_newsletter"]
- end
- end
-
- it "raises UnknownObjectException if the radio button doesn't exist" do
- expect { browser.radio(name: "no_such_name").set }.to raise_unknown_object_exception
- expect { browser.radio(xpath: "//input[@name='no_such_name']").set }.to raise_unknown_object_exception
- end
-
- it "raises ObjectDisabledException if the radio is disabled" do
- expect { browser.radio(id: "new_user_newsletter_nah").set }.to raise_object_disabled_exception
- expect { browser.radio(xpath: "//input[@id='new_user_newsletter_nah']").set }.to raise_object_disabled_exception
- end
- end
-
- # Other
- describe '#set?' do
- it "returns true if the radio button is set" do
- expect(browser.radio(id: "new_user_newsletter_yes")).to be_set
- end
-
- it "returns false if the radio button unset" do
- expect(browser.radio(id: "new_user_newsletter_no")).to_not be_set
- end
-
- it "returns the state for radios with string values" do
- expect(browser.radio(name: "new_user_newsletter", value: 'no')).to_not be_set
- browser.radio(name: "new_user_newsletter", value: 'no').set
- expect(browser.radio(name: "new_user_newsletter", value: 'no')).to be_set
- browser.radio(name: "new_user_newsletter", value: 'yes').set
- expect(browser.radio(name: "new_user_newsletter", value: 'no')).to_not be_set
- end
-
- it "raises UnknownObjectException if the radio button doesn't exist" do
- expect { browser.radio(id: "no_such_id").set? }.to raise_unknown_object_exception
- expect { browser.radio(xpath: "//input[@id='no_such_id']").set? }.to raise_unknown_object_exception
- end
- end
-
-end
+require "watirspec_helper"
+
+describe "Radio" do
+
+ before :each do
+ browser.goto(WatirSpec.url_for("forms_with_input_elements.html"))
+ end
+
+ # Exists method
+ describe "#exists?" do
+ it "returns true if the radio button exists" do
+ expect(browser.radio(id: "new_user_newsletter_yes")).to exist
+ expect(browser.radio(id: /new_user_newsletter_yes/)).to exist
+ expect(browser.radio(name: "new_user_newsletter")).to exist
+ expect(browser.radio(name: /new_user_newsletter/)).to exist
+ expect(browser.radio(value: "yes")).to exist
+ expect(browser.radio(value: /yes/)).to exist
+ expect(browser.radio(text: "Yes")).to exist
+ expect(browser.radio(text: /Yes/)).to exist
+ expect(browser.radio(class: "huge")).to exist
+ expect(browser.radio(class: /huge/)).to exist
+ expect(browser.radio(index: 0)).to exist
+ expect(browser.radio(xpath: "//input[@id='new_user_newsletter_yes']")).to exist
+ end
+
+ it "returns the first radio if given no args" do
+ expect(browser.radio).to exist
+ end
+
+ it "returns true if the radio button exists (search by name and value)" do
+ expect(browser.radio(name: "new_user_newsletter", value: 'yes')).to exist
+ browser.radio(xpath: "//input[@name='new_user_newsletter' and @value='yes']").set
+ end
+
+ it "returns true for element with upper case type" do
+ expect(browser.radio(id: "new_user_newsletter_probably")).to exist
+ end
+
+ it "returns false if the radio button does not exist" do
+ expect(browser.radio(id: "no_such_id")).to_not exist
+ expect(browser.radio(id: /no_such_id/)).to_not exist
+ expect(browser.radio(name: "no_such_name")).to_not exist
+ expect(browser.radio(name: /no_such_name/)).to_not exist
+ expect(browser.radio(value: "no_such_value")).to_not exist
+ expect(browser.radio(value: /no_such_value/)).to_not exist
+ expect(browser.radio(text: "no_such_text")).to_not exist
+ expect(browser.radio(text: /no_such_text/)).to_not exist
+ expect(browser.radio(class: "no_such_class")).to_not exist
+ expect(browser.radio(class: /no_such_class/)).to_not exist
+ expect(browser.radio(index: 1337)).to_not exist
+ expect(browser.radio(xpath: "input[@id='no_such_id']")).to_not exist
+ end
+
+ it "returns false if the radio button does not exist (search by name and value)" do
+ expect(browser.radio(name: "new_user_newsletter", value: 'no_such_value')).to_not exist
+ expect(browser.radio(xpath: "//input[@name='new_user_newsletter' and @value='no_such_value']")).to_not exist
+ expect(browser.radio(name: "no_such_name", value: 'yes')).to_not exist
+ expect(browser.radio(xpath: "//input[@name='no_such_name' and @value='yes']")).to_not exist
+ end
+
+ it "returns true for radios with a string value" do
+ expect(browser.radio(name: 'new_user_newsletter', value: 'yes')).to exist
+ expect(browser.radio(name: 'new_user_newsletter', value: 'no')).to exist
+ end
+
+ it "raises TypeError when 'what' argument is invalid" do
+ expect { browser.radio(id: 3.14).exists? }.to raise_error(TypeError)
+ end
+ end
+
+ # Attribute methods
+ describe "#class_name" do
+ it "returns the class name if the radio exists and has an attribute" do
+ expect(browser.radio(id: "new_user_newsletter_yes").class_name).to eq "huge"
+ end
+
+ it "returns an empty string if the radio exists and the attribute doesn't" do
+ expect(browser.radio(id: "new_user_newsletter_no").class_name).to eq ""
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(id: "no_such_id").class_name }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#id" do
+ it "returns the id attribute if the radio exists and has an attribute" do
+ expect(browser.radio(index: 0).id).to eq "new_user_newsletter_yes"
+ end
+
+ it "returns an empty string if the radio exists and the attribute doesn't" do
+ expect(browser.radio(index: 2).id).to eq ""
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).id }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#name" do
+ it "returns the name attribute if the radio exists" do
+ expect(browser.radio(id: 'new_user_newsletter_yes').name).to eq "new_user_newsletter"
+ end
+
+ it "returns an empty string if the radio exists and the attribute doesn't" do
+ expect(browser.radio(id: 'new_user_newsletter_absolutely').name).to eq ""
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).name }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#text" do
+ it "returns the text if the radio exists" do
+ expect(browser.radio(id: 'new_user_newsletter_yes').text).to eq "Yes"
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).text }.to raise_unknown_object_exception
+ end
+
+ it "returns empty string when there is no label" do
+ form = browser.form(id: "new_user")
+ expect(form.radio(index: 2).text).to eq ''
+ end
+ end
+
+ describe "#title" do
+ it "returns the title attribute if the radio exists" do
+ expect(browser.radio(id: "new_user_newsletter_no").title).to eq "Traitor!"
+ end
+
+ it "returns an empty string if the radio exists and the attribute doesn't" do
+ expect(browser.radio(id: "new_user_newsletter_yes").title).to eq ""
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).title }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#type" do
+ it "returns the type attribute if the radio exists" do
+ expect(browser.radio(index: 0).type).to eq "radio"
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).type }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#value" do
+ it "returns the value attribute if the radio exists" do
+ expect(browser.radio(id: 'new_user_newsletter_yes').value).to eq 'yes'
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).value}.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#respond_to?" do
+ it "returns true for all attribute methods" do
+ expect(browser.radio(index: 0)).to respond_to(:class_name)
+ expect(browser.radio(index: 0)).to respond_to(:id)
+ expect(browser.radio(index: 0)).to respond_to(:name)
+ expect(browser.radio(index: 0)).to respond_to(:title)
+ expect(browser.radio(index: 0)).to respond_to(:type)
+ expect(browser.radio(index: 0)).to respond_to(:value)
+ end
+ end
+
+ # Access methods
+ describe "#enabled?" do
+ it "returns true if the radio button is enabled" do
+ expect(browser.radio(id: "new_user_newsletter_yes")).to be_enabled
+ expect(browser.radio(xpath: "//input[@id='new_user_newsletter_yes']")).to be_enabled
+ end
+
+ it "returns false if the radio button is disabled" do
+ expect(browser.radio(id: "new_user_newsletter_nah")).to_not be_enabled
+ expect(browser.radio(xpath: "//input[@id='new_user_newsletter_nah']")).to_not be_enabled
+ end
+
+ it "raises UnknownObjectException if the radio button doesn't exist" do
+ expect { browser.radio(id: "no_such_id").enabled? }.to raise_unknown_object_exception
+ expect { browser.radio(xpath: "//input[@id='no_such_id']").enabled? }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#disabled?" do
+ it "returns true if the radio is disabled" do
+ expect(browser.radio(id: 'new_user_newsletter_nah')).to be_disabled
+ end
+
+ it "returns false if the radio is enabled" do
+ expect(browser.radio(id: 'new_user_newsletter_yes')).to_not be_disabled
+ end
+
+ it "raises UnknownObjectException if the radio doesn't exist" do
+ expect { browser.radio(index: 1337).disabled? }.to raise_unknown_object_exception
+ end
+ end
+
+ describe "#set" do
+ it "sets the radio button" do
+ browser.radio(id: "new_user_newsletter_no").set
+ expect(browser.radio(id: "new_user_newsletter_no")).to be_set
+ end
+
+ it "sets the radio button when found by :xpath" do
+ browser.radio(xpath: "//input[@id='new_user_newsletter_no']").set
+ expect(browser.radio(xpath: "//input[@id='new_user_newsletter_no']")).to be_set
+ end
+
+ it "fires the onclick event" do
+ browser.radio(id: "new_user_newsletter_no").set
+ browser.radio(id: "new_user_newsletter_yes").set
+ expect(messages).to eq ["clicked: new_user_newsletter_no", "clicked: new_user_newsletter_yes"]
+ end
+
+ # http://webbugtrack.blogspot.com/2007/11/bug-193-onchange-does-not-fire-properly.html
+ not_compliant_on :internet_explorer do
+ it "fires the onchange event" do
+ browser.radio(value: 'certainly').set
+ expect(messages).to eq ["changed: new_user_newsletter"]
+
+ browser.radio(value: 'certainly').set
+ expect(messages).to eq ["changed: new_user_newsletter"] # no event fired here - didn't change
+
+ browser.radio(value: 'yes').set
+ browser.radio(value: 'certainly').set
+ expect(messages).to eq ["changed: new_user_newsletter", "clicked: new_user_newsletter_yes", "changed: new_user_newsletter"]
+ end
+ end
+
+ it "raises UnknownObjectException if the radio button doesn't exist" do
+ expect { browser.radio(name: "no_such_name").set }.to raise_unknown_object_exception
+ expect { browser.radio(xpath: "//input[@name='no_such_name']").set }.to raise_unknown_object_exception
+ end
+
+ it "raises ObjectDisabledException if the radio is disabled" do
+ expect { browser.radio(id: "new_user_newsletter_nah").set }.to raise_object_disabled_exception
+ expect { browser.radio(xpath: "//input[@id='new_user_newsletter_nah']").set }.to raise_object_disabled_exception
+ end
+ end
+
+ # Other
+ describe '#set?' do
+ it "returns true if the radio button is set" do
+ expect(browser.radio(id: "new_user_newsletter_yes")).to be_set
+ end
+
+ it "returns false if the radio button unset" do
+ expect(browser.radio(id: "new_user_newsletter_no")).to_not be_set
+ end
+
+ it "returns the state for radios with string values" do
+ expect(browser.radio(name: "new_user_newsletter", value: 'no')).to_not be_set
+ browser.radio(name: "new_user_newsletter", value: 'no').set
+ expect(browser.radio(name: "new_user_newsletter", value: 'no')).to be_set
+ browser.radio(name: "new_user_newsletter", value: 'yes').set
+ expect(browser.radio(name: "new_user_newsletter", value: 'no')).to_not be_set
+ end
+
+ it "raises UnknownObjectException if the radio button doesn't exist" do
+ expect { browser.radio(id: "no_such_id").set? }.to raise_unknown_object_exception
+ expect { browser.radio(xpath: "//input[@id='no_such_id']").set? }.to raise_unknown_object_exception
+ end
+ end
+
+end