-
Notifications
You must be signed in to change notification settings - Fork 0
/
mtestthread.cpp
71 lines (59 loc) · 2.27 KB
/
mtestthread.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#include "mtestthread.h"
#include "at_shared.h"
MTestThread::MTestThread(qintptr socketDescriptor) {
m_socketDescriptor = socketDescriptor;
m_netManager = new QLClientNetManager(0, this);
connect(m_netManager,SIGNAL(newBinaryMessageReceived(QByteArray)),this,SLOT(newBinMsgFromClient(QByteArray)));
connect(m_netManager,SIGNAL(socketDisconnected()),this,SLOT(socketDisconnected()));
connect(m_netManager,SIGNAL(binaryMessageSent(quint32)),this,SLOT(binaryMessageSent(quint32)));
m_err = 0;
m_count = 0;
m_packetN = 1000000;
}
MTestThread::~MTestThread() {
deleteLater();
quit();
wait();
}
void MTestThread::run() {
QTcpSocket * m_tcpSocket = new QTcpSocket();
qlDebug() << m_tcpSocket << m_socketDescriptor;
if (!m_tcpSocket->setSocketDescriptor(m_socketDescriptor)) {
qlDebug() << "ERROR! Can not make socket from descriptor!";
return;
}
m_netManager->setTCPSocket(m_tcpSocket);
exec();
}
void MTestThread::newBinMsgFromClient(QByteArray in) {
++m_count;
QString zz;
zz.append(in);
QByteArray zz1;
for ( int i=0; i<60; ++i ) { // 60000
zz1.append("0123456789012345678901234567890123456789012345678901234567890123456789012345678901234567890123456789\r\n");
}
if ( in.size()!=zz.size() ) {
++m_err;
qlDebug() << "Size incorrect!" << in.size() << zz.size() << m_err;
m_netManager->sendBinaryMessage(zz1, m_packetN++);
} else {
m_netManager->sendBinaryMessage(in, m_packetN++);
}
if ( in != zz1) {
++m_err;
qlDebug() << "Packet incorrect!" << qChecksum(in.constData(),in.size()) << qChecksum(zz1.constData(),zz1.size()) << m_err;
}
}
void MTestThread::socketDisconnected() {
disconnect(m_netManager,SIGNAL(newBinaryMessageReceived(QByteArray)),this,SLOT(newBinMsgFromClient(QByteArray)));
disconnect(m_netManager,SIGNAL(socketDisconnected()),this,SLOT(socketDisconnected()));
disconnect(m_netManager,SIGNAL(binaryMessageSent(quint32)),this,SLOT(binaryMessageSent(quint32)));
delete(m_netManager);
}
void MTestThread::checkStatistics(void) {
qlDebug() << "Total:" << m_count << "Errors:" << m_err;
}
void MTestThread::binaryMessageSent(quint32 packetN) {
qlDebug() << packetN << QDateTime::currentDateTime();
}