chromium/third_party/blink/web_tests/fast/lists/list-style-position-inside.html

<!DOCTYPE html>
<html>
    <head>
        <style>
            section {
                display: inline-block;
                width: 300px;
                border: 1px solid blue;
                margin: 5px 0;
                padding: 5px;
            }
            section > h1 {
                font-size: 1.1em;
                margin: 0;
            }
            
            li {
                list-style-position: inside;
                margin: 5px;
                background: silver;
            }
            ul, ol {
                margin: 0;
                padding: 0;
            }
            
            .floating > ul > li, .floating > ol > li {
                float: left;
            }
            .floating > p {
                clear: both;
            }
            
            .block > ul, .block > ol {
                display: inline-block;
                margin: 0;
                padding: 0;
            }
        </style>
        <script src="../../resources/js-test.js"></script>
    </head>

    <body>
        <header>
            <h1>list-style-position: inside</h1>
            <p>
                Tests that lists with header the list marker displayed
                inside the item works as expected.
            </p>
        </header>
        
        <section class="floating">
            <h1>Floating, Unordered</h1>
            <ul>
                <li>Item A</li>
                <li>Item B</li>
                <li>Item C</li>
            </ul>
            <p>
                The list markers above should be inside the respective
                list item boxes.
            </p>
        </section>
        <section class="floating">
            <h1>Floating, Ordered</h1>
            <ol>
                <li>Item A</li>
                <li>Item B</li>
                <li>Item C</li>
            </ol>
            <p>
                The list markers above should be inside the respective
                list item boxes.
            </p>
        </section>
        <br>

        <section class="block">
            <h1>Block, Unordered</h1>
            <ul>
                <li>Item A</li>
                <li>Item B</li>
                <li>Item C</li>
            </ul>
            <p>
                The list markers above should be inside the respective
                list item boxes and the text should not wrap.
            </p>
        </section>
        
        <section class="block">
            <h1>Block, Ordered</h1>
            <ol>
                <li>Item A</li>
                <li>Item B</li>
                <li>Item C</li>
            </ol>
            <p>
                The list markers above should be inside the respective
                list item boxes and the text should not wrap.
            </p>
        </section>
        <br>
        
        <section class="reference">
            <h1>Reference, Unordered</h1>
            <ul>
                <li>Item A</li>
            </ul>
        </section>

        <section class="reference">
            <h1>Reference, Ordered</h1>
            <ol>
                <li>Item A</li>
            </ol>
        </section>
        
        <script>
            function getItems(className, tagName)
            {
                var selector = '.' + className + ' > ' + tagName;
                var block = document.querySelector(selector);
                return block.getElementsByTagName('li');
            }

            function test(className, tagName)
            {
                var referenceHeight = getItems('reference', tagName)[0].
                    getBoundingClientRect().height;
                var testItems = getItems(className, tagName);
                
                // Check that all items have the right height
                var failed = 0;
                for (var item, i = 0; item = testItems[i]; i++) {
                    var rect = item.getBoundingClientRect();
                    if (rect.height != referenceHeight) {
                        failed++;
                        testFailed('Item ' + i + ' in ' + className +
                            ' ' + tagName + ' has height of ' +
                            rect.height + 'px, expecting ' +
                            referenceHeight + 'px.');
                    }
                }
                if (!failed)
                    testPassed('All items in ' + className + ' ' +
                        tagName + ' has the expected height.');

                // Change list-style-type to none and back to ensure
                // that the width changes.
                for (var item, i = 0; item = testItems[i]; i++) {
                    item.style.listStyleType = 'none';
                }
                var width = testItems[0].getBoundingClientRect().width;
                for (var item, i = 0; item = testItems[i]; i++) {
                    item.style.listStyleType = '';
                }
                if (testItems[0].getBoundingClientRect().width != width)
                    testPassed('Width of first item in ' + className +
                        ' ' + tagName + ' is affected by list marker ' + 
                        'as expected.');
                else
                    testFailed('Width of first item in ' + className +
                        ' ' + tagName + ' is not affected by list ' + 
                        'marker as expected.');
            }
            
            test('floating', 'ul');
            test('floating', 'ol');
            test('block', 'ul');
            test('block', 'ol');

            // Only include test results in test output.
            if (window.testRunner) {
                while (document.body.lastChild != document.body.firstChild)
                    document.body.removeChild(document.body.lastChild);
            }
        </script>
    </body>
</html>