⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tchtest.c

📁 Tokyo Cabinet的Tokyo Cabinet 是一个DBM的实现。这里的数据库由一系列key-value对的记录构成。key和value都可以是任意长度的字节序列,既可以是二进制也可以是字符
💻 C
📖 第 1 页 / 共 4 页
字号:
      err = true;      break;    }    if(rnum > 250) iputchar('.');  }  if(rnum > 250) iprintf(" (%08d)\n", sizeof(words) / sizeof(*words));  iprintf("random erasing:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(rnum));    if(!tchdbout(hdb, kbuf, ksiz) && tchdbecode(hdb) != TCENOREC){      eprint(hdb, "tchdbout");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("writing:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "[%d]", i);    char vbuf[RECBUFSIZ];    int vsiz = i % RECBUFSIZ;    memset(vbuf, '*', vsiz);    if(!tchdbputkeep(hdb, kbuf, ksiz, vbuf, vsiz)){      eprint(hdb, "tchdbputkeep");      err = true;      break;    }    if(vsiz < 1){      char tbuf[PATH_MAX];      for(int j = 0; j < PATH_MAX; j++){        tbuf[j] = myrand(0x100);      }      if(!tchdbput(hdb, kbuf, ksiz, tbuf, PATH_MAX)){        eprint(hdb, "tchdbput");        err = true;        break;      }    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("erasing:\n");  for(int i = 1; i <= rnum; i++){    if(i % 2 == 1){      char kbuf[RECBUFSIZ];      int ksiz = sprintf(kbuf, "[%d]", i);      if(!tchdbout(hdb, kbuf, ksiz)){        eprint(hdb, "tchdbout");        err = true;        break;      }      if(tchdbout(hdb, kbuf, ksiz) || tchdbecode(hdb) != TCENOREC){        eprint(hdb, "tchdbout");        err = true;        break;      }    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("random writing and reopening:\n");  for(int i = 1; i <= rnum; i++){    if(myrand(10) == 0){      int ksiz, vsiz;      char *kbuf, *vbuf;      ksiz = (myrand(5) == 0) ? myrand(UINT16_MAX) : myrand(RECBUFSIZ);      kbuf = tcmalloc(ksiz + 1);      memset(kbuf, '@', ksiz);      vsiz = (myrand(5) == 0) ? myrand(UINT16_MAX) : myrand(RECBUFSIZ);      vbuf = tcmalloc(vsiz + 1);      for(int j = 0; j < vsiz; j++){        vbuf[j] = myrand(256);      }      switch(myrand(4)){      case 0:        if(!tchdbput(hdb, kbuf, ksiz, vbuf, vsiz)){          eprint(hdb, "tchdbput");          err = true;        }        break;      case 1:        if(!tchdbputcat(hdb, kbuf, ksiz, vbuf, vsiz)){          eprint(hdb, "tchdbputcat");          err = true;        }        break;      case 2:        if(!tchdbputasync(hdb, kbuf, ksiz, vbuf, vsiz)){          eprint(hdb, "tchdbputasync");          err = true;        }        break;      case 3:        if(!tchdbout(hdb, kbuf, ksiz) && tchdbecode(hdb) != TCENOREC){          eprint(hdb, "tchdbout");          err = true;        }        break;      }      tcfree(vbuf);      tcfree(kbuf);    } else {      char kbuf[RECBUFSIZ];      int ksiz = myrand(RECBUFSIZ);      memset(kbuf, '@', ksiz);      char vbuf[RECBUFSIZ];      int vsiz = myrand(RECBUFSIZ);      memset(vbuf, '@', vsiz);      if(!tchdbput(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbputcat");        err = true;        break;      }    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(!tchdbclose(hdb)){    eprint(hdb, "tchdbclose");    err = true;  }  if(!tchdbopen(hdb, path, HDBOWRITER | omode)){    eprint(hdb, "tchdbopen");    err = true;  }  iprintf("checking:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "[%d]", i);    int vsiz;    char *vbuf = tchdbget(hdb, kbuf, ksiz, &vsiz);    if(i % 2 == 0){      if(!vbuf){        eprint(hdb, "tchdbget");        err = true;        break;      }      if(vsiz != i % RECBUFSIZ && vsiz != PATH_MAX){        eprint(hdb, "(validation)");        err = true;        tcfree(vbuf);        break;      }    } else {      if(vbuf || tchdbecode(hdb) != TCENOREC){        eprint(hdb, "(validation)");        err = true;        tcfree(vbuf);        break;      }    }    tcfree(vbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("writing:\n");  for(int i = 1; i <= rnum; i++){    char buf[RECBUFSIZ];    int len = sprintf(buf, "%08d", i);    if(!tchdbput(hdb, buf, len, buf, len)){      eprint(hdb, "tchdbput");      err = true;      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("reading:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%08d", i);    int vsiz;    char *vbuf = tchdbget(hdb, kbuf, ksiz, &vsiz);    if(!vbuf){      eprint(hdb, "tchdbget");      err = true;      break;    } else if(vsiz != ksiz || memcmp(vbuf, kbuf, vsiz)){      eprint(hdb, "(validation)");      err = true;      tcfree(vbuf);      break;    }    tcfree(vbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("checking words:\n");  for(int i = 0; words[i] != NULL; i += 2){    const char *kbuf = words[i];    int ksiz = strlen(kbuf);    const char *vbuf = words[i+1];    int vsiz = strlen(vbuf);    int rsiz;    char *rbuf = tchdbget(hdb, kbuf, ksiz, &rsiz);    if(!rbuf){      eprint(hdb, "tchdbget");      err = true;      break;    } else if(rsiz != vsiz || memcmp(rbuf, vbuf, rsiz)){      eprint(hdb, "(validation)");      err = true;      tcfree(rbuf);      break;    }    tcfree(rbuf);    if(rnum > 250) iputchar('.');  }  if(rnum > 250) iprintf(" (%08d)\n", sizeof(words) / sizeof(*words));  iprintf("checking iterator:\n");  int inum = 0;  if(!tchdbiterinit(hdb)){    eprint(hdb, "tchdbiterinit");    err = true;  }  char *kbuf;  int ksiz;  for(int i = 1; (kbuf = tchdbiternext(hdb, &ksiz)) != NULL; i++, inum++){    int vsiz;    char *vbuf = tchdbget(hdb, kbuf, ksiz, &vsiz);    if(!vbuf){      eprint(hdb, "tchdbget");      err = true;      tcfree(kbuf);      break;    }    tcfree(vbuf);    tcfree(kbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(rnum > 250) iprintf(" (%08d)\n", inum);  if(tchdbecode(hdb) != TCENOREC || inum != tchdbrnum(hdb)){    eprint(hdb, "(validation)");    err = true;  }  iprintf("iteration updating:\n");  if(!tchdbiterinit(hdb)){    eprint(hdb, "tchdbiterinit");    err = true;  }  inum = 0;  for(int i = 1; (kbuf = tchdbiternext(hdb, &ksiz)) != NULL; i++, inum++){    if(myrand(2) == 0){      if(!tchdbputcat(hdb, kbuf, ksiz, "0123456789", 10)){        eprint(hdb, "tchdbputcat");        err = true;        tcfree(kbuf);        break;      }    } else {      if(!tchdbout(hdb, kbuf, ksiz)){        eprint(hdb, "tchdbout");        err = true;        tcfree(kbuf);        break;      }    }    tcfree(kbuf);    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(rnum > 250) iprintf(" (%08d)\n", inum);  if(tchdbecode(hdb) != TCENOREC || inum < tchdbrnum(hdb)){    eprint(hdb, "(validation)");    err = true;  }  if(myrand(10) == 0 && !tchdbsync(hdb)){    eprint(hdb, "tchdbsync");    err = true;  }  if(!tchdbvanish(hdb)){    eprint(hdb, "tchdbvanish");    err = true;  }  TCMAP *map = tcmapnew();  iprintf("random writing:\n");  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(rnum));    char vbuf[RECBUFSIZ];    int vsiz = sprintf(vbuf, "%d", myrand(rnum));    switch(myrand(4)){    case 0:      if(!tchdbput(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbput");        err = true;      }      tcmapput(map, kbuf, ksiz, vbuf, vsiz);      break;    case 1:      if(!tchdbputkeep(hdb, kbuf, ksiz, vbuf, vsiz) && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbputkeep");        err = true;      }      tcmapputkeep(map, kbuf, ksiz, vbuf, vsiz);      break;    case 2:      if(!tchdbputcat(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbputcat");        err = true;      }      tcmapputcat(map, kbuf, ksiz, vbuf, vsiz);      break;    case 3:      if(!tchdbout(hdb, kbuf, ksiz) && tchdbecode(hdb) != TCENOREC){        eprint(hdb, "tchdbout");        err = true;      }      tcmapout(map, kbuf, ksiz);      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  iprintf("checking transaction commit:\n");  if(!tchdbtranbegin(hdb)){    eprint(hdb, "tchdbtranbegin");    err = true;  }  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(rnum));    char vbuf[RECBUFSIZ];    int vsiz = sprintf(vbuf, "[%d]", myrand(rnum));    switch(myrand(7)){    case 0:      if(!tchdbput(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbput");        err = true;      }      tcmapput(map, kbuf, ksiz, vbuf, vsiz);      break;    case 1:      if(!tchdbputkeep(hdb, kbuf, ksiz, vbuf, vsiz) && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbputkeep");        err = true;      }      tcmapputkeep(map, kbuf, ksiz, vbuf, vsiz);      break;    case 2:      if(!tchdbputcat(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbputcat");        err = true;      }      tcmapputcat(map, kbuf, ksiz, vbuf, vsiz);      break;    case 3:      if(tchdbaddint(hdb, kbuf, ksiz, 1) == INT_MIN && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbaddint");        err = true;      }      tcmapaddint(map, kbuf, ksiz, 1);      break;    case 4:      if(isnan(tchdbadddouble(hdb, kbuf, ksiz, 1.0)) && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbadddouble");        err = true;      }      tcmapadddouble(map, kbuf, ksiz, 1.0);      break;    case 5:      if(myrand(2) == 0){        void *op = (void *)(intptr_t)(myrand(3) + 1);        if(!tchdbputproc(hdb, kbuf, ksiz, vbuf, vsiz, pdprocfunc, op) &&           tchdbecode(hdb) != TCEKEEP){          eprint(hdb, "tchdbputproc");          err = true;        }        tcmapputproc(map, kbuf, ksiz, vbuf, vsiz, pdprocfunc, op);      } else {        vsiz = myrand(10);        void *op = (void *)(intptr_t)(myrand(3) + 1);        if(!tchdbputproc(hdb, kbuf, ksiz, NULL, vsiz, pdprocfunc, op) &&           tchdbecode(hdb) != TCEKEEP && tchdbecode(hdb) != TCENOREC){          eprint(hdb, "tchdbputproc");          err = true;        }        tcmapputproc(map, kbuf, ksiz, NULL, vsiz, pdprocfunc, op);      }      break;    case 6:      if(!tchdbout(hdb, kbuf, ksiz) && tchdbecode(hdb) != TCENOREC){        eprint(hdb, "tchdbout");        err = true;      }      tcmapout(map, kbuf, ksiz);      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(!tchdbtrancommit(hdb)){    eprint(hdb, "tchdbtrancommit");    err = true;  }  iprintf("checking transaction abort:\n");  uint64_t ornum = tchdbrnum(hdb);  uint64_t ofsiz = tchdbfsiz(hdb);  if(!tchdbtranbegin(hdb)){    eprint(hdb, "tchdbtranbegin");    err = true;  }  for(int i = 1; i <= rnum; i++){    char kbuf[RECBUFSIZ];    int ksiz = sprintf(kbuf, "%d", myrand(rnum));    char vbuf[RECBUFSIZ];    int vsiz = sprintf(vbuf, "((%d))", myrand(rnum));    switch(myrand(7)){    case 0:      if(!tchdbput(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbput");        err = true;      }      break;    case 1:      if(!tchdbputkeep(hdb, kbuf, ksiz, vbuf, vsiz) && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbputkeep");        err = true;      }      break;    case 2:      if(!tchdbputcat(hdb, kbuf, ksiz, vbuf, vsiz)){        eprint(hdb, "tchdbputcat");        err = true;      }      break;    case 3:      if(tchdbaddint(hdb, kbuf, ksiz, 1) == INT_MIN && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbaddint");        err = true;      }      break;    case 4:      if(isnan(tchdbadddouble(hdb, kbuf, ksiz, 1.0)) && tchdbecode(hdb) != TCEKEEP){        eprint(hdb, "tchdbadddouble");        err = true;      }      break;    case 5:      if(myrand(2) == 0){        void *op = (void *)(intptr_t)(myrand(3) + 1);        if(!tchdbputproc(hdb, kbuf, ksiz, vbuf, vsiz, pdprocfunc, op) &&           tchdbecode(hdb) != TCEKEEP){          eprint(hdb, "tchdbputproc");          err = true;        }      } else {        vsiz = myrand(10);        void *op = (void *)(intptr_t)(myrand(3) + 1);        if(!tchdbputproc(hdb, kbuf, ksiz, NULL, vsiz, pdprocfunc, op) &&           tchdbecode(hdb) != TCEKEEP && tchdbecode(hdb) != TCENOREC){          eprint(hdb, "tchdbputproc");          err = true;        }      }      break;    case 6:      if(!tchdbout(hdb, kbuf, ksiz) && tchdbecode(hdb) != TCENOREC){        eprint(hdb, "tchdbout");        err = true;      }      break;    }    if(rnum > 250 && i % (rnum / 250) == 0){      iputchar('.');      if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i);    }  }  if(!tchdbtranabort(hdb)){    eprint(hdb, "tchdbtranabort");    err = true;  }  iprintf("checking consistency:\n");  if(tchdbrnum(hdb) != ornum || tchdbfsiz(hdb) != ofsiz || tchdbrnum(hdb) != tcmaprnum(map)){    eprint(hdb, "(validation)");    err = true;  }  inum = 0;  tcmapiterinit(map);  const char *tkbuf;  int tksiz;  for(int i = 1; (tkbuf = tcmapiternext(map, &tksiz)) != NULL; i++, inum++){

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -