chromium/third_party/blink/web_tests/fast/forms/basic-buttons.html

<!DocType html><html> 
<body> 

Tests for basic button rendering. Creates a table with seven columns and seven rows. <BR>
Creates two different types of buttons, one with an image (a red dot) and another <BR>
with text ("foo") and then uses six different paddings to make sure each of the buttons render properly.
<BR><BR>

<script>
var fooImage = '<img src="" alt="Red dot" />';

function getRowHtml(style) 
{
     return '<tr><td>' + (style || '(default)') + '</td>' +
         '<td><button ' + (style ? 'style="' + style + '"' : '') + '>' + fooImage + '</button></td>' +
         '<td></td>' +
         '<td><input type="button" value="foo" style="' + style + '"></td>' +
         '<td></td></tr>';
}

document.body.innerHTML += '<table cellspacing=0><tbody>' +
     '<tr><td>styling</td><td>&lt;button&gt;</td><td>(offsetH,W) (clientH,W)</td>' +
     '<td>&lt;input type=button&gt;</td><td>(offsetH,W) (clientH, -W)</td>' +
     '</tr>' +
     getRowHtml('') +
     getRowHtml('padding: 0') +
     getRowHtml('padding: 10%') +
     getRowHtml('padding: 2px') +
     getRowHtml('padding: 2px 6px 3px 6px') +
     getRowHtml('padding: 3px 7px') +
     getRowHtml('padding: 20px') +
     '</tbody></table>';

function printSize(tagname, cell) 
{
    var buttons = document.getElementsByTagName(tagname);
    for (var i = 0; i < buttons.length; i++) {
        var button = buttons[i];

        var table = document.getElementsByTagName('table')[0];
        var rows = table.rows;
        var thisCell = button.parentNode;
        var thisRow = thisCell.parentNode;

        button.parentNode.nextSibling.innerHTML = 
            "(" + button.offsetHeight + ", " + button.offsetWidth + ") " +
            "(" + button.clientHeight + ", " + button.clientWidth + ")";
    }
}

window.onload = function() {
    printSize('button');
    printSize('input');
};
</script>

</body> 
</html>