test: fix constructor of msg_tx

In python, if the default value is a mutable object (here: a class)
its shared over all instances, so that one instance being changed
would affect others to be changed as well.
This was likely the source of various intermittent bugs in the
functional tests.

Github-Pull: #30552
Rebased-From: ec5e294e4b
This commit is contained in:
Martin Zumsande 2024-07-30 17:49:04 -04:00 committed by fanquake
parent 0cbdc6b380
commit 500bba0561
No known key found for this signature in database
GPG key ID: 2EEB9F5CC09526C1

View file

@ -1293,8 +1293,11 @@ class msg_tx:
__slots__ = ("tx",) __slots__ = ("tx",)
msgtype = b"tx" msgtype = b"tx"
def __init__(self, tx=CTransaction()): def __init__(self, tx=None):
self.tx = tx if tx is None:
self.tx = CTransaction()
else:
self.tx = tx
def deserialize(self, f): def deserialize(self, f):
self.tx.deserialize(f) self.tx.deserialize(f)