From be46b605b0a358c620f523d298d5c329f1bd4645 Mon Sep 17 00:00:00 2001 From: jan iversen Date: Mon, 21 Oct 2024 18:10:49 +0200 Subject: [PATCH] Wrong close, when transaction do not match. (#2401) --- pymodbus/transaction.py | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/pymodbus/transaction.py b/pymodbus/transaction.py index e951a79c7..1b2f9e612 100644 --- a/pymodbus/transaction.py +++ b/pymodbus/transaction.py @@ -186,7 +186,10 @@ def execute(self, no_response_expected: bool, request: ModbusPDU): # noqa: C901 ModbusTransactionState.to_string(self.client.state), ) retries = self.retries - request.transaction_id = self.getNextTID() + if isinstance(self.client.framer, FramerSocket): + request.transaction_id = self.getNextTID() + else: + request.transaction_id = 0 Log.debug("Running transaction {}", request.transaction_id) if _buffer := hexlify_packets( self.client.framer.databuffer @@ -241,7 +244,7 @@ def execute(self, no_response_expected: bool, request: ModbusPDU): # noqa: C901 self.addTransaction(pdu) if not (result := self.getTransaction(request.transaction_id)): if len(self.transactions): - result = self.getTransaction(tid=0) + result = self.getTransaction(0) else: last_exception = last_exception or ( "No Response received from the remote slave" @@ -250,7 +253,7 @@ def execute(self, no_response_expected: bool, request: ModbusPDU): # noqa: C901 result = ModbusIOException( last_exception, request.function_code ) - self.client.close() + self.client.close() if hasattr(self.client, "state"): Log.debug( "Changing transaction state from "