• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

taosdata / TDengine / #4986

15 Mar 2026 08:32AM UTC coverage: 37.305% (-31.3%) from 68.601%
#4986

push

travis-ci

tomchon
test: keep docs and unit test

125478 of 336361 relevant lines covered (37.3%)

1134847.06 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

0.0
/tools/shell/src/shellNettest.c
1
/*
2
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
3
 *
4
 * This program is free software: you can use, redistribute, and/or modify
5
 * it under the terms of the GNU Affero General Public License, version 3
6
 * or later ("AGPL"), as published by the Free Software Foundation.
7
 *
8
 * This program is distributed in the hope that it will be useful, but WITHOUT
9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10
 * FITNESS FOR A PARTICULAR PURPOSE.
11
 *
12
 * You should have received a copy of the GNU Affero General Public License
13
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
14
 */
15

16
#define _GNU_SOURCE
17
#include "shellInt.h"
18

19
static void shellWorkAsClient() {
×
20
  SShellArgs *pArgs = &shell.args;
×
21
  SRpcInit    rpcInit = {0};
×
22
  SEpSet      epSet = {.inUse = 0, .numOfEps = 1};
×
23
  SRpcMsg     rpcRsp = {0};
×
24
  void       *clientRpc = NULL;
×
25
  char        pass[TSDB_PASSWORD_LEN + 1] = {0};
×
26

27
  taosEncryptPass_c((uint8_t *)("_pwd"), strlen("_pwd"), pass);
28
  rpcInit.label = "CHK";
×
29
  rpcInit.numOfThreads = 1;
×
30
  rpcInit.sessions = 16;
×
31
  rpcInit.connType = TAOS_CONN_CLIENT;
×
32
  rpcInit.idleTime = 3000;
×
33
  rpcInit.user = "_dnd";
×
34
  rpcInit.timeToGetConn = 500000;
×
35

36
  memcpy(rpcInit.caPath, tsTLSCaPath, strlen(tsTLSCaPath));
×
37
  memcpy(rpcInit.certPath, tsTLSSvrCertPath, strlen(tsTLSSvrCertPath));
×
38
  memcpy(rpcInit.keyPath, tsTLSSvrKeyPath, strlen(tsTLSSvrKeyPath));
×
39
  memcpy(rpcInit.cliCertPath, tsTLSCliCertPath, strlen(tsTLSCliCertPath));
×
40
  memcpy(rpcInit.cliKeyPath, tsTLSCliKeyPath, strlen(tsTLSCliKeyPath));
×
41

42
  taosVersionStrToInt(td_version, &rpcInit.compatibilityVer);
×
43
  clientRpc = rpcOpen(&rpcInit);
×
44
  if (clientRpc == NULL) {
×
45
    printf("failed to init net test client since %s\r\n", terrstr());
×
46
    goto _OVER;
×
47
  }
48

49
  if (pArgs->port == 0) {
×
50
    pArgs->port = 6030;
×
51
  }
52
  if (pArgs->host == NULL) {
×
53
    pArgs->host = "localhost";
×
54
  }
55
  char fqdn[TSDB_FQDN_LEN] = {0};
×
56
  tstrncpy(fqdn, pArgs->host, TSDB_FQDN_LEN);
×
57
  strtok(fqdn, ":");
×
58

59
  printf("network test client is initialized, the server is %s:%u\r\n", fqdn, pArgs->port);
×
60

61
  tstrncpy(epSet.eps[0].fqdn, fqdn, TSDB_FQDN_LEN);
×
62
  epSet.eps[0].port = (uint16_t)pArgs->port;
×
63

64
  int32_t  totalSucc = 0;
×
65
  uint64_t startTime = taosGetTimestampUs();
×
66

67
  for (int32_t i = 0; i < pArgs->pktNum; ++i) {
×
68
    SRpcMsg rpcMsg = {.info.ahandle = (void *)0x9525, .info.notFreeAhandle = 1, .msgType = TDMT_DND_NET_TEST};
×
69
    rpcMsg.pCont = rpcMallocCont(pArgs->pktLen);
×
70
    rpcMsg.contLen = pArgs->pktLen;
×
71

72
    printf("request is sent, size:%d\r\n", rpcMsg.contLen);
×
73
    rpcSendRecv(clientRpc, &epSet, &rpcMsg, &rpcRsp);
×
74
    if (rpcRsp.code == 0 && rpcRsp.contLen == rpcMsg.contLen) {
×
75
      printf("response is received, size:%d\r\n", rpcMsg.contLen);
×
76
      if (rpcRsp.code == 0) totalSucc++;
×
77
    } else {
78
      printf("response not received since %s\r\n", tstrerror(rpcRsp.code));
×
79
    }
80

81
    rpcFreeCont(rpcRsp.pCont);
×
82
    rpcRsp.pCont = NULL;
×
83
  }
84

85
  uint64_t endTime = taosGetTimestampUs();
×
86
  uint64_t elT = endTime - startTime;
×
87

88
  printf("\r\ntotal succ:%5d/%d\tcost:%8.2lf ms\tspeed:%8.2lf MB/s\r\n", totalSucc, pArgs->pktNum, elT / 1000.0,
×
89
         pArgs->pktLen / (elT / 1000000.0) / 1024.0 / 1024.0 * totalSucc);
×
90

91
_OVER:
×
92
  if (clientRpc != NULL) {
×
93
    rpcClose(clientRpc);
×
94
  }
95
  if (rpcRsp.pCont != NULL) {
×
96
    rpcFreeCont(rpcRsp.pCont);
×
97
  }
98
}
×
99

100
static void shellProcessMsg(void *p, SRpcMsg *pRpc, SEpSet *pEpSet) {
×
101
  printf("request is received, size:%d\r\n", pRpc->contLen);
×
102
  fflush(stdout);
×
103
  SRpcMsg rsp = {.info = pRpc->info, .code = 0};
×
104
  rsp.pCont = rpcMallocCont(pRpc->contLen);
×
105
  if (rsp.pCont == NULL) {
×
106
    rsp.code = TSDB_CODE_OUT_OF_MEMORY;
×
107
  } else {
108
    rsp.contLen = pRpc->contLen;
×
109
  }
110
  rpcSendResponse(&rsp);
×
111
}
×
112

113
void shellNettestHandler(int32_t signum, void *sigInfo, void *context) { shellExit(); }
×
114

115
static void shellWorkAsServer() {
×
116
  SShellArgs *pArgs = &shell.args;
×
117

118
  if (pArgs->port == 0) {
×
119
    pArgs->port = 6030;
×
120
  }
121
  if (pArgs->host == NULL) {
×
122
    pArgs->host = "127.0.0.1";
×
123
  }
124

125
  SRpcInit rpcInit = {0};
×
126
  memcpy(rpcInit.localFqdn, pArgs->host, strlen(pArgs->host));
×
127
  rpcInit.localPort = pArgs->port;
×
128
  rpcInit.label = "CHK";
×
129
  rpcInit.numOfThreads = 2;
×
130
  rpcInit.cfp = (RpcCfp)shellProcessMsg;
×
131
  rpcInit.sessions = 10;
×
132
  rpcInit.connType = TAOS_CONN_SERVER;
×
133
  rpcInit.idleTime = 3000;
×
134

135
  taosVersionStrToInt(td_version, &rpcInit.compatibilityVer);
×
136

137
  void *serverRpc = rpcOpen(&rpcInit);
×
138
  if (serverRpc == NULL) {
×
139
    printf("failed to init net test server since %s\r\n", terrstr());
×
140
  } else {
141
    printf("network test server is initialized, %s:%u\r\n", pArgs->host, pArgs->port);
×
142
    taosSetSignal(SIGTERM, shellNettestHandler);
×
143
    while (1) taosMsleep(10);
×
144
  }
145
}
×
146

147
void shellTestNetWork() {
×
148
  (void)osDefaultInit();
×
149
  (void)rpcInit();
×
150

151
  if (strcmp(shell.args.netrole, "client") == 0) {
×
152
    shellWorkAsClient();
×
153
  }
154

155
  if (strcmp(shell.args.netrole, "server") == 0) {
×
156
    shellWorkAsServer();
×
157
  }
158
}
×
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc