diff options
author | Karsten Heimrich <karsten.heimrich@theqtcompany.com> | 2016-03-17 14:27:05 +0100 |
---|---|---|
committer | Karsten Heimrich <karsten.heimrich@theqtcompany.com> | 2016-03-17 16:22:19 +0000 |
commit | 8a5a904441a9a60ab711721a0a6acd8089e74a79 (patch) | |
tree | 06679bd59e75a787ff7485fc3e7c6ae6e984ac1e /tests | |
parent | 71e78c687c5351298fa099121da8a85f07c518b4 (diff) |
Have a means to register a custom data size calculator.
Adds possibility to:
* Override our data size calculation for a function code.
* Implement data size calculation for a custom function code.
Change-Id: I5611990a7bc10c2e90aef0f52aa1eb7ddf440717
Reviewed-by: Alex Blasche <alexander.blasche@theqtcompany.com>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/auto/qmodbuspdu/tst_qmodbuspdu.cpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/tests/auto/qmodbuspdu/tst_qmodbuspdu.cpp b/tests/auto/qmodbuspdu/tst_qmodbuspdu.cpp index 76bfea3..592a14e 100644 --- a/tests/auto/qmodbuspdu/tst_qmodbuspdu.cpp +++ b/tests/auto/qmodbuspdu/tst_qmodbuspdu.cpp @@ -803,6 +803,47 @@ private slots: quint8(0xff)); // dummy additional data QCOMPARE(QModbusResponse::calculateDataSize(rdi), 22); } + + void testCustomCalculator() + { + // request + QModbusRequest request(QModbusRequest::WriteSingleCoil); + request.encodeData(quint8(0x00), quint8(0xac), quint8(0xff), quint8(0x00)); + QCOMPARE(QModbusRequest::calculateDataSize(request), 4); + + QModbusRequest::registerDataSizeCalculator(QModbusRequest::WriteSingleCoil, + [](const QModbusRequest &)->int { + return 15; + }); + QCOMPARE(QModbusRequest::calculateDataSize(request), 15); + + QModbusRequest::registerDataSizeCalculator(QModbusRequest::WriteSingleCoil, nullptr); + QCOMPARE(QModbusRequest::calculateDataSize(request), 4); + + // response + QModbusResponse response(QModbusRequest::WriteSingleCoil); + response.encodeData(quint8(0x00), quint8(0xac), quint8(0xff), quint8(0x00)); + QCOMPARE(QModbusResponse::calculateDataSize(request), 4); + + QModbusResponse::registerDataSizeCalculator(QModbusResponse::WriteSingleCoil, + [](const QModbusResponse &)->int { + return 15; + }); + QCOMPARE(QModbusResponse::calculateDataSize(response), 15); + + QModbusResponse::registerDataSizeCalculator(QModbusResponse::WriteSingleCoil, nullptr); + QCOMPARE(QModbusResponse::calculateDataSize(response), 4); + + // custom + QModbusPdu::FunctionCode custom = QModbusPdu::FunctionCode(0x30); + request.setFunctionCode(custom); + QCOMPARE(QModbusRequest::calculateDataSize(request), -1); + + QModbusRequest::registerDataSizeCalculator(custom, [](const QModbusRequest &)->int { + return 27; + }); + QCOMPARE(QModbusRequest::calculateDataSize(request), 27); + } }; QTEST_MAIN(tst_QModbusPdu) |