📄 tcatest.c
字号:
/************************************************************************************************* * The test cases of the abstract database API * Copyright (C) 2006-2008 Mikio Hirabayashi * This file is part of Tokyo Cabinet. * Tokyo Cabinet is free software; you can redistribute it and/or modify it under the terms of * the GNU Lesser General Public License as published by the Free Software Foundation; either * version 2.1 of the License or any later version. Tokyo Cabinet is distributed in the hope * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public * License for more details. * You should have received a copy of the GNU Lesser General Public License along with Tokyo * Cabinet; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, MA 02111-1307 USA. *************************************************************************************************/#include <tcutil.h>#include <tcadb.h>#include "myconf.h"#define RECBUFSIZ 32 // buffer for records/* global variables */const char *g_progname; // program name/* function prototypes */int main(int argc, char **argv);static void usage(void);static void iprintf(const char *format, ...);static void iputchar(int c);static void eprint(TCADB *adb, const char *func);static int myrand(int range);static int runwrite(int argc, char **argv);static int runread(int argc, char **argv);static int runremove(int argc, char **argv);static int runrcat(int argc, char **argv);static int runmisc(int argc, char **argv);static int runwicked(int argc, char **argv);static int procwrite(const char *name, int rnum);static int procread(const char *name);static int procremove(const char *name);static int procrcat(const char *name, int rnum);static int procmisc(const char *name, int rnum);static int procwicked(const char *name, int rnum);/* main routine */int main(int argc, char **argv){ g_progname = argv[0]; srand((unsigned int)(tctime() * 1000) % UINT_MAX); if(argc < 2) usage(); int rv = 0; if(!strcmp(argv[1], "write")){ rv = runwrite(argc, argv); } else if(!strcmp(argv[1], "read")){ rv = runread(argc, argv); } else if(!strcmp(argv[1], "remove")){ rv = runremove(argc, argv); } else if(!strcmp(argv[1], "rcat")){ rv = runrcat(argc, argv); } else if(!strcmp(argv[1], "misc")){ rv = runmisc(argc, argv); } else if(!strcmp(argv[1], "wicked")){ rv = runwicked(argc, argv); } else { usage(); } return rv;}/* print the usage and exit */static void usage(void){ fprintf(stderr, "%s: test cases of the abstract database API of Tokyo Cabinet\n", g_progname); fprintf(stderr, "\n"); fprintf(stderr, "usage:\n"); fprintf(stderr, " %s write name rnum\n", g_progname); fprintf(stderr, " %s read name\n", g_progname); fprintf(stderr, " %s remove name\n", g_progname); fprintf(stderr, " %s rcat name rnum\n", g_progname); fprintf(stderr, " %s misc name rnum\n", g_progname); fprintf(stderr, " %s wicked name rnum\n", g_progname); fprintf(stderr, "\n"); exit(1);}/* print formatted information string and flush the buffer */static void iprintf(const char *format, ...){ va_list ap; va_start(ap, format); vprintf(format, ap); fflush(stdout); va_end(ap);}/* print a character and flush the buffer */static void iputchar(int c){ putchar(c); fflush(stdout);}/* print error message of abstract database */static void eprint(TCADB *adb, const char *func){ fprintf(stderr, "%s: %s: error\n", g_progname, func);}/* get a random number */static int myrand(int range){ return (int)((double)range * rand() / (RAND_MAX + 1.0));}/* parse arguments of write command */static int runwrite(int argc, char **argv){ char *name = NULL; char *rstr = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else if(!rstr){ rstr = argv[i]; } else { usage(); } } if(!name || !rstr) usage(); int rnum = tcatoi(rstr); if(rnum < 1) usage(); int rv = procwrite(name, rnum); return rv;}/* parse arguments of read command */static int runread(int argc, char **argv){ char *name = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else { usage(); } } if(!name) usage(); int rv = procread(name); return rv;}/* parse arguments of remove command */static int runremove(int argc, char **argv){ char *name = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else { usage(); } } if(!name) usage(); int rv = procremove(name); return rv;}/* parse arguments of rcat command */static int runrcat(int argc, char **argv){ char *name = NULL; char *rstr = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else if(!rstr){ rstr = argv[i]; } else { usage(); } } if(!name || !rstr) usage(); int rnum = tcatoi(rstr); if(rnum < 1) usage(); int rv = procrcat(name, rnum); return rv;}/* parse arguments of misc command */static int runmisc(int argc, char **argv){ char *name = NULL; char *rstr = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else if(!rstr){ rstr = argv[i]; } else { usage(); } } if(!name || !rstr) usage(); int rnum = tcatoi(rstr); if(rnum < 1) usage(); int rv = procmisc(name, rnum); return rv;}/* parse arguments of wicked command */static int runwicked(int argc, char **argv){ char *name = NULL; char *rstr = NULL; for(int i = 2; i < argc; i++){ if(!name && argv[i][0] == '-'){ usage(); } else if(!name){ name = argv[i]; } else if(!rstr){ rstr = argv[i]; } else { usage(); } } if(!name || !rstr) usage(); int rnum = tcatoi(rstr); if(rnum < 1) usage(); int rv = procwicked(name, rnum); return rv;}/* perform write command */static int procwrite(const char *name, int rnum){ iprintf("<Writing Test>\n name=%s rnum=%d\n\n", name, rnum); bool err = false; double stime = tctime(); TCADB *adb = tcadbnew(); if(!tcadbopen(adb, name)){ eprint(adb, "tcadbopen"); err = true; } for(int i = 1; i <= rnum; i++){ char buf[RECBUFSIZ]; int len = sprintf(buf, "%08d", i); if(!tcadbput(adb, buf, len, buf, len)){ eprint(adb, "tcadbput"); err = true; break; } if(rnum > 250 && i % (rnum / 250) == 0){ iputchar('.'); if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i); } } iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb)); iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb)); if(!tcadbclose(adb)){ eprint(adb, "tcadbclose"); err = true; } tcadbdel(adb); iprintf("time: %.3f\n", tctime() - stime); iprintf("%s\n\n", err ? "error" : "ok"); return err ? 1 : 0;}/* perform read command */static int procread(const char *name){ iprintf("<Reading Test>\n name=%s\n\n", name); bool err = false; double stime = tctime(); TCADB *adb = tcadbnew(); if(!tcadbopen(adb, name)){ eprint(adb, "tcadbopen"); err = true; } int rnum = tcadbrnum(adb); for(int i = 1; i <= rnum; i++){ char kbuf[RECBUFSIZ]; int ksiz = sprintf(kbuf, "%08d", i); int vsiz; char *vbuf = tcadbget(adb, kbuf, ksiz, &vsiz); if(!vbuf){ eprint(adb, "tcadbget"); err = true; break; } tcfree(vbuf); if(rnum > 250 && i % (rnum / 250) == 0){ iputchar('.'); if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i); } } iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb)); iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb)); if(!tcadbclose(adb)){ eprint(adb, "tcadbclose"); err = true; } tcadbdel(adb); iprintf("time: %.3f\n", tctime() - stime); iprintf("%s\n\n", err ? "error" : "ok"); return err ? 1 : 0;}/* perform remove command */static int procremove(const char *name){ iprintf("<Removing Test>\n name=%s\n\n", name); bool err = false; double stime = tctime(); TCADB *adb = tcadbnew(); if(!tcadbopen(adb, name)){ eprint(adb, "tcadbopen"); err = true; } int rnum = tcadbrnum(adb); for(int i = 1; i <= rnum; i++){ char kbuf[RECBUFSIZ]; int ksiz = sprintf(kbuf, "%08d", i); if(!tcadbout(adb, kbuf, ksiz)){ eprint(adb, "tcadbout"); err = true; break; } if(rnum > 250 && i % (rnum / 250) == 0){ iputchar('.'); if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i); } } iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb)); iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb)); if(!tcadbclose(adb)){ eprint(adb, "tcadbclose"); err = true; } tcadbdel(adb); iprintf("time: %.3f\n", tctime() - stime); iprintf("%s\n\n", err ? "error" : "ok"); return err ? 1 : 0;}/* perform rcat command */static int procrcat(const char *name, int rnum){ iprintf("<Random Concatenating Test>\n name=%s rnum=%d\n\n", name, rnum); int pnum = rnum / 5 + 1; bool err = false; double stime = tctime(); TCADB *adb = tcadbnew(); if(!tcadbopen(adb, name)){ eprint(adb, "tcadbopen"); err = true; } for(int i = 1; i <= rnum; i++){ char kbuf[RECBUFSIZ]; int ksiz = sprintf(kbuf, "%d", myrand(pnum) + 1); if(!tcadbputcat(adb, kbuf, ksiz, kbuf, ksiz)){ eprint(adb, "tcadbputcat"); err = true; break; } if(rnum > 250 && i % (rnum / 250) == 0){ iputchar('.'); if(i == rnum || i % (rnum / 10) == 0) iprintf(" (%08d)\n", i); } } iprintf("record number: %llu\n", (unsigned long long)tcadbrnum(adb)); iprintf("size: %llu\n", (unsigned long long)tcadbsize(adb)); if(!tcadbclose(adb)){ eprint(adb, "tcadbclose"); err = true; } tcadbdel(adb); iprintf("time: %.3f\n", tctime() - stime); iprintf("%s\n\n", err ? "error" : "ok"); return err ? 1 : 0;}/* perform misc command */static int procmisc(const char *name, int rnum){
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -