xref: /aosp_15_r20/tools/acloud/metrics/metrics.py (revision 800a58d989c669b8eb8a71d8df53b1ba3d411444)
1*800a58d9SAndroid Build Coastguard Worker# Copyright 2018 - The Android Open Source Project
2*800a58d9SAndroid Build Coastguard Worker#
3*800a58d9SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
4*800a58d9SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
5*800a58d9SAndroid Build Coastguard Worker# You may obtain a copy of the License at
6*800a58d9SAndroid Build Coastguard Worker#
7*800a58d9SAndroid Build Coastguard Worker#     http://www.apache.org/licenses/LICENSE-2.0
8*800a58d9SAndroid Build Coastguard Worker#
9*800a58d9SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
10*800a58d9SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
11*800a58d9SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*800a58d9SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
13*800a58d9SAndroid Build Coastguard Worker# limitations under the License.
14*800a58d9SAndroid Build Coastguard Workerr"""Acloud metrics functions."""
15*800a58d9SAndroid Build Coastguard Worker
16*800a58d9SAndroid Build Coastguard Workerimport logging
17*800a58d9SAndroid Build Coastguard Worker
18*800a58d9SAndroid Build Coastguard Workerfrom acloud.internal import constants
19*800a58d9SAndroid Build Coastguard Worker_NO_METRICS = "--no-metrics"
20*800a58d9SAndroid Build Coastguard Worker_NO_METRICS_COMMANDS = ["delete"]
21*800a58d9SAndroid Build Coastguard Worker
22*800a58d9SAndroid Build Coastguard Worker
23*800a58d9SAndroid Build Coastguard Workerlogger = logging.getLogger(__name__)
24*800a58d9SAndroid Build Coastguard Worker
25*800a58d9SAndroid Build Coastguard Worker
26*800a58d9SAndroid Build Coastguard Worker# pylint: disable=broad-except, import-error
27*800a58d9SAndroid Build Coastguard Workerdef LogUsage(argv):
28*800a58d9SAndroid Build Coastguard Worker    """Log acloud start event.
29*800a58d9SAndroid Build Coastguard Worker
30*800a58d9SAndroid Build Coastguard Worker    Log acloud start event and the usage, following are the data we log:
31*800a58d9SAndroid Build Coastguard Worker    - tool_name: All asuite tools are storing event in the same database. This
32*800a58d9SAndroid Build Coastguard Worker      property is provided to distinguish different tools.
33*800a58d9SAndroid Build Coastguard Worker    - command_line: Log all command arguments.
34*800a58d9SAndroid Build Coastguard Worker    - test_references: Should be a list, we record the acloud sub-command.
35*800a58d9SAndroid Build Coastguard Worker      e.g. create/delete/reconnect/..etc. We could use this property as filter
36*800a58d9SAndroid Build Coastguard Worker      criteria to speed up query time.
37*800a58d9SAndroid Build Coastguard Worker    - cwd: User's current working directory.
38*800a58d9SAndroid Build Coastguard Worker    - os: The platform that users are working at.
39*800a58d9SAndroid Build Coastguard Worker
40*800a58d9SAndroid Build Coastguard Worker    Args:
41*800a58d9SAndroid Build Coastguard Worker        argv: A list of system arguments.
42*800a58d9SAndroid Build Coastguard Worker
43*800a58d9SAndroid Build Coastguard Worker    Returns:
44*800a58d9SAndroid Build Coastguard Worker        True if start event is sent and need to pair with end event.
45*800a58d9SAndroid Build Coastguard Worker    """
46*800a58d9SAndroid Build Coastguard Worker    if _NO_METRICS in argv:
47*800a58d9SAndroid Build Coastguard Worker        return False
48*800a58d9SAndroid Build Coastguard Worker    if len(argv) > 0 and argv[0] in _NO_METRICS_COMMANDS:
49*800a58d9SAndroid Build Coastguard Worker        return False
50*800a58d9SAndroid Build Coastguard Worker
51*800a58d9SAndroid Build Coastguard Worker    try:
52*800a58d9SAndroid Build Coastguard Worker        from asuite.metrics import metrics_utils
53*800a58d9SAndroid Build Coastguard Worker        metrics_utils.print_data_collection_notice()
54*800a58d9SAndroid Build Coastguard Worker        metrics_utils.send_start_event(tool_name=constants.TOOL_NAME,
55*800a58d9SAndroid Build Coastguard Worker                                       command_line=' '.join(argv),
56*800a58d9SAndroid Build Coastguard Worker                                       test_references=[argv[0]])
57*800a58d9SAndroid Build Coastguard Worker        return True
58*800a58d9SAndroid Build Coastguard Worker    except Exception as e:
59*800a58d9SAndroid Build Coastguard Worker        logger.debug("Failed to send start event:%s", str(e))
60*800a58d9SAndroid Build Coastguard Worker
61*800a58d9SAndroid Build Coastguard Worker    return False
62*800a58d9SAndroid Build Coastguard Worker
63*800a58d9SAndroid Build Coastguard Worker
64*800a58d9SAndroid Build Coastguard Worker# pylint: disable=broad-except
65*800a58d9SAndroid Build Coastguard Workerdef LogExitEvent(exit_code, stacktrace="", logs=""):
66*800a58d9SAndroid Build Coastguard Worker    """Log acloud exit event.
67*800a58d9SAndroid Build Coastguard Worker
68*800a58d9SAndroid Build Coastguard Worker    A start event should followed by an exit event to calculate the consuming
69*800a58d9SAndroid Build Coastguard Worker    time. This function will be run at the end of acloud main process or
70*800a58d9SAndroid Build Coastguard Worker    at the init of the error object.
71*800a58d9SAndroid Build Coastguard Worker
72*800a58d9SAndroid Build Coastguard Worker    Args:
73*800a58d9SAndroid Build Coastguard Worker        exit_code: Integer, the exit code of acloud main process.
74*800a58d9SAndroid Build Coastguard Worker        stacktrace: A string of stacktrace.
75*800a58d9SAndroid Build Coastguard Worker        logs: A string of logs.
76*800a58d9SAndroid Build Coastguard Worker    """
77*800a58d9SAndroid Build Coastguard Worker    try:
78*800a58d9SAndroid Build Coastguard Worker        from asuite.metrics import metrics_utils
79*800a58d9SAndroid Build Coastguard Worker        metrics_utils.send_exit_event(exit_code, stacktrace=stacktrace,
80*800a58d9SAndroid Build Coastguard Worker                                      logs=logs)
81*800a58d9SAndroid Build Coastguard Worker    except Exception as e:
82*800a58d9SAndroid Build Coastguard Worker        logger.debug("Failed to send exit event:%s", str(e))
83