1#!/usr/bin/env python3
2#
3# Copyright 2019 - The Android Open Source Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9#     http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16import logging
17
18from acts import tracelogger
19
20
21class TakoTraceLogger(tracelogger.TraceLogger):
22    def __init__(self, *args, **kwargs):
23        super().__init__(*args, **kwargs)
24        self.d = self.debug
25        self.e = self.error
26        self.i = self.info
27        self.t = self.step
28        self.w = self.warning
29
30    def _logger_level(self, level_name):
31        level = logging.getLevelName(level_name)
32        return lambda *args, **kwargs: self._logger.log(level, *args, **kwargs)
33
34    def step(self, msg, *args, **kwargs):
35        """Delegate a step call to the underlying logger."""
36        self._log_with(self._logger_level('STEP'), 1, msg, *args, **kwargs)
37
38    def device(self, msg, *args, **kwargs):
39        """Delegate a device call to the underlying logger."""
40        self._log_with(self._logger_level('DEVICE'), 1, msg, *args, **kwargs)
41
42    def suite(self, msg, *args, **kwargs):
43        """Delegate a device call to the underlying logger."""
44        self._log_with(self._logger_level('SUITE'), 1, msg, *args, **kwargs)
45
46    def case(self, msg, *args, **kwargs):
47        """Delegate a case call to the underlying logger."""
48        self._log_with(self._logger_level('CASE'), 1, msg, *args, **kwargs)
49
50    def flush_log(self):
51        """This function exists for compatibility with Tako's logserial module.
52
53        Note that flushing the log is handled automatically by python's logging
54        module.
55        """
56