#include #include "syncEnv.h" #include "syncIO.h" #include "syncInt.h" #include "syncRaftLog.h" #include "syncRaftStore.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"); } SSyncRaftEntry* createEntry(int i) { int32_t dataLen = 20; SSyncRaftEntry* pEntry = syncEntryBuild(dataLen); assert(pEntry != NULL); pEntry->msgType = 88; pEntry->originalRpcType = 99; pEntry->seqNum = 3; pEntry->isWeak = true; pEntry->term = 100 + i; pEntry->index = i; snprintf(pEntry->data, dataLen, "value%d", i); return pEntry; } SSyncNode* createFakeNode() { SSyncNode* pSyncNode = (SSyncNode*)taosMemoryMalloc(sizeof(SSyncNode)); ASSERT(pSyncNode != NULL); memset(pSyncNode, 0, sizeof(SSyncNode)); return pSyncNode; } SRaftEntryCache* createCache(int maxCount) { SSyncNode* pSyncNode = createFakeNode(); ASSERT(pSyncNode != NULL); SRaftEntryCache* pCache = raftCacheCreate(pSyncNode, maxCount); ASSERT(pCache != NULL); return pCache; } void test1() { int32_t code = 0; SRaftEntryCache* pCache = createCache(5); for (int i = 0; i < 5; ++i) { SSyncRaftEntry* pEntry = createEntry(i); code = raftCachePutEntry(pCache, pEntry); ASSERT(code == 1); syncEntryDestory(pEntry); } raftCacheLog2((char*)"==test1 write 5 entries==", pCache); SyncIndex index; index = 1; code = raftCacheDelEntry(pCache, index); ASSERT(code == 0); index = 3; code = raftCacheDelEntry(pCache, index); ASSERT(code == 0); raftCacheLog2((char*)"==test1 delete 1,3==", pCache); code = raftCacheClear(pCache); ASSERT(code == 0); raftCacheLog2((char*)"==clear all==", pCache); } void test2() { int32_t code = 0; SRaftEntryCache* pCache = createCache(5); for (int i = 0; i < 5; ++i) { SSyncRaftEntry* pEntry = createEntry(i); code = raftCachePutEntry(pCache, pEntry); ASSERT(code == 1); syncEntryDestory(pEntry); } raftCacheLog2((char*)"==test2 write 5 entries==", pCache); SyncIndex index; index = 1; SSyncRaftEntry* pEntry; code = raftCacheGetEntry(pCache, index, &pEntry); ASSERT(code == 0); syncEntryDestory(pEntry); syncEntryLog2((char*)"==test2 get entry 1==", pEntry); index = 2; code = raftCacheGetEntryP(pCache, index, &pEntry); ASSERT(code == 0); syncEntryLog2((char*)"==test2 get entry pointer 2==", pEntry); // not found index = 8; code = raftCacheGetEntry(pCache, index, &pEntry); ASSERT(code == -1 && terrno == TSDB_CODE_WAL_LOG_NOT_EXIST); sTrace("==test2 get entry 8 not found=="); // not found index = 9; code = raftCacheGetEntryP(pCache, index, &pEntry); ASSERT(code == -1 && terrno == TSDB_CODE_WAL_LOG_NOT_EXIST); sTrace("==test2 get entry pointer 9 not found=="); } void test3() { int32_t code = 0; SRaftEntryCache* pCache = createCache(5); for (int i = 0; i < 5; ++i) { SSyncRaftEntry* pEntry = createEntry(i); code = raftCachePutEntry(pCache, pEntry); ASSERT(code == 1); syncEntryDestory(pEntry); } for (int i = 6; i < 10; ++i) { SSyncRaftEntry* pEntry = createEntry(i); code = raftCachePutEntry(pCache, pEntry); ASSERT(code == 0); syncEntryDestory(pEntry); } raftCacheLog2((char*)"==test3 write 10 entries, max count is 5==", pCache); } void test4() { int32_t code = 0; SRaftEntryCache* pCache = createCache(5); for (int i = 0; i < 5; ++i) { SSyncRaftEntry* pEntry = createEntry(i); code = raftCachePutEntry(pCache, pEntry); ASSERT(code == 1); syncEntryDestory(pEntry); } raftCacheLog2((char*)"==test4 write 5 entries==", pCache); SyncIndex index; index = 3; SSyncRaftEntry* pEntry; code = raftCacheGetAndDel(pCache, index, &pEntry); ASSERT(code == 0); syncEntryLog2((char*)"==test4 get-and-del entry 3==", pEntry); raftCacheLog2((char*)"==test4 after get-and-del entry 3==", pCache); } int main(int argc, char** argv) { gRaftDetailLog = true; tsAsyncLog = 0; sDebugFlag = DEBUG_TRACE + DEBUG_SCREEN + DEBUG_FILE + DEBUG_DEBUG; test1(); test2(); test3(); test4(); return 0; }