-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathLogger.py
108 lines (84 loc) · 3.61 KB
/
Logger.py
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
# -*- coding: utf-8 -*-
# Copyright 2017-2020 NTT Communications
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import datetime
import Common
from robot.libraries.BuiltIn import BuiltIn
from robot.libraries.BuiltIn import RobotNotRunningError
class Logger(object):
""" Provides advanced logging functions. Every [./Logger.html|Logger] instance has one
[./VChannel.html|VChannel] object and the is synchronized with the current active
[./VChannel.html|VChannel].
*Notes:* log file is not updated pararelly. Anytime a terminal is switched
to, it will update its log file.
"""
ROBOT_LIBRARY_SCOPE = 'TEST SUITE'
ROBOT_LIBRARY_VERSION = Common.version()
_vchannel = None
###
def __init__(self):
try:
self._vchannel = BuiltIn().get_library_instance('VChannel')
if self._vchannel is None:
raise Exception("Could not find an instance of VChannel. Need import VChannel first")
except RobotNotRunningError as e:
Common.err("WARN: RENAT is not running")
def switch(self,name):
""" Switches the current [./VChannel.html|VChannel] instance to ``name``.
``name`` is the name of the [./VChannel.html|VChannel] (usually is the
node name defined in the current active ``local.yaml``).
Example:
| Logger.`Switch` | vmx11 |
"""
self._vchannel.switch(name)
def log(self,msg,with_time=False,mark="***"):
""" Inserts a message ``msg`` to the current `VChannel` log file.
A default mark of ``***`` will be added at the beginning ant the end of
this message.
Example:
| Logger.`Log` | START TRAFFIC FROM HERE | ${TRUE} |
| Logger.`Log` | START TRAFFIC FROM HERE | ${False} | ===== |
"""
channel = self._vchannel.get_current_channel()
note = ""
if with_time :
note = datetime.datetime.now().strftime("%I:%M:%S%p on %B %d, %Y: ") + msg
else :
note = msg
note = mark + ' ' + note + ' ' + mark
channel['logger'].write(Common.newline + Common.newline + note + Common.newline + Common.newline)
channel['logger'].flush()
def log_all(self,msg,with_time=False,mark="***"):
""" Inserts a message ``msg`` to current *all* [./VChannel.html|VChannel] log files.
A default ``mark`` of ``***`` and newline will be added at the beggining and the end of this
message.
Example:
| Logger.`Log All` | START TRAFFIC FROM HERE | ${TRUE} |
| Logger.`Log All` | START TRAFFIC FROM HERE | ${TRUE} | ===== |
The log file will look likes this:
| user@vmx12>
|
| ***** 06:01PM on August 13, 2017: START TRAFFIC FROM HERE *****
|
| === 06:01PM on August 13, 2017: START TRAFFIC FROM HERE ===
|
| configure
"""
old_name = self._vchannel.current_name
channels = self._vchannel.get_channels()
for name in channels:
self.switch(name)
self.log(msg,with_time,mark)
if old_name: self.switch(old_name)
BuiltIn().log("Wrote msg to `%d` clients" % (len(channels)))