File: metrics_log_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 (61 lines) | stat: -rw-r--r-- 2,385 bytes parent folder | download | duplicates (6)
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
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "components/metrics/metrics_log.h"

#include "base/command_line.h"
#include "build/build_config.h"
#include "chrome/browser/browser_process.h"
#include "chrome/common/chrome_switches.h"
#include "chrome/test/base/platform_browser_test.h"
#include "components/metrics/test/test_metrics_service_client.h"
#include "components/variations/hashing.h"
#include "components/webui/flags/flags_ui_switches.h"
#include "content/public/test/browser_test.h"
#include "third_party/metrics_proto/chrome_user_metrics_extension.pb.h"
#include "third_party/metrics_proto/system_profile.pb.h"

namespace metrics {

class MetricsLogBrowserTest : public PlatformBrowserTest {
 public:
  MetricsLogBrowserTest() = default;
  ~MetricsLogBrowserTest() override = default;

  void SetUpCommandLine(base::CommandLine* command_line) override {
    PlatformBrowserTest::SetUpCommandLine(command_line);
    command_line->AppendSwitch(switches::kNoStartupWindow);
    command_line->AppendSwitch(switches::kFlagSwitchesBegin);
    command_line->AppendSwitch(switches::kFlagSwitchesEnd);
  }
};

// Verify that system profile contains filtered command line keys.
IN_PROC_BROWSER_TEST_F(MetricsLogBrowserTest, CommandLineKeyHash) {
  TestMetricsServiceClient client;
  MetricsLog log("0a94430b-18e5-43c8-a657-580f7e855ce1", 0,
                 MetricsLog::INITIAL_STABILITY_LOG, &client);
  std::string encoded;
  // Don't set the close_time param since this is an initial stability log.
  log.FinalizeLog(/*truncate_events=*/false, client.GetVersionString(),
                  /*close_time=*/std::nullopt, &encoded);
  ChromeUserMetricsExtension uma_proto;
  uma_proto.ParseFromString(encoded);
  const auto hashes = uma_proto.system_profile().command_line_key_hash();

  bool found_startup_window_cmd = false;
  for (const auto hash : hashes) {
    // These two should be filtered out.
    EXPECT_NE(variations::HashName(switches::kFlagSwitchesBegin), hash);
    EXPECT_NE(variations::HashName(switches::kFlagSwitchesEnd), hash);
    // This one should appear.
    if (hash == variations::HashName(switches::kNoStartupWindow)) {
      found_startup_window_cmd = true;
      continue;
    }
  }
  EXPECT_TRUE(found_startup_window_cmd);
}

}  // namespace metrics