forked from Yelp/detect-secrets
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmocks.py
90 lines (67 loc) · 2.56 KB
/
mocks.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
"""This is a collection of utility functions for easier, DRY testing."""
import io
from collections import defaultdict
from contextlib import contextmanager
from types import ModuleType
from typing import Any
from typing import Dict
from typing import Generator
from typing import IO
from typing import Iterator
from typing import Optional
from unittest import mock
def mock_file_object(string: str) -> IO:
return io.StringIO(string)
class PrinterShim:
def __init__(self) -> None:
self.clear()
def add(self, message: str, *args: Any, **kwargs: Any) -> None:
self.message += str(message) + '\n'
def clear(self) -> None:
self.message = ''
@contextmanager
def mock_printer(
module: ModuleType,
shim: Optional[PrinterShim] = None,
) -> Generator[PrinterShim, None, None]:
if not shim:
shim = PrinterShim()
with mock.patch.object(module, 'print', shim.add):
yield shim
class MockLogWrapper:
"""This is used to check what is being logged."""
def __init__(self) -> None:
self.messages: Dict[str, str] = defaultdict(str)
def error(self, message: str, *args: Any) -> None:
self.messages['error'] += (str(message) + '\n') % args
@property
def error_messages(self) -> str: # pragma: no cover
return self.messages['error']
def warning(self, message: str, *args: Any) -> None:
self.messages['warning'] += (str(message) + '\n') % args
@property
def warning_messages(self) -> str: # pragma: no cover
return self.messages['warning']
def info(self, message: str, *args: Any) -> None:
self.messages['info'] += (str(message) + '\n') % args
@property
def info_messages(self) -> str: # pragma: no cover
return self.messages['info']
def debug(self, message: str, *args: Any) -> None:
self.messages['debug'] += (str(message) + '\n') % args
@property
def debug_messages(self) -> str: # pragma: no cover
return self.messages['debug']
@contextmanager
def disable_gibberish_filter() -> Iterator[None]:
"""
Unfortunately, we can't just use `Settings.disable_filters`, since `parse_args` is
the function that *enables* this filter. Therefore, for test cases that test through
the `main` function flow, we can't disable the filter before the function call.
However, since this only happens in test environments, we can just mock it out.
"""
with mock.patch(
'detect_secrets.filters.gibberish.is_feature_enabled',
return_value=False,
):
yield