-test("index(Object)", function() {
- expect(8);
- ok( $([window, document]).index(window) == 0, "Check for index of elements" );
- ok( $([window, document]).index(document) == 1, "Check for index of elements" );
- var inputElements = $('#radio1,#radio2,#check1,#check2');
- ok( inputElements.index(document.getElementById('radio1')) == 0, "Check for index of elements" );
- ok( inputElements.index(document.getElementById('radio2')) == 1, "Check for index of elements" );
- ok( inputElements.index(document.getElementById('check1')) == 2, "Check for index of elements" );
- ok( inputElements.index(document.getElementById('check2')) == 3, "Check for index of elements" );
- ok( inputElements.index(window) == -1, "Check for not found index" );
- ok( inputElements.index(document) == -1, "Check for not found index" );
-});
-
-test("attr(String)", function() {
- expect(20);
- ok( $('#text1').attr('value') == "Test", 'Check for value attribute' );
- ok( $('#text1').attr('value', "Test2").attr('defaultValue') == "Test", 'Check for defaultValue attribute' );
- ok( $('#text1').attr('type') == "text", 'Check for type attribute' );
- ok( $('#radio1').attr('type') == "radio", 'Check for type attribute' );
- ok( $('#check1').attr('type') == "checkbox", 'Check for type attribute' );
- ok( $('#simon1').attr('rel') == "bookmark", 'Check for rel attribute' );
- ok( $('#google').attr('title') == "Google!", 'Check for title attribute' );
- ok( $('#mark').attr('hreflang') == "en", 'Check for hreflang attribute' );
- ok( $('#en').attr('lang') == "en", 'Check for lang attribute' );
- ok( $('#simon').attr('class') == "blog link", 'Check for class attribute' );
- ok( $('#name').attr('name') == "name", 'Check for name attribute' );
- ok( $('#text1').attr('name') == "action", 'Check for name attribute' );
- ok( $('#form').attr('action').indexOf("formaction") >= 0, 'Check for action attribute' );
- ok( $('#text1').attr('maxlength') == '30', 'Check for maxlength attribute' );
- ok( $('#text1').attr('maxLength') == '30', 'Check for maxLength attribute' );
- ok( $('#area1').attr('maxLength') == '30', 'Check for maxLength attribute' );
- ok( $('#select2').attr('selectedIndex') == 3, 'Check for selectedIndex attribute' );
- ok( $('#foo').attr('nodeName') == 'DIV', 'Check for nodeName attribute' );
- ok( $('#foo').attr('tagName') == 'DIV', 'Check for tagName attribute' );
-
- $('<a id="tAnchor5"></a>').attr('href', '#5').appendTo('#main'); // using innerHTML in IE causes href attribute to be serialized to the full path
- ok( $('#tAnchor5').attr('href') == "#5", 'Check for non-absolute href (an anchor)' );
-});
-
-if ( !isLocal ) {
- test("attr(String) in XML Files", function() {
- expect(2);
- stop();
- $.get("data/dashboard.xml", function(xml) {
- ok( $("locations", xml).attr("class") == "foo", "Check class attribute in XML document" );
- ok( $("location", xml).attr("for") == "bar", "Check for attribute in XML document" );
- start();
- });
- });
-}
-
-test("attr(String, Function)", function() {
- expect(2);
- ok( $('#text1').attr('value', function() { return this.id })[0].value == "text1", "Set value from id" );
- ok( $('#text1').attr('title', function(i) { return i }).attr('title') == "0", "Set value with an index");
-});
-
-test("attr(Hash)", function() {
- expect(1);
- var pass = true;
- $("div").attr({foo: 'baz', zoo: 'ping'}).each(function(){
- if ( this.getAttribute('foo') != "baz" && this.getAttribute('zoo') != "ping" ) pass = false;
- });
- ok( pass, "Set Multiple Attributes" );
-});
-
-test("attr(String, Object)", function() {
- expect(17);
- var div = $("div");
- div.attr("foo", "bar");
- var pass = true;
- for ( var i = 0; i < div.size(); i++ ) {
- if ( div.get(i).getAttribute('foo') != "bar" ) pass = false;
- }
- ok( pass, "Set Attribute" );
-
- ok( $("#foo").attr({"width": null}), "Try to set an attribute to nothing" );
-
- $("#name").attr('name', 'something');
- ok( $("#name").attr('name') == 'something', 'Set name attribute' );
- $("#check2").attr('checked', true);
- ok( document.getElementById('check2').checked == true, 'Set checked attribute' );
- $("#check2").attr('checked', false);
- ok( document.getElementById('check2').checked == false, 'Set checked attribute' );
- $("#text1").attr('readonly', true);
- ok( document.getElementById('text1').readOnly == true, 'Set readonly attribute' );
- $("#text1").attr('readonly', false);
- ok( document.getElementById('text1').readOnly == false, 'Set readonly attribute' );
- $("#name").attr('maxlength', '5');
- ok( document.getElementById('name').maxLength == '5', 'Set maxlength attribute' );
- $("#name").attr('maxLength', '10');
- ok( document.getElementById('name').maxLength == '10', 'Set maxlength attribute' );
-
- // for #1070
- $("#name").attr('someAttr', '0');
- equals( $("#name").attr('someAttr'), '0', 'Set attribute to a string of "0"' );
- $("#name").attr('someAttr', 0);
- equals( $("#name").attr('someAttr'), 0, 'Set attribute to the number 0' );
- $("#name").attr('someAttr', 1);
- equals( $("#name").attr('someAttr'), 1, 'Set attribute to the number 1' );
-
- // using contents will get comments regular, text, and comment nodes
- var j = $("#nonnodes").contents();
-
- j.attr("name", "attrvalue");
- equals( j.attr("name"), "attrvalue", "Check node,textnode,comment for attr" );
- j.removeAttr("name")
-
- reset();
-
- var type = $("#check2").attr('type');
- var thrown = false;
- try {
- $("#check2").attr('type','hidden');
- } catch(e) {
- thrown = true;
- }
- ok( thrown, "Exception thrown when trying to change type property" );
- equals( type, $("#check2").attr('type'), "Verify that you can't change the type of an input element" );
-
- var check = document.createElement("input");
- var thrown = true;
- try {
- $(check).attr('type','checkbox');
- } catch(e) {
- thrown = false;
- }
- ok( thrown, "Exception thrown when trying to change type property" );
- equals( "checkbox", $(check).attr('type'), "Verify that you can change the type of an input element that isn't in the DOM" );
-});
-
-if ( !isLocal ) {
- test("attr(String, Object) - Loaded via XML document", function() {
- expect(2);
- stop();
- $.get('data/dashboard.xml', function(xml) {
- var titles = [];
- $('tab', xml).each(function() {
- titles.push($(this).attr('title'));
- });
- equals( titles[0], 'Location', 'attr() in XML context: Check first title' );
- equals( titles[1], 'Users', 'attr() in XML context: Check second title' );
- start();
- });
- });
-}
-
-test("css(String|Hash)", function() {
- expect(19);
-
- ok( $('#main').css("display") == 'none', 'Check for css property "display"');
-
- ok( $('#foo').is(':visible'), 'Modifying CSS display: Assert element is visible');
- $('#foo').css({display: 'none'});
- ok( !$('#foo').is(':visible'), 'Modified CSS display: Assert element is hidden');
- $('#foo').css({display: 'block'});
- ok( $('#foo').is(':visible'), 'Modified CSS display: Assert element is visible');
-
- $('#floatTest').css({styleFloat: 'right'});
- ok( $('#floatTest').css('styleFloat') == 'right', 'Modified CSS float using "styleFloat": Assert float is right');
- $('#floatTest').css({cssFloat: 'left'});
- ok( $('#floatTest').css('cssFloat') == 'left', 'Modified CSS float using "cssFloat": Assert float is left');
- $('#floatTest').css({'float': 'right'});
- ok( $('#floatTest').css('float') == 'right', 'Modified CSS float using "float": Assert float is right');
- $('#floatTest').css({'font-size': '30px'});
- ok( $('#floatTest').css('font-size') == '30px', 'Modified CSS font-size: Assert font-size is 30px');
-
- $.each("0,0.25,0.5,0.75,1".split(','), function(i, n) {
- $('#foo').css({opacity: n});
- ok( $('#foo').css('opacity') == parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a String" );
- $('#foo').css({opacity: parseFloat(n)});
- ok( $('#foo').css('opacity') == parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a Number" );
- });
- $('#foo').css({opacity: ''});
- ok( $('#foo').css('opacity') == '1', "Assert opacity is 1 when set to an empty String" );
-});