summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/user-timing/clearMeasures.html
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 09:22:09 +0000
commit43a97878ce14b72f0981164f87f2e35e14151312 (patch)
tree620249daf56c0258faa40cbdcf9cfba06de2a846 /testing/web-platform/tests/user-timing/clearMeasures.html
parentInitial commit. (diff)
downloadfirefox-43a97878ce14b72f0981164f87f2e35e14151312.tar.xz
firefox-43a97878ce14b72f0981164f87f2e35e14151312.zip
Adding upstream version 110.0.1.upstream/110.0.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/user-timing/clearMeasures.html')
-rw-r--r--testing/web-platform/tests/user-timing/clearMeasures.html77
1 files changed, 77 insertions, 0 deletions
diff --git a/testing/web-platform/tests/user-timing/clearMeasures.html b/testing/web-platform/tests/user-timing/clearMeasures.html
new file mode 100644
index 0000000000..54d4100569
--- /dev/null
+++ b/testing/web-platform/tests/user-timing/clearMeasures.html
@@ -0,0 +1,77 @@
+<!DOCTYPE html>
+<html>
+<head>
+<meta charset="utf-8" />
+<title>functionality test of window.performance.clearMeasures</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 context = new PerformanceContext(window.performance);
+ const entrylist_checker = new performance_entrylist_checker('measure');
+ const measure_names = measures.map(function(x) {return x[0];});
+
+ mark_names.forEach(function(name) {
+ context.mark(name);
+ });
+ measures.forEach(context.initialMeasures, context);
+ for (let i = 0; i < measures.length; ++i)
+ {
+ context.clearMeasures(measures[i][0]);
+ const retained_entries = context.getEntriesByType('measure');
+ const non_retained_entries = context.getEntriesByName(measures[i][0], 'measure');
+ entrylist_checker.entrylist_check(retained_entries, measures.length - i - 1, measure_names,
+ 'First loop: checking entries after removing "' + measures[i][0] + '". ');
+ test_equals(non_retained_entries.length, 0,
+ 'First loop: measure "' + measures[i][0] + '" should not exist anymore after we cleared it.');
+ }
+
+ measures.forEach(context.initialMeasures, context);
+ context.clearMeasures();
+ test_equals(context.getEntriesByType('measure').length, 0, 'No measures should exist after we clear all (after first loop).');
+
+ // Following cases test clear existed measure name that is tied twice.
+ measures.forEach(context.initialMeasures, context);
+ mark_names.forEach(function(name) {
+ context.mark(name);
+ });
+ measures.forEach(context.initialMeasures, context);
+ for (let i = 0; i < measures.length; ++i)
+ {
+ context.clearMeasures(measures[i][0]);
+ const retained_entries = context.getEntriesByType('measure');
+ const non_retained_entries = context.getEntriesByName(measures[i][0], 'measure');
+ entrylist_checker.entrylist_check(retained_entries, (measures.length - i - 1) * 2, measure_names,
+ 'Second loop: checking entries after removing "' + measures[i][0] + '". ');
+ test_equals(non_retained_entries.length, 0,
+ 'Second loop: measure "' + measures[i][0] +'" should not exist anymore after we cleared it.');
+ }
+
+ // Following cases test clear functionality when measure names are tied twice.
+ measures.forEach(context.initialMeasures, context);
+ measures.forEach(context.initialMeasures, context);
+ const entry_number_before_useless_clear = context.getEntriesByType('measure').length;
+ context.clearMeasures('NonExist');
+ const entry_number_after_useless_clear = context.getEntriesByType('measure').length;
+ test_equals(entry_number_before_useless_clear, entry_number_after_useless_clear, 'Nothing should happen if we clear a non-exist measure');
+ context.clearMeasures();
+ test_equals(context.getEntriesByType('measure').length, 0, 'No measures should exist when we clear all (after second loop).');
+
+ done();
+}
+</script>
+</head>
+<body onload=onload_test()>
+ <h1>Description</h1>
+ <p>This test validates functionality of the interface window.performance.clearMeasures.</p>
+ <div id="log"></div>
+</body>
+</html>