73 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
| #include <gtest/gtest.h>
 | |
| #include <stdio.h>
 | |
| #include "syncIO.h"
 | |
| #include "syncInt.h"
 | |
| #include "syncRaftStore.h"
 | |
| 
 | |
| void print(SHashObj *pNextIndex) {
 | |
|   printf("----------------\n");
 | |
|   uint64_t *p = (uint64_t *)taosHashIterate(pNextIndex, NULL);
 | |
|   while (p) {
 | |
|     size_t len;
 | |
|     void  *key = taosHashGetKey(p, &len);
 | |
| 
 | |
|     SRaftId *pRaftId = (SRaftId *)key;
 | |
| 
 | |
|     printf("key:<" PRIu64 ", %d>, value:%" PRIu64 " \n", pRaftId->addr, pRaftId->vgId, *p);
 | |
|     p = (uint64_t *)taosHashIterate(pNextIndex, p);
 | |
|   }
 | |
| }
 | |
| 
 | |
| 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 main() {
 | |
|   // taosInitLog((char *)"syncTest.log", 100000, 10);
 | |
|   tsAsyncLog = 0;
 | |
|   sDebugFlag = 143 + 64;
 | |
| 
 | |
|   logTest();
 | |
| 
 | |
|   SRaftId me;
 | |
|   SRaftId peer1;
 | |
|   SRaftId peer2;
 | |
| 
 | |
|   me.addr = 0;
 | |
|   me.vgId = 99;
 | |
|   peer1.addr = 1;
 | |
|   peer1.vgId = 99;
 | |
|   peer2.addr = 2;
 | |
|   peer2.vgId = 99;
 | |
| 
 | |
|   uint64_t  index;
 | |
|   SHashObj *pNextIndex =
 | |
|       taosHashInit(sizeof(SRaftId), taosGetDefaultHashFunction(TSDB_DATA_TYPE_BINARY), true, HASH_NO_LOCK);
 | |
| 
 | |
|   index = 1000;
 | |
|   taosHashPut(pNextIndex, &me, sizeof(me), &index, sizeof(index));
 | |
|   index = 1001;
 | |
|   taosHashPut(pNextIndex, &peer1, sizeof(peer1), &index, sizeof(index));
 | |
|   index = 1002;
 | |
|   taosHashPut(pNextIndex, &peer2, sizeof(peer2), &index, sizeof(index));
 | |
| 
 | |
|   print(pNextIndex);
 | |
| 
 | |
|   SRaftId find;
 | |
|   find = peer1;
 | |
|   uint64_t *p;
 | |
|   p = (uint64_t *)taosHashGet(pNextIndex, &find, sizeof(find));
 | |
|   (*p) += 900;
 | |
| 
 | |
|   print(pNextIndex);
 | |
| 
 | |
|   taosHashCleanup(pNextIndex);
 | |
| 
 | |
|   return 0;
 | |
| }
 |