• 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

33.33
/source/dnode/xnode/src/xnode.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
#include "libs/txnode/txnode.h"
17
#include "xndInt.h"
18

19
static SXnode xnodeInstance = {0};
20
SXnode       *xndInstance() { return &xnodeInstance; }
×
21

22
int32_t xndOpen(const SXnodeOpt *pOption, SXnode **pXnode) {
16✔
23
  *pXnode = &xnodeInstance;
16✔
24
  (*pXnode)->protocol = (int8_t)pOption->proto;
16✔
25
  (*pXnode)->dnodeId = pOption->dnodeId;
16✔
26
  (*pXnode)->clusterId = pOption->clusterId;
16✔
27
  (*pXnode)->ep = pOption->ep;
16✔
28

29
  // if (TSDB_XNODE_OPT_PROTO == (*pXnode)->protocol) {
30
  //   // if ((code = xnodeMgmtStartXnoded((*pXnode)->dnodeId)) != 0) {
31
  //   if ((code = xnodeMgmtStartXnoded(*pXnode)) != 0) {
32
  //     xndError("failed to start xnoded since %s", tstrerror(code));
33

34
  //     taosMemoryFree(*pXnode);
35
  //     TAOS_RETURN(code);
36
  //   }
37
  // } else {
38
  //   xndError("Unknown xnode proto: %hhd.", (*pXnode)->protocol);
39

40
  //   taosMemoryFree(*pXnode);
41
  //   TAOS_RETURN(code);
42
  // }
43

44
  xndInfo("xnode: opened & initialized by dnode");
16✔
45

46
  return TSDB_CODE_SUCCESS;
16✔
47
}
48

49
void xndClose(SXnode *pXnode) {
16✔
50
  xndInfo("xnode: dnode is closing xnoded");
16✔
51
  xnodeMgmtStopXnoded();
16✔
52
}
16✔
53

54
int32_t mndOpenXnd(const SXnodeOpt *pOption) {
×
55
  int32_t code = 0;
×
56
  SXnode *pXnode = xndInstance();
×
57
  pXnode->dnodeId = pOption->dnodeId;
×
58
  pXnode->clusterId = pOption->clusterId;
×
59
  pXnode->upLen = pOption->upLen;
×
60
  pXnode->ep = pOption->ep;
×
61
  memset(pXnode->userPass, 0, XNODE_USER_PASS_LEN);
×
62
  memcpy(pXnode->userPass, pOption->userPass, pOption->upLen);
×
63
  memset(pXnode->token, 0, sizeof(pXnode->token));
×
64
  memcpy(pXnode->token, pOption->token, TSDB_TOKEN_LEN);
×
65

66
  if ((code = xnodeMgmtStartXnoded(pXnode)) != 0) {
×
67
    xndError("failed to start xnoded since %s", tstrerror(code));
×
68

69
    TAOS_RETURN(code);
×
70
  }
71
  return code;
×
72
}
73

74
void mndCloseXnd() { xnodeMgmtStopXnoded(); }
×
75

76
void getXnodedPipeName(char *pipeName, int32_t size) {
×
77
#ifdef _WIN32
78
  snprintf(pipeName, size, "%s.%x", XNODED_MGMT_LISTEN_PIPE_NAME_PREFIX, MurmurHash3_32(tsDataDir, strlen(tsDataDir)));
79
#else
80
  int32_t len = strlen(tsDataDir);
×
81
  if (len > 0 && tsDataDir[len - 1] != '/') {
×
82
    snprintf(pipeName, size, "%s/%s", tsDataDir, XNODED_MGMT_LISTEN_PIPE_NAME_PREFIX);
×
83
  } else {
84
    snprintf(pipeName, size, "%s%s", tsDataDir, XNODED_MGMT_LISTEN_PIPE_NAME_PREFIX);
×
85
  }
86
#endif
87
  xndDebug("xnode get unix socket pipe path:%s", pipeName);
×
88
}
×
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