<!DOCTYPE html>
<html>
<head>
<script src="../../resources/js-test.js"></script>
</head>
<body>
<p>This test case ensures that nameNodeListCache should be invalidate when name attribute changes.</p>
<div id="console"></div>
<script>
var element1;
var element2;
function createElement(type, properties)
{
var element = document.createElement(type);
for (var i in properties)
if (properties.hasOwnProperty(i))
element.setAttribute(i,properties[i]);
document.body.appendChild(element);
return element;
}
function createTwoElements(tagName)
{
element1 = createElement(tagName, {name: 'fullname'});
element2 = createElement(tagName, {name: 'fullname'});
}
function runTest(tagName)
{
shouldBe("createTwoElements('" + tagName + "'); document.getElementsByName('fullname').length", "2");
shouldBe("document.querySelector('" + tagName + "').setAttribute('name', 'changed-name'); document.getElementsByName('fullname').length", "1");
document.body.removeChild(element1);
document.body.removeChild(element2);
debug('');
}
runTest('a');
runTest('applet');
runTest('embed');
runTest('section');
runTest('frame');
runTest('form');
runTest('iframe');
runTest('img');
runTest('map');
runTest('meta');
runTest('object');
runTest('param');
var successfullyParsed = true;
</script>
</body>
</html>