summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/user-timing/mark.html
blob: e03e9e6247adabb186783e06a493dcc3a7ecb464 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>functionality test of window.performance.mark</title>
<link rel="author" title="Intel" href="http://www.intel.com/" />
<link rel="help" href="http://www.w3.org/TR/user-timing/#extensions-performance-interface"/>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/performance-timeline-utils.js"></script>
<script src="resources/webperftestharness.js"></script>
<script src="resources/webperftestharnessextension.js"></script>
<script>
setup({ explicit_done: true });

function onload_test()
{
    const entrylist_checker = new performance_entrylist_checker('mark');
    const string_mark_names = mark_names.map(function (x) { return String(x)});

    test_equals(performance.getEntriesByType("mark").length, 0, 'There should be ' + 0 + ' marks');
    mark_names.forEach(function(name) {
        performance.mark(name);
    });
    let mark_entrylist = performance.getEntriesByType('mark');

    entrylist_checker.entrylist_check(mark_entrylist, mark_names.length, string_mark_names, 'Checking all entries.');

    for (let i = 0; i < mark_entrylist.length; ++i)
    {
        const mark_entrylist_by_name = performance.getEntriesByName(mark_entrylist[i].name, 'mark');
        entrylist_checker.entrylist_check(mark_entrylist_by_name, 1, string_mark_names,
            'First loop: checking entry of name "' + mark_entrylist[i].name + '".');
    }

    mark_names.forEach(function(name) {
        performance.mark(name);
    });
    mark_entrylist = performance.getEntriesByType('mark');
    entrylist_checker.entrylist_check(mark_entrylist, mark_names.length * 2, string_mark_names, 'Checking all doubly marked entries.');

    for (let i = 0; i < mark_entrylist.length; ++i)
    {
        const mark_entrylist_by_name = performance.getEntriesByName(mark_entrylist[i].name, 'mark');
        entrylist_checker.entrylist_check(mark_entrylist_by_name, 2, string_mark_names,
            'Second loop step ' + i + ': checking entries of name "' + mark_entrylist[i].name + '".');
    }

    done();
}
</script>
</head>
<body onload=onload_test()>
    <h1>Description</h1>
    <p>This test validates functionality of the interface window.performance.mark.</p>
    <div id="log"></div>
</body>
</html>