forked from googleapis/google-cloud-python
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_handlers.py
More file actions
125 lines (89 loc) · 3.49 KB
/
test_handlers.py
File metadata and controls
125 lines (89 loc) · 3.49 KB
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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#!/usr/bin/env python
# Copyright 2016 Google Inc. All Rights Reserved.
#
# 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 logging
import unittest2
class TestCloudLoggingHandler(unittest2.TestCase):
PROJECT = 'PROJECT'
def _getTargetClass(self):
from gcloud.logging.handlers import CloudLoggingHandler
return CloudLoggingHandler
def _makeOne(self, *args, **kw):
return self._getTargetClass()(*args, **kw)
def test_ctor(self):
client = _Client(self.PROJECT)
handler = self._makeOne(client)
self.assertEqual(handler.client, client)
def test_emit(self):
client = _Client(self.PROJECT)
handler = self._makeOne(client)
LOGNAME = 'loggername'
MESSAGE = 'hello world'
record = _Record(LOGNAME, logging.INFO, MESSAGE)
handler.emit(record)
self.assertEqual(client.logger(LOGNAME).log_struct_called_with,
({'message': MESSAGE}, logging.INFO))
class TestSetupLogging(unittest2.TestCase):
def _callFUT(self, handler, excludes=None):
from gcloud.logging.handlers import setup_logging
if excludes:
return setup_logging(handler, excluded_loggers=excludes)
else:
return setup_logging(handler)
def test_setup_logging(self):
handler = _Handler(logging.INFO)
self._callFUT(handler)
root_handlers = logging.getLogger().handlers
self.assertIn(handler, root_handlers)
def test_setup_logging_excludes(self):
INCLUDED_LOGGER_NAME = 'includeme'
EXCLUDED_LOGGER_NAME = 'excludeme'
handler = _Handler(logging.INFO)
self._callFUT(handler, (EXCLUDED_LOGGER_NAME,))
included_logger = logging.getLogger(INCLUDED_LOGGER_NAME)
self.assertTrue(included_logger.propagate)
excluded_logger = logging.getLogger(EXCLUDED_LOGGER_NAME)
self.assertNotIn(handler, excluded_logger.handlers)
self.assertFalse(excluded_logger.propagate)
def setUp(self):
self._handlers_cache = logging.getLogger().handlers[:]
def tearDown(self):
# cleanup handlers
logging.getLogger().handlers = self._handlers_cache[:]
class _Handler(object):
def __init__(self, level):
self.level = level
def acquire(self):
pass # pragma: NO COVER
def release(self):
pass # pragma: NO COVER
class _Logger(object):
def log_struct(self, message, severity=None):
self.log_struct_called_with = (message, severity)
class _Client(object):
def __init__(self, project):
self.project = project
self.logger_ = _Logger()
def logger(self, _): # pylint: disable=unused-argument
return self.logger_
class _Record(object):
def __init__(self, name, level, message):
self.name = name
self.levelname = level
self.message = message
self.exc_info = None
self.exc_text = None
self.stack_info = None
def getMessage(self):
return self.message