File: smoothness_metric_browsertest.cc

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (90 lines) | stat: -rw-r--r-- 3,166 bytes parent folder | download | duplicates (3)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include <string_view>

#include "build/build_config.h"
#include "chrome/browser/page_load_metrics/integration_tests/metric_integration_test.h"
#include "chrome/test/base/ui_test_utils.h"
#include "components/page_load_metrics/browser/page_load_metrics_util.h"
#include "content/public/test/browser_test.h"
#include "content/public/test/browser_test_utils.h"
#include "services/metrics/public/cpp/ukm_builders.h"

using ukm::builders::Graphics_Smoothness_FrameSequence;
using ukm::builders::Graphics_Smoothness_NormalizedPercentDroppedFrames;

namespace {

bool ExtractUKMSmoothnessMetric(const ukm::TestUkmRecorder& ukm_recorder,
                                std::string_view entry_name,
                                std::string_view metric_name,
                                int64_t* extracted_value) {
  std::map<ukm::SourceId, ukm::mojom::UkmEntryPtr> merged_entries =
      ukm_recorder.GetMergedEntriesByName(entry_name);
  EXPECT_EQ(1ul, merged_entries.size());
  if (merged_entries.size() != 1u)
    return false;
  const auto& kv = merged_entries.begin();
  auto* metric_value =
      ukm::TestUkmRecorder::GetEntryMetric(kv->second.get(), metric_name);
  if (!metric_value)
    return false;
  *extracted_value = *metric_value;
  return true;
}

}  // namespace

// TODO(crbug.com/40934889): Re-enable this test
#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
#define MAYBE_FrameSequenceAndAveragePercentDroppedUKMs \
  DISABLED_FrameSequenceAndAveragePercentDroppedUKMs
#else
#define MAYBE_FrameSequenceAndAveragePercentDroppedUKMs \
  FrameSequenceAndAveragePercentDroppedUKMs
#endif
IN_PROC_BROWSER_TEST_F(MetricIntegrationTest,
                       MAYBE_FrameSequenceAndAveragePercentDroppedUKMs) {
  LoadHTML(R"HTML(<div id='animate' style='width: 20px; height: 20px'></div>
    <img src="images/lcp-16x16.png"></img>
    <script>
      runtest = async() => {
        const promise = new Promise(resolve => {
          var r = 0;
          function run() {
            if (r >= 500) {
              resolve(true);
              return;
            }
            const now = new Date();
            while ((new Date() - now) < 20) {}
            animate.style.backgroundColor = `rgb(${r * 2}, 0, 0)`;
            requestAnimationFrame(run);
            ++r;
          }
          run();
        });
        return await promise;
      };
    </script>
    )HTML");

  ASSERT_TRUE(EvalJs(web_contents(), "runtest()").ExtractBool());

  // Finish session.
  web_contents()->ClosePage();
  ui_test_utils::WaitForBrowserToClose(browser());

  int64_t fsm_pdf_value;
  // FrameSequenceMetric export should show a value.
  ASSERT_TRUE(ExtractUKMSmoothnessMetric(
      ukm_recorder(), Graphics_Smoothness_FrameSequence::kEntryName,
      Graphics_Smoothness_FrameSequence::kPercentDroppedFramesName,
      &fsm_pdf_value));

  // Some of the frames should be dropped. It is not possible to measure the
  // exact number of dropped frames, so validate that it is non-zero.
  EXPECT_NE(fsm_pdf_value, 0);
}