chromium/third_party/blink/web_tests/fast/dom/coreDOM-element-attribute-js-null.xhtml

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <style type="text/css">
        .pass { color: green; }
        .fail { color: red; }
    </style>
    <script type="text/javascript" charset="utf-8">
        function printOut(msg)
        {
            var console = document.getElementById("console");
            var span = document.createElementNS('http://www.w3.org/1999/xhtml', 'span');
            // span.innerHTML = msg + "<br />";
            span.appendChild(document.createTextNode(msg));
            span.appendChild(document.createElementNS('http://www.w3.org/1999/xhtml', 'br'));
            console.appendChild(span);
        }

        function resultStringifier(result)
        {
            if (result === "")
                return "the empty string";
            else if (result === undefined)
                return "undefined";
            else if (result === null)
                return "null";
            return "the string '" + result + "'";
        }

        function nullTestElementAttribute(elementType, element, attr, expected)
        {
            element[attr] = null;

            var result;
            if (element[attr] === expected)
                result = "TEST SUCCEEDED: The value was " + resultStringifier(expected) + ".";
            else
                result = "TEST FAILED: The value should have been " + resultStringifier(expected) + " but was " + resultStringifier(element[attr]) + ".";

            result += " [tested " + elementType + "." + attr + "]";
            printOut(result);
        }
        
        function runTests()
        {
            if (window.testRunner)
                testRunner.dumpAsText();

            var listing = [
                {
                    type: 'Attr',
                    elementToUse: document.createAttributeNS('http://www.w3.org/1999/xhtml','anAttribute'),
                    attributes: [
                        {name: 'value', expectedNull: 'null'},
                        {name: 'nodeValue', expectedNull: ''},
                        {name: 'textContent', expectedNull: ''}
                    ]
                },
                {
                    type: 'ProcessingInstruction',
                    elementToUse: document.createProcessingInstruction('target', 'data'),
                    attributes: [
                        {name: 'data', expectedNull: ''}
                    ]
                },
                {
                    type: 'CharacterData',
                    elementToUse: document.createTextNode('text'),
                    attributes: [
                        {name: 'data', expectedNull: ''}
                    ]
                }
            ];

            for (element in listing) {
                var type = listing[element].type;
                var elementToUse = listing[element].elementToUse;
                var attrs = listing[element].attributes;
                for (attr in attrs) {
                    nullTestElementAttribute(type, elementToUse, attrs[attr].name, attrs[attr].expectedNull);
                }
                printOut('');
            }
        }
        
    </script>
</head>

<body onload="runTests();">
    <p>This test setting various attributes of a elements to JavaScript null.</p>
    <div id="console"></div>
</body>
</html>