syncIndexMgrTest.cpp 3.8 KB
Newer Older
M
Minghao Li 已提交
1 2
#include "syncIndexMgr.h"
//#include <gtest/gtest.h>
M
Minghao Li 已提交
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
#include <stdio.h>
#include "syncEnv.h"
#include "syncIO.h"
#include "syncInt.h"
#include "syncRaftStore.h"
#include "syncUtil.h"
#include "syncVoteMgr.h"

void logTest() {
  sTrace("--- sync log test: trace");
  sDebug("--- sync log test: debug");
  sInfo("--- sync log test: info");
  sWarn("--- sync log test: warn");
  sError("--- sync log test: error");
  sFatal("--- sync log test: fatal");
}

uint16_t ports[] = {7010, 7110, 7210, 7310, 7410};
int32_t  replicaNum = 3;
int32_t  myIndex = 0;

SRaftId    ids[TSDB_MAX_REPLICA];
SSyncInfo  syncInfo;
SSyncFSM*  pFsm;
SSyncNode* pSyncNode;

SSyncNode* syncNodeInit() {
  syncInfo.vgId = 1234;
  syncInfo.rpcClient = gSyncIO->clientRpc;
  syncInfo.FpSendMsg = syncIOSendMsg;
  syncInfo.queue = gSyncIO->pMsgQ;
  syncInfo.FpEqMsg = syncIOEqMsg;
  syncInfo.pFsm = pFsm;
M
Minghao Li 已提交
36
  snprintf(syncInfo.path, sizeof(syncInfo.path), "%s", "./");
M
Minghao Li 已提交
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

  SSyncCfg* pCfg = &syncInfo.syncCfg;
  pCfg->myIndex = myIndex;
  pCfg->replicaNum = replicaNum;

  for (int i = 0; i < replicaNum; ++i) {
    pCfg->nodeInfo[i].nodePort = ports[i];
    snprintf(pCfg->nodeInfo[i].nodeFqdn, sizeof(pCfg->nodeInfo[i].nodeFqdn), "%s", "127.0.0.1");
    // taosGetFqdn(pCfg->nodeInfo[0].nodeFqdn);
  }

  pSyncNode = syncNodeOpen(&syncInfo);
  assert(pSyncNode != NULL);

  gSyncIO->FpOnSyncPing = pSyncNode->FpOnPing;
  gSyncIO->FpOnSyncPingReply = pSyncNode->FpOnPingReply;
  gSyncIO->FpOnSyncRequestVote = pSyncNode->FpOnRequestVote;
  gSyncIO->FpOnSyncRequestVoteReply = pSyncNode->FpOnRequestVoteReply;
  gSyncIO->FpOnSyncAppendEntries = pSyncNode->FpOnAppendEntries;
  gSyncIO->FpOnSyncAppendEntriesReply = pSyncNode->FpOnAppendEntriesReply;
  gSyncIO->FpOnSyncPing = pSyncNode->FpOnPing;
  gSyncIO->FpOnSyncPingReply = pSyncNode->FpOnPingReply;
  gSyncIO->pSyncNode = pSyncNode;

  return pSyncNode;
}

SSyncNode* syncInitTest() { return syncNodeInit(); }

void initRaftId(SSyncNode* pSyncNode) {
  for (int i = 0; i < replicaNum; ++i) {
    ids[i] = pSyncNode->replicasId[i];
    char* s = syncUtilRaftId2Str(&ids[i]);
    printf("raftId[%d] : %s\n", i, s);
wafwerar's avatar
wafwerar 已提交
71
    taosMemoryFree(s);
M
Minghao Li 已提交
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
  }
}

int main(int argc, char** argv) {
  // taosInitLog((char *)"syncTest.log", 100000, 10);
  tsAsyncLog = 0;
  sDebugFlag = 143 + 64;

  myIndex = 0;
  if (argc >= 2) {
    myIndex = atoi(argv[1]);
  }

  int32_t ret = syncIOStart((char*)"127.0.0.1", ports[myIndex]);
  assert(ret == 0);

  ret = syncEnvStart();
  assert(ret == 0);

  SSyncNode* pSyncNode = syncInitTest();
  assert(pSyncNode != NULL);

  char* serialized = syncNode2Str(pSyncNode);
  printf("%s\n", serialized);
wafwerar's avatar
wafwerar 已提交
96
  taosMemoryFree(serialized);
M
Minghao Li 已提交
97 98 99

  initRaftId(pSyncNode);

M
Minghao Li 已提交
100 101
  SSyncIndexMgr* pSyncIndexMgr = syncIndexMgrCreate(pSyncNode);
  assert(pSyncIndexMgr != NULL);
M
Minghao Li 已提交
102 103 104

  printf("---------------------------------------\n");
  {
M
Minghao Li 已提交
105
    char* serialized = syncIndexMgr2Str(pSyncIndexMgr);
M
Minghao Li 已提交
106 107
    assert(serialized != NULL);
    printf("%s\n", serialized);
wafwerar's avatar
wafwerar 已提交
108
    taosMemoryFree(serialized);
M
Minghao Li 已提交
109 110
  }

M
Minghao Li 已提交
111 112 113 114
  syncIndexMgrSetIndex(pSyncIndexMgr, &ids[0], 100);
  syncIndexMgrSetIndex(pSyncIndexMgr, &ids[1], 200);
  syncIndexMgrSetIndex(pSyncIndexMgr, &ids[2], 300);

M
Minghao Li 已提交
115 116
  printf("---------------------------------------\n");
  {
M
Minghao Li 已提交
117
    char* serialized = syncIndexMgr2Str(pSyncIndexMgr);
M
Minghao Li 已提交
118 119
    assert(serialized != NULL);
    printf("%s\n", serialized);
wafwerar's avatar
wafwerar 已提交
120
    taosMemoryFree(serialized);
M
Minghao Li 已提交
121 122
  }

M
Minghao Li 已提交
123 124 125 126
  printf("---------------------------------------\n");
  for (int i = 0; i < pSyncIndexMgr->replicaNum; ++i) {
    SyncIndex idx = syncIndexMgrGetIndex(pSyncIndexMgr, &ids[i]);
    printf("index %d : %lu \n", i, idx);
M
Minghao Li 已提交
127 128
  }

M
Minghao Li 已提交
129
  syncIndexMgrClear(pSyncIndexMgr);
M
Minghao Li 已提交
130 131
  printf("---------------------------------------\n");
  {
M
Minghao Li 已提交
132
    char* serialized = syncIndexMgr2Str(pSyncIndexMgr);
M
Minghao Li 已提交
133 134
    assert(serialized != NULL);
    printf("%s\n", serialized);
wafwerar's avatar
wafwerar 已提交
135
    taosMemoryFree(serialized);
M
Minghao Li 已提交
136 137
  }

M
Minghao Li 已提交
138
  syncIndexMgrDestroy(pSyncIndexMgr);
M
Minghao Li 已提交
139 140
  return 0;
}