cacheTest.cpp 4.5 KB
Newer Older
H
hjxilinx 已提交
1 2 3
#include <iostream>
#include <gtest/gtest.h>

4
#include "os.h"
H
hjxilinx 已提交
5 6 7 8
#include "taos.h"
#include "tcache.h"

// test cache
H
Haojun Liao 已提交
9
TEST(cacheTest, client_cache_test) {
H
hjxilinx 已提交
10
  const int32_t REFRESH_TIME_IN_SEC = 2;
H
Haojun Liao 已提交
11
  SCacheObj* tscMetaCache = taosCacheInit(TSDB_DATA_TYPE_BINARY, REFRESH_TIME_IN_SEC, 0, NULL, "test");
H
hjxilinx 已提交
12

H
hjxilinx 已提交
13 14
  const char* key1 = "test1";
  char data1[] = "test11";
H
hjxilinx 已提交
15

H
Haojun Liao 已提交
16
  char* cachedObj = (char*) taosCachePut(tscMetaCache, key1, strlen(key1), data1, strlen(data1)+1, 1);
wafwerar's avatar
wafwerar 已提交
17
  taosSsleep(REFRESH_TIME_IN_SEC+1);
H
hjxilinx 已提交
18 19 20

  printf("obj is still valid: %s\n", cachedObj);

H
hjxilinx 已提交
21
  char data2[] = "test22";
H
Haojun Liao 已提交
22
  taosCacheRelease(tscMetaCache, (void**) &cachedObj, false);
H
hjxilinx 已提交
23 24

  /* the object is cleared by cache clean operation */
H
Haojun Liao 已提交
25
  cachedObj = (char*) taosCachePut(tscMetaCache, key1, strlen(key1), data2, strlen(data2)+1, 20);
H
hjxilinx 已提交
26 27 28
  printf("after updated: %s\n", cachedObj);

  printf("start to remove data from cache\n");
H
Haojun Liao 已提交
29
  taosCacheRelease(tscMetaCache, (void**) &cachedObj, false);
H
hjxilinx 已提交
30 31
  printf("end of removing data from cache\n");

H
hjxilinx 已提交
32 33
  const char* key3 = "test2";
  const char* data3 = "kkkkkkk";
H
hjxilinx 已提交
34

H
Haojun Liao 已提交
35
  char* cachedObj2 = (char*) taosCachePut(tscMetaCache, key3, strlen(key3), data3, strlen(data3) + 1, 1);
H
hjxilinx 已提交
36 37
  printf("%s\n", cachedObj2);

H
Haojun Liao 已提交
38
  taosCacheRelease(tscMetaCache, (void**) &cachedObj2, false);
H
hjxilinx 已提交
39

wafwerar's avatar
wafwerar 已提交
40
  taosSsleep(3);
H
Haojun Liao 已提交
41
  char* d = (char*) taosCacheAcquireByKey(tscMetaCache, key3, strlen(key3));
42
  assert(d == NULL);
H
hjxilinx 已提交
43

H
hjxilinx 已提交
44 45
  char key5[] = "test5";
  char data5[] = "data5kkkkk";
H
Haojun Liao 已提交
46
  cachedObj2 = (char*) taosCachePut(tscMetaCache, key5, strlen(key5), data5, strlen(data5) + 1, 20);
H
hjxilinx 已提交
47

H
hjxilinx 已提交
48
  const char* data6= "new Data after updated";
H
Haojun Liao 已提交
49
  taosCacheRelease(tscMetaCache, (void**) &cachedObj2, false);
H
hjxilinx 已提交
50

H
Haojun Liao 已提交
51
  cachedObj2 = (char*) taosCachePut(tscMetaCache, key5, strlen(key5), data6, strlen(data6) + 1, 20);
H
hjxilinx 已提交
52 53
  printf("%s\n", cachedObj2);

H
Haojun Liao 已提交
54
  taosCacheRelease(tscMetaCache, (void**) &cachedObj2, true);
H
hjxilinx 已提交
55

H
hjxilinx 已提交
56
  const char* data7 = "add call update procedure";
H
Haojun Liao 已提交
57
  cachedObj2 = (char*) taosCachePut(tscMetaCache, key5, strlen(key5), data7, strlen(data7) + 1, 20);
H
hjxilinx 已提交
58 59
  printf("%s\n=======================================\n\n", cachedObj2);

H
Haojun Liao 已提交
60
  char* cc = (char*) taosCacheAcquireByKey(tscMetaCache, key5, strlen(key5));
H
hjxilinx 已提交
61

H
Haojun Liao 已提交
62 63
  taosCacheRelease(tscMetaCache, (void**) &cachedObj2, true);
  taosCacheRelease(tscMetaCache, (void**) &cc, false);
H
hjxilinx 已提交
64

H
hjxilinx 已提交
65 66
  const char* data8 = "ttft";
  const char* key6 = "key6";
H
hjxilinx 已提交
67

H
Haojun Liao 已提交
68 69
  char* ft = (char*) taosCachePut(tscMetaCache, key6, strlen(key6), data8, strlen(data8), 20);
  taosCacheRelease(tscMetaCache, (void**) &ft, false);
H
hjxilinx 已提交
70 71 72 73 74

  /**
   * 140ns
   */
  uint64_t startTime = taosGetTimestampUs();
H
hjxilinx 已提交
75
  printf("Cache Performance Test\nstart time:%" PRIu64 "\n", startTime);
H
hjxilinx 已提交
76
  for(int32_t i=0; i<1000; ++i) {
H
Haojun Liao 已提交
77
    char* dd = (char*) taosCacheAcquireByKey(tscMetaCache, key6, strlen(key6));
H
hjxilinx 已提交
78 79 80 81 82 83
    if (dd != NULL) {
//      printf("get the data\n");
    } else {
      printf("data has been released\n");
    }

H
Haojun Liao 已提交
84
    taosCacheRelease(tscMetaCache, (void**) &dd, false);
H
hjxilinx 已提交
85 86 87 88 89
  }

  uint64_t endTime = taosGetTimestampUs();
  int64_t el = endTime - startTime;

H
hjxilinx 已提交
90
  printf("End of Test, %" PRIu64 "\nTotal Elapsed Time:%" PRIu64 " us.avg:%f us\n", endTime, el, el/1000.0);
H
hjxilinx 已提交
91

H
Haojun Liao 已提交
92
  taosCacheCleanup(tscMetaCache);
H
hjxilinx 已提交
93 94
}

H
Haojun Liao 已提交
95
TEST(cacheTest, cache_iter_test) {
H
hjxilinx 已提交
96
  const int32_t REFRESH_TIME_IN_SEC = 2;
97
  auto* pCache = taosCacheInit(TSDB_DATA_TYPE_BINARY, REFRESH_TIME_IN_SEC, false, NULL, "test");
H
hjxilinx 已提交
98 99 100

  char key[256] = {0};
  char data[1024] = "abcdefghijk";
101
//  int32_t len = strlen(data);
H
hjxilinx 已提交
102 103 104 105 106 107

  uint64_t startTime = taosGetTimestampUs();
  int32_t num = 10000;

  for(int32_t i = 0; i < num; ++i) {
    int32_t len = sprintf(key, "abc_%7d", i);
H
Haojun Liao 已提交
108
    taosCachePut(pCache, key, strlen(key), data, len, 3600);
H
hjxilinx 已提交
109
  }
H
Haojun Liao 已提交
110

H
hjxilinx 已提交
111 112
  uint64_t endTime = taosGetTimestampUs();

H
hjxilinx 已提交
113
  printf("add %d object cost:%" PRIu64 " us, avg:%f us\n", num, endTime - startTime, (endTime-startTime)/(double)num);
H
hjxilinx 已提交
114 115 116 117

  startTime = taosGetTimestampUs();
  for(int32_t i = 0; i < num; ++i) {
    int32_t len = sprintf(key, "abc_%7d", i);
H
Haojun Liao 已提交
118
    void* k = taosCacheAcquireByKey(pCache, key, len);
H
hjxilinx 已提交
119 120 121
    assert(k != 0);
  }
  endTime = taosGetTimestampUs();
H
hjxilinx 已提交
122
  printf("retrieve %d object cost:%" PRIu64 " us,avg:%f\n", num, endTime - startTime, (endTime - startTime)/(double)num);
H
hjxilinx 已提交
123

H
Haojun Liao 已提交
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
  int32_t count = 0;
  SCacheIter* pIter = taosCacheCreateIter(pCache);
  while(taosCacheIterNext(pIter)) {
    size_t keyLen = 0;
    size_t dataLen = 0;

    char* key1 = static_cast<char*>(taosCacheIterGetKey(pIter, &keyLen));
    char* data1 = static_cast<char*>(taosCacheIterGetData(pIter, &dataLen));

//    char d[256] = {0};
//    memcpy(d, data1, dataLen);
//    char k[256] = {0};
//    memcpy(k, key1, keyLen);
  }

  ASSERT_EQ(count, num);

H
hjxilinx 已提交
141
  taosCacheCleanup(pCache);
H
Haojun Liao 已提交
142
}