-
-
Notifications
You must be signed in to change notification settings - Fork 225
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ExceptionDictTransformer
incorrectly formatting strings
#638
Comments
This is an expected change. For example: >>> import json
>>> from typed_settings.types import SecretStr
>>>
>>> json.dumps({"a": repr("spam"), "b": repr(SecretStr("eggs"))})
'{"a": "\'spam\'", "b": "\'*******\'"}'
>>>
>>> json.dumps({"a": "spam", "b": SecretStr("eggs")})
'{"a": "spam", "b": "eggs"}' I’m sure we could find a way to get sth. like |
Okay, Pydantic is not affected – their |
Rich's "to_repr" implementation does the same thing and when printing So imho, this issue should be closed as wontfix/works-as-expected/... :) |
Thanks for your swift responses 🙌🏻 So if I understand that correctly, you suggest this is not an issue because the Renderer is taking care of representing the data correctly? In my above example code, the Given your logic this means that structlog ties the correct logging of log data to the specific Renderer implementation. Doesn't this break the concept of having isolated components which you plug together? |
The dict of locals which is part of the stacktrace is now a dict mapping names (as strings) to reprs (as strings). In the older versions, there was an exceptions for strings, so the mapping was not a "mapping of names to reprs" but a "mapping of names to reprs but also maybe strings". Now it works like this: The repr of a numer is, for example, What the renderers do with this mapping is up to them but the json renderer happens to render it as shown in the example above. |
Hmmm, that seems bad though? Firstly, it's a breaking change and secondly we'd have to modify all renderers and our users would have to modify all of their renderers? |
The >>> import structlog
>>> structlog.configure([structlog.processors.dict_tracebacks, structlog.processors.JSONRenderer(indent=2)])
>>> log = structlog.get_logger()
>>> a = 42
>>> b = object()
>>> c = "spam"
>>> try: 1 / 0
... except: log.exception("onoes")
...
{
"event": "onoes",
"exception": [
{
"exc_type": "ZeroDivisionError",
"exc_value": "division by zero",
"syntax_error": null,
"is_cause": false,
"frames": [
{
"filename": "<stdin>",
"lineno": 1,
"name": "<module>",
"locals": {
"structlog": "<module 'structlog' from '/Users/stefan/Projects/structlog/src/structlog/__init__.py'>",
"rich": "<module 'rich' from '/Users/stefan/Projects/structlog/.venv/lib/python3.12/site-packages/rich/__init__.py'>",
"a": "42",
"b": "<object object at 0x100d313d0>",
"c": "'spam'", # This is the change in question
"log": "<BoundLoggerLazyProxy(logger=None, wrapper_class=None, processors=None, context_class=None, initial_values={}, logger_factory_args=())>"
}
}
]
}
]
} And again, the aim of this change was to safe people using simple secret classes with a @wochinge Is this just a minor annoyance for you or does it really break some log processing in a way? |
Version
24.4.0
Code to reproduce
Problem
The local string variable
my_variable
is escaped as"'number'"
where it should be just `"number"Root Cause
This is caused by this line. Instead of
repr(object)
it should be justobject
for stringsThe text was updated successfully, but these errors were encountered: