X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Ftestlib.h;h=298e88092046e920dbb6ab2f613fcae10a9ea150;hb=1d09966e51904c44ed82eaa920ffc9fbcc087541;hp=cc60d2f43898319c0bbffd2e0f0711900896e824;hpb=8801da78027ff39a9ac158d0a982094d42e2c22d;p=idzebra-moved-to-github.git diff --git a/test/api/testlib.h b/test/api/testlib.h index cc60d2f..298e880 100644 --- a/test/api/testlib.h +++ b/test/api/testlib.h @@ -1,6 +1,6 @@ -/* $Id: testlib.h,v 1.1 2004-10-28 10:43:38 heikki Exp $ - Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004 - Index Data Aps +/* $Id: testlib.h,v 1.17 2005-12-15 13:28:32 adam Exp $ + Copyright (C) 1995-2005 + Index Data ApS This file is part of the Zebra server. @@ -22,19 +22,99 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA /** testlib - utilities for the api tests */ -#include +#include +#include #include +#include #include +/** + * start_up : Does all the usual start functions + * - nmem_init + * - build the name of logfile from argv[0], and open it + * if no argv passed, do not open a log + * - read zebra.cfg from env var srcdir if it exists; otherwise current dir + * default to zebra.cfg, if no name is given + */ +ZebraService start_up(char *cfgname, int argc, char **argv); + +/** + * get_srcdir : returns the source dir. Most often ".", but when + * making distcheck, some other dir + */ +const char *get_srcdir(); -/** read zebra.cfg from env var srcdir if it exists; otherwise current dir */ -ZebraService start_service(); +/** + * start_log: open a log file + */ +/* FIXME - parse command line arguments to set log levels etc */ +void start_log(int argc, char **argv); /** - * makes a query, checks number of hits, and for the first hit, that - * it contains the given string, and that it gets the right score + * start_service - do a zebra_start with a decent config name + * Takes care of checking the environment for srcdir (as needed by distcheck) + * and uses that if need be. + * The name defaults to zebra.cfg, if null or emtpy */ -void RankingQuery(int lineno, ZebraHandle zh, char *query, - int exphits, char *firstrec, int firstscore ); +ZebraService start_service(const char *cfgname); +/** + * close_down closes it all down + * Does a zebra_close on zh, if not null. + * Does a zebra_stop on zs, if not null + * Writes a log message, OK if retcode is zero, error if not + * closes down nmem and xmalloc + * returns the retcode, for use in return or exit in main() + */ +int close_down(ZebraHandle zh, ZebraService zs, int retcode); + +/** inits the database and inserts test data */ +void init_data(ZebraHandle zh, const char **recs); + + +/** + * do_query does a simple query, and checks that the number of hits matches + */ +int do_query(int lineno, ZebraHandle zh, const char *query, zint exphits); + + +/** + * do_query does a simple query, and checks that error is what is expected + */ +int do_query_x(int lineno, ZebraHandle zh, const char *query, zint exphits, + int experror); + +/** + * do_scan is a utility for scan testing + */ +void do_scan(int lineno, ZebraHandle zh, const char *query, + int pos, int num, /* input params */ + int exp_pos, int exp_num, int exp_partial, /* expected result */ + const char **exp_entries /* expected entries (or NULL) */ + ); + +void do_sort(ZebraHandle zh, const char *query, zint hits, zint *exp); + +/** + * ranking_query makes a query, checks number of hits, and for + * the first hit, that it contains the given string, and that it + * gets the right score + */ +void ranking_query(int lineno, ZebraHandle zh, char *query, + int exphits, char *firstrec, int firstscore ); + +/** + * meta_query makes a query, checks number of hits, and for + * checks that the all records in result set has the proper identifiers (ids) + */ +void meta_query(int lineno, ZebraHandle zh, char *query, int exphits, + zint *ids); + +/** + * if filter given by name does not exist, exit nicely but warn in log + */ +void check_filter(ZebraService zs, const char *name); + +#define TL_ASSERT(x) if (!(x)) { yaz_log(YLOG_FATAL, "%s:%d TL_ASSERT(%s) failed", __FILE__, __LINE__, #x); exit(1); } +#define TL_ASSERT2(x,m) if (!(x)) { yaz_log(YLOG_WARN, "%s", m); yaz_log(YLOG_FATAL, "%s:%d TL_ASSERT(%s) failed", __FILE__, __LINE__, #x); exit(1); }