+var testVal = function(valueObj) {
+ expect(8);
+
+ jQuery("#text1").val(valueObj( 'test' ));
+ equals( document.getElementById('text1').value, "test", "Check for modified (via val(String)) value of input element" );
+
+ jQuery("#text1").val(valueObj( undefined ));
+ equals( document.getElementById('text1').value, "", "Check for modified (via val(undefined)) value of input element" );
+
+ jQuery("#text1").val(valueObj( 67 ));
+ equals( document.getElementById('text1').value, "67", "Check for modified (via val(Number)) value of input element" );
+
+ jQuery("#text1").val(valueObj( null ));
+ equals( document.getElementById('text1').value, "", "Check for modified (via val(null)) value of input element" );
+
+ jQuery("#select1").val(valueObj( "3" ));
+ equals( jQuery("#select1").val(), "3", "Check for modified (via val(String)) value of select element" );
+
+ jQuery("#select1").val(valueObj( 2 ));
+ equals( jQuery("#select1").val(), "2", "Check for modified (via val(Number)) value of select element" );
+
+ jQuery("#select1").append("<option value='4'>four</option>");
+ jQuery("#select1").val(valueObj( 4 ));
+ equals( jQuery("#select1").val(), "4", "Should be possible to set the val() to a newly created option" );
+
+ // using contents will get comments regular, text, and comment nodes
+ var j = jQuery("#nonnodes").contents();
+ j.val(valueObj( "asdf" ));
+ equals( j.val(), "asdf", "Check node,textnode,comment with val()" );
+ j.removeAttr("value");
+}
+
+test("val(String/Number)", function() {
+ testVal(bareObj);
+});
+
+test("val(Function)", function() {
+ testVal(functionReturningObj);
+});
+
+test( "val(Array of Numbers) (Bug #7123)", function() {
+ expect(4);
+ jQuery('#form').append('<input type="checkbox" name="arrayTest" value="1" /><input type="checkbox" name="arrayTest" value="2" /><input type="checkbox" name="arrayTest" value="3" checked="checked" /><input type="checkbox" name="arrayTest" value="4" />');
+ var elements = jQuery('input[name=arrayTest]').val([ 1, 2 ]);
+ ok( elements[0].checked, "First element was checked" );
+ ok( elements[1].checked, "Second element was checked" );
+ ok( !elements[2].checked, "Third element was unchecked" );
+ ok( !elements[3].checked, "Fourth element remained unchecked" );
+
+ elements.remove();
+});
+
+test("val(Function) with incoming value", function() {
+ expect(10);
+
+ var oldVal = jQuery("#text1").val();
+
+ jQuery("#text1").val(function(i, val) {
+ equals( val, oldVal, "Make sure the incoming value is correct." );
+ return "test";
+ });
+
+ equals( document.getElementById('text1').value, "test", "Check for modified (via val(String)) value of input element" );
+
+ oldVal = jQuery("#text1").val();
+
+ jQuery("#text1").val(function(i, val) {
+ equals( val, oldVal, "Make sure the incoming value is correct." );
+ return 67;
+ });
+
+ equals( document.getElementById('text1').value, "67", "Check for modified (via val(Number)) value of input element" );
+
+ oldVal = jQuery("#select1").val();
+
+ jQuery("#select1").val(function(i, val) {
+ equals( val, oldVal, "Make sure the incoming value is correct." );
+ return "3";
+ });
+
+ equals( jQuery("#select1").val(), "3", "Check for modified (via val(String)) value of select element" );
+
+ oldVal = jQuery("#select1").val();
+
+ jQuery("#select1").val(function(i, val) {
+ equals( val, oldVal, "Make sure the incoming value is correct." );
+ return 2;
+ });
+
+ equals( jQuery("#select1").val(), "2", "Check for modified (via val(Number)) value of select element" );
+
+ jQuery("#select1").append("<option value='4'>four</option>");
+
+ oldVal = jQuery("#select1").val();
+
+ jQuery("#select1").val(function(i, val) {
+ equals( val, oldVal, "Make sure the incoming value is correct." );
+ return 4;
+ });
+
+ equals( jQuery("#select1").val(), "4", "Should be possible to set the val() to a newly created option" );
+});
+
+// testing if a form.reset() breaks a subsequent call to a select element's .val() (in IE only)
+test("val(select) after form.reset() (Bug #2551)", function() {
+ expect(3);
+
+ jQuery('<form id="kk" name="kk"><select id="kkk"><option value="cf">cf</option><option value="gf">gf</option></select></form>').appendTo("#main");
+
+ jQuery("#kkk").val( "gf" );
+
+ document.kk.reset();
+
+ equal( jQuery("#kkk")[0].value, "cf", "Check value of select after form reset." );
+ equal( jQuery("#kkk").val(), "cf", "Check value of select after form reset." );
+
+ // re-verify the multi-select is not broken (after form.reset) by our fix for single-select
+ same( jQuery('#select3').val(), ['1', '2'], 'Call val() on a multiple="multiple" select' );
+
+ jQuery("#kk").remove();
+});
+
+var testAddClass = function(valueObj) {
+ expect(5);