182 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C++
		
	
	
	
| #include <gtest/gtest.h>
 | |
| #include <stdio.h>
 | |
| #include "syncIO.h"
 | |
| #include "syncInt.h"
 | |
| #include "syncMessage.h"
 | |
| #include "syncUtil.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");
 | |
| }
 | |
| 
 | |
| int          gg = 0;
 | |
| SyncTimeout *createSyncTimeout() {
 | |
|   SyncTimeout *pMsg = syncTimeoutBuild2(SYNC_TIMEOUT_PING, 999, 333, &gg);
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncPing *createSyncPing() {
 | |
|   SRaftId srcId, destId;
 | |
|   srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   srcId.vgId = 100;
 | |
|   destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   destId.vgId = 100;
 | |
|   SyncPing *pMsg = syncPingBuild3(&srcId, &destId);
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncPingReply *createSyncPingReply() {
 | |
|   SRaftId srcId, destId;
 | |
|   srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   srcId.vgId = 100;
 | |
|   destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   destId.vgId = 100;
 | |
|   SyncPingReply *pMsg = syncPingReplyBuild3(&srcId, &destId);
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncClientRequest *createSyncClientRequest() {
 | |
|   SRpcMsg rpcMsg;
 | |
|   memset(&rpcMsg, 0, sizeof(rpcMsg));
 | |
|   rpcMsg.msgType = 12345;
 | |
|   rpcMsg.contLen = 20;
 | |
|   rpcMsg.pCont = rpcMallocCont(rpcMsg.contLen);
 | |
|   strcpy((char *)rpcMsg.pCont, "hello rpc");
 | |
|   SyncClientRequest *pMsg = syncClientRequestBuild2(&rpcMsg, 123, true);
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncRequestVote *createSyncRequestVote() {
 | |
|   SyncRequestVote *pMsg = syncRequestVoteBuild();
 | |
|   pMsg->srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   pMsg->srcId.vgId = 100;
 | |
|   pMsg->destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   pMsg->destId.vgId = 100;
 | |
|   pMsg->term = 11;
 | |
|   pMsg->lastLogIndex = 22;
 | |
|   pMsg->lastLogTerm = 33;
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncRequestVoteReply *createSyncRequestVoteReply() {
 | |
|   SyncRequestVoteReply *pMsg = syncRequestVoteReplyBuild();
 | |
|   pMsg->srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   pMsg->srcId.vgId = 100;
 | |
|   pMsg->destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   pMsg->destId.vgId = 100;
 | |
|   pMsg->term = 77;
 | |
|   pMsg->voteGranted = true;
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncAppendEntries *createSyncAppendEntries() {
 | |
|   SyncAppendEntries *pMsg = syncAppendEntriesBuild(20);
 | |
|   pMsg->srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   pMsg->srcId.vgId = 100;
 | |
|   pMsg->destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   pMsg->destId.vgId = 100;
 | |
|   pMsg->prevLogIndex = 11;
 | |
|   pMsg->prevLogTerm = 22;
 | |
|   pMsg->commitIndex = 33;
 | |
|   strcpy(pMsg->data, "hello world");
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| SyncAppendEntriesReply *createSyncAppendEntriesReply() {
 | |
|   SyncAppendEntriesReply *pMsg = syncAppendEntriesReplyBuild();
 | |
|   pMsg->srcId.addr = syncUtilAddr2U64("127.0.0.1", 1234);
 | |
|   pMsg->srcId.vgId = 100;
 | |
|   pMsg->destId.addr = syncUtilAddr2U64("127.0.0.1", 5678);
 | |
|   pMsg->destId.vgId = 100;
 | |
|   pMsg->success = true;
 | |
|   pMsg->matchIndex = 77;
 | |
|   return pMsg;
 | |
| }
 | |
| 
 | |
| void test1() {
 | |
|   SyncTimeout *pMsg = createSyncTimeout();
 | |
|   SRpcMsg      rpcMsg;
 | |
|   syncTimeout2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test1", &rpcMsg);
 | |
|   syncTimeoutDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test2() {
 | |
|   SyncPing *pMsg = createSyncPing();
 | |
|   SRpcMsg   rpcMsg;
 | |
|   syncPing2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test2", &rpcMsg);
 | |
|   syncPingDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test3() {
 | |
|   SyncPingReply *pMsg = createSyncPingReply();
 | |
|   SRpcMsg        rpcMsg;
 | |
|   syncPingReply2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test3", &rpcMsg);
 | |
|   syncPingReplyDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test4() {
 | |
|   SyncRequestVote *pMsg = createSyncRequestVote();
 | |
|   SRpcMsg          rpcMsg;
 | |
|   syncRequestVote2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test4", &rpcMsg);
 | |
|   syncRequestVoteDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test5() {
 | |
|   SyncRequestVoteReply *pMsg = createSyncRequestVoteReply();
 | |
|   SRpcMsg               rpcMsg;
 | |
|   syncRequestVoteReply2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test5", &rpcMsg);
 | |
|   syncRequestVoteReplyDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test6() {
 | |
|   SyncAppendEntries *pMsg = createSyncAppendEntries();
 | |
|   SRpcMsg            rpcMsg;
 | |
|   syncAppendEntries2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test6", &rpcMsg);
 | |
|   syncAppendEntriesDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test7() {
 | |
|   SyncAppendEntriesReply *pMsg = createSyncAppendEntriesReply();
 | |
|   SRpcMsg                 rpcMsg;
 | |
|   syncAppendEntriesReply2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test7", &rpcMsg);
 | |
|   syncAppendEntriesReplyDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| void test8() {
 | |
|   SyncClientRequest *pMsg = createSyncClientRequest();
 | |
|   SRpcMsg            rpcMsg;
 | |
|   syncClientRequest2RpcMsg(pMsg, &rpcMsg);
 | |
|   syncRpcMsgPrint2((char *)"test8", &rpcMsg);
 | |
|   syncClientRequestDestroy(pMsg);
 | |
| }
 | |
| 
 | |
| int main() {
 | |
|   // taosInitLog((char *)"syncTest.log", 100000, 10);
 | |
|   tsAsyncLog = 0;
 | |
|   sDebugFlag = 143 + 64;
 | |
|   logTest();
 | |
| 
 | |
|   test1();
 | |
|   test2();
 | |
|   test3();
 | |
|   test4();
 | |
|   test5();
 | |
|   test6();
 | |
|   test7();
 | |
|   test8();
 | |
| 
 | |
|   return 0;
 | |
| }
 |