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