Selenium-Automation-Template/src/core/utils/Logger.py

57 lines
1.9 KiB
Python
Raw Normal View History

2020-04-10 22:41:42 +00:00
# Python imports
import os, logging
# Application imports
class Logger:
def __init__(self):
pass
def get_logger(self, loggerName = "NO_LOGGER_NAME_PASSED", createFile = True):
"""
Create a new logging object and return it.
:note:
2020-04-11 20:00:22 +00:00
NOSET # Don't know the actual log level of this... (defaulting or literally none?)
2020-04-10 22:41:42 +00:00
Log Levels (From least to most)
Type Value
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
:param loggerName: Sets the name of the logger object. (Used in log lines)
:param createFile: Whether we create a log file or just pump to terminal
2020-04-11 20:00:22 +00:00
:return: the logging object we created
2020-04-10 22:41:42 +00:00
"""
globalLogLvl = logging.DEBUG # Keep this at highest so that handlers can filter to their desired levels
chLogLevel = logging.CRITICAL # Prety musch the only one we change ever
fhLogLevel = logging.DEBUG
log = logging.getLogger(loggerName)
2020-05-22 06:32:34 +00:00
log.setLevel(globalLogLvl)
2020-04-10 22:41:42 +00:00
# Set our log output styles
fFormatter = logging.Formatter('[%(asctime)s] %(pathname)s:%(lineno)d %(levelname)s - %(message)s', '%m-%d %H:%M:%S')
cFormatter = logging.Formatter('%(pathname)s:%(lineno)d] %(levelname)s - %(message)s')
ch = logging.StreamHandler()
ch.setLevel(level=chLogLevel)
ch.setFormatter(cFormatter)
log.addHandler(ch)
if createFile:
folder = "core/logs"
file = folder + "/twitter-bot.log"
2020-04-11 20:36:41 +00:00
if not os.path.exists(folder):
os.mkdir(folder)
2020-04-10 22:41:42 +00:00
fh = logging.FileHandler(file)
fh.setLevel(level=fhLogLevel)
fh.setFormatter(fFormatter)
log.addHandler(fh)
return log