99 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
| #include <gtest/gtest.h>
 | |
| #include <stdio.h>
 | |
| #include "syncEnv.h"
 | |
| #include "syncIO.h"
 | |
| #include "syncInt.h"
 | |
| #include "syncRaftLog.h"
 | |
| #include "syncRaftStore.h"
 | |
| #include "syncUtil.h"
 | |
| #include "wal.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");
 | |
| }
 | |
| 
 | |
| SSyncNode*     pSyncNode;
 | |
| SWal*          pWal;
 | |
| SSyncLogStore* pLogStore;
 | |
| const char*    pWalPath = "./syncLogStoreTest_wal";
 | |
| 
 | |
| void init() {
 | |
|   walInit();
 | |
|   taosRemoveDir(pWalPath);
 | |
| 
 | |
|   SWalCfg walCfg;
 | |
|   memset(&walCfg, 0, sizeof(SWalCfg));
 | |
|   walCfg.vgId = 1000;
 | |
|   walCfg.fsyncPeriod = 1000;
 | |
|   walCfg.retentionPeriod = 1000;
 | |
|   walCfg.rollPeriod = 1000;
 | |
|   walCfg.retentionSize = 1000;
 | |
|   walCfg.segSize = 1000;
 | |
|   walCfg.level = TAOS_WAL_FSYNC;
 | |
|   pWal = walOpen(pWalPath, &walCfg);
 | |
|   assert(pWal != NULL);
 | |
| 
 | |
|   pSyncNode = (SSyncNode*)taosMemoryMalloc(sizeof(SSyncNode));
 | |
|   memset(pSyncNode, 0, sizeof(SSyncNode));
 | |
|   pSyncNode->pWal = pWal;
 | |
| }
 | |
| 
 | |
| void cleanup() {
 | |
|   walClose(pWal);
 | |
|   walCleanUp();
 | |
|   taosMemoryFree(pSyncNode);
 | |
| }
 | |
| 
 | |
| void logStoreTest() {
 | |
|   pLogStore = logStoreCreate(pSyncNode);
 | |
|   assert(pLogStore);
 | |
|   assert(pLogStore->getLastIndex(pLogStore) == SYNC_INDEX_INVALID);
 | |
| 
 | |
|   logStoreLog2((char*)"logStoreTest", pLogStore);
 | |
| 
 | |
|   for (int i = 0; i < 5; ++i) {
 | |
|     int32_t         dataLen = 10;
 | |
|     SSyncRaftEntry* pEntry = syncEntryBuild(dataLen);
 | |
|     assert(pEntry != NULL);
 | |
|     pEntry->msgType = 1;
 | |
|     pEntry->originalRpcType = 2;
 | |
|     pEntry->seqNum = 3;
 | |
|     pEntry->isWeak = true;
 | |
|     pEntry->term = 100 + i;
 | |
|     pEntry->index = pLogStore->getLastIndex(pLogStore) + 1;
 | |
|     snprintf(pEntry->data, dataLen, "value%d", i);
 | |
| 
 | |
|     syncEntryLog2((char*)"==write entry== :", pEntry);
 | |
|     pLogStore->appendEntry(pLogStore, pEntry);
 | |
|     syncEntryDestory(pEntry);
 | |
| 
 | |
|     if (i == 0) {
 | |
|       assert(pLogStore->getLastIndex(pLogStore) == SYNC_INDEX_BEGIN);
 | |
|     }
 | |
|   }
 | |
|   logStoreLog2((char*)"after appendEntry", pLogStore);
 | |
| 
 | |
|   pLogStore->truncate(pLogStore, 3);
 | |
|   logStoreLog2((char*)"after truncate 3", pLogStore);
 | |
| 
 | |
|   logStoreDestory(pLogStore);
 | |
| }
 | |
| 
 | |
| int main(int argc, char** argv) {
 | |
|   tsAsyncLog = 0;
 | |
|   sDebugFlag = DEBUG_TRACE + DEBUG_SCREEN + DEBUG_FILE;
 | |
| 
 | |
|   init();
 | |
|   logStoreTest();
 | |
| 
 | |
|   taosMsleep(2000);
 | |
|   cleanup();
 | |
| 
 | |
|   return 0;
 | |
| }
 |