From 2fe4a49d8f062cdd0d778aac8e3e9b245b331f3f Mon Sep 17 00:00:00 2001 From: Maximilian Hils Date: Sat, 19 Jun 2021 14:35:39 +0200 Subject: [PATCH] logging: don't pick up later mutations --- mitmproxy/log.py | 4 +++- test/mitmproxy/test_log.py | 7 +++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/mitmproxy/log.py b/mitmproxy/log.py index 9d4af8b79..0713df964 100644 --- a/mitmproxy/log.py +++ b/mitmproxy/log.py @@ -6,7 +6,9 @@ from mitmproxy import hooks class LogEntry: def __init__(self, msg, level): - self.msg = msg + # it's important that we serialize to string here already so that we don't pick up changes + # happening after this log statement. + self.msg = str(msg) self.level = level def __eq__(self, other): diff --git a/test/mitmproxy/test_log.py b/test/mitmproxy/test_log.py index 349e3ac86..225087e80 100644 --- a/test/mitmproxy/test_log.py +++ b/test/mitmproxy/test_log.py @@ -9,3 +9,10 @@ def test_logentry(): assert e == e assert e != f assert e != 42 + + +def test_dont_pick_up_mutations(): + x = {"foo": "bar"} + e = log.LogEntry(x, "info") + x["foo"] = "baz" # this should not affect the log entry anymore. + assert repr(e) == "LogEntry({'foo': 'bar'}, info)"