代码拉取完成,页面将自动刷新
#!/usr/bin/env python3
# Copyright 2023 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""This script manages the counter for how many times developers should
be notified before uploading reclient metrics."""
import json
import os
import subprocess
import sys
THIS_DIR = os.path.dirname(__file__)
CONFIG = os.path.join(THIS_DIR, 'reclient_metrics.cfg')
VERSION = 1
def default_config():
return {
'is-googler': is_googler(),
'countdown': 10,
'version': VERSION,
}
def load_config():
config = None
try:
with open(CONFIG) as f:
raw_config = json.load(f)
if raw_config['version'] == VERSION:
raw_config['countdown'] = max(0, raw_config['countdown'] - 1)
config = raw_config
except Exception:
pass
if not config:
config = default_config()
save_config(config)
return config
def save_config(config):
with open(CONFIG, 'w') as f:
json.dump(config, f)
def show_message(config, ninja_out):
print("""
Your reclient metrics will be uploaded to the chromium build metrics database. The uploaded metrics will be used to analyze user side build performance.
We upload the contents of {ninja_out_abs}.
This contains
* Flags passed to reproxy
* Auth related flags are filtered out by reproxy
* Start and end time of build tasks
* Aggregated durations and counts of events during remote build actions
* OS (e.g. Win, Mac or Linux)
* Number of cpu cores and the amount of RAM of the building machine
Uploading reclient metrics will be started after you run autoninja another {config_count} time(s).
If you don't want to upload reclient metrics, please run following command.
$ python3 {file_path} opt-out
If you want to allow upload reclient metrics from next autoninja run, please run the
following command.
$ python3 {file_path} opt-in
If you have questions about this, please send an email to foundry-x@google.com
You can find a more detailed explanation in
{metrics_readme_path}
or
https://chromium.googlesource.com/chromium/tools/depot_tools/+/main/reclient_metrics.README.md
""".format(
ninja_out_abs=os.path.abspath(
os.path.join(ninja_out, ".reproxy_tmp", "logs", "rbe_metrics.txt")),
config_count=config.get("countdown", 0),
file_path=__file__,
metrics_readme_path=os.path.abspath(
os.path.join(THIS_DIR, "reclient_metrics.README.md")),
))
def is_googler(config=None):
"""Check whether this user is Googler or not."""
if config is not None and 'is-googler' in config:
return config['is-googler']
# Use cipd auth-info to check for googler status as
# downloading rewrapper configs already requires cipd to be logged in
p = subprocess.run('cipd auth-info',
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
text=True,
shell=True)
if p.returncode != 0:
return False
lines = p.stdout.splitlines()
if len(lines) == 0:
return False
l = lines[0]
# |l| will be like 'Logged in as <user>@google.com.' for googlers.
return l.startswith('Logged in as ') and l.endswith('@google.com.')
def check_status(ninja_out):
"""Checks metrics collections status and shows notice to user if needed.
Returns True if metrics should be collected."""
config = load_config()
if not is_googler(config):
return False
if 'opt-in' in config:
return config['opt-in']
if config.get("countdown", 0) > 0:
show_message(config, ninja_out)
return False
return True
def main(argv):
cfg = load_config()
if not is_googler(cfg):
save_config(cfg)
return 0
if len(argv) == 2 and argv[1] == 'opt-in':
cfg['opt-in'] = True
cfg['countdown'] = 0
save_config(cfg)
print('reclient metrics upload is opted in.')
return 0
if len(argv) == 2 and argv[1] == 'opt-out':
cfg['opt-in'] = False
save_config(cfg)
print('reclient metrics upload is opted out.')
return 0
if __name__ == '__main__':
sys.exit(main(sys.argv))
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。