X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Fsafari1.c;h=ae561ba4bdac23bbfe08c554e0ff28e02fd27768;hb=6ba9698e88c0283e40fa5980a1a6b551fff2d597;hp=47c3a722234c032c970c2bd645d963920f1d60ec;hpb=6c9fcd3b5d3108702fa1ffc92dab4ab6060f9a19;p=idzebra-moved-to-github.git diff --git a/test/api/safari1.c b/test/api/safari1.c index 47c3a72..ae561ba 100644 --- a/test/api/safari1.c +++ b/test/api/safari1.c @@ -1,4 +1,4 @@ -/* $Id: safari1.c,v 1.3 2005-01-15 19:38:35 adam Exp $ +/* $Id: safari1.c,v 1.11 2006-05-10 08:13:35 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -24,39 +24,98 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include "testlib.h" -const char *myrec[] = { - "1234\n" /* first record */ +const char *myrec[] = +{ + "1234\n" /* ID first record */ + /* chunk owner seq idx term */ "00024338 125060 1 any the\n" "00024338 125060 2 any art\n" - "00024338 125060 3 any of\n", + "00024338 125060 3 any mand\n", - "5678\n" /* other record */ + "5678\n" /* other record - same owner id */ "00024339 125060 1 any den\n" "00024339 125060 2 any gamle\n" "00024339 125060 3 any mand\n", - "5678\n" /* same record identifier as before .. */ + "5678\n" /* same record chunk id as before .. */ "00024339 125060 1 any the\n" "00024339 125060 2 any gamle\n" "00024339 125060 3 any mand\n", - 0}; - -int main(int argc, char **argv) + "1000\n" /* separate record */ + "00024339 125061 1 any the\n" + "00024339 125061 2 any gamle\n" + "00024339 125061 3 any mand\n", + + "1001\n" /* separate record */ + "00024340 125062 1 any the\n" + "00024340 125062 1 any the\n" /* DUP KEY, bug #432 */ + "00024340 125062 2 any old\n" + "00024340 125062 3 any mand\n", + + 0 +}; + +static void tst(int argc, char **argv) { - zint ids[2]; - ZebraService zs = start_up("safari.cfg", argc, argv); + zint ids[3]; + zint limits[3]; + ZebraService zs = tl_start_up("safari.cfg", argc, argv); - ZebraHandle zh = zebra_open(zs); + ZebraHandle zh = zebra_open(zs, 0); + + YAZ_CHECK(tl_init_data(zh, myrec)); + + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any the", 3)); + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any @and the art", 1)); + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any @and den gamle", 0)); + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any @and the gamle", 1)); + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any @and the of", 0)); + + /* verify that we get these records exactly */ + ids[0] = 24338; + ids[1] = 24339; + ids[2] = 24340; + YAZ_CHECK(tl_meta_query(zh, "@attr 4=3 @attr 1=any mand", 3, ids)); - init_data(zh, myrec); - do_query(__LINE__, zh, "@attr 1=1016 the", 1); - do_query(__LINE__, zh, "@attr 1=1016 {the art}", 1); - do_query(__LINE__, zh, "@attr 1=1016 {den gamle}", 1); - do_query(__LINE__, zh, "@attr 1=1016 {the of}", 0); + /* limit to 125061 */ + limits[0] = 125061; + limits[1] = 0; + zebra_set_limit(zh, 0, limits); + ids[0] = 24339; + YAZ_CHECK(tl_meta_query(zh, "@attr 4=3 @attr 1=any mand", 1, ids)); + /* limit to 125060, 125061 */ + limits[0] = 125061; + limits[1] = 125060; + limits[2] = 0; + zebra_set_limit(zh, 0, limits); ids[0] = 24338; - meta_query(__LINE__, zh, "@attr 1=1016 the", 1, ids); - - return close_down(zh, zs, 0); + ids[1] = 24339; + YAZ_CHECK(tl_meta_query(zh, "@attr 4=3 @attr 1=any mand", 2, ids)); + + /* all except 125062 */ + limits[0] = 125062; + limits[1] = 0; + zebra_set_limit(zh, 1, limits); + + ids[0] = 24338; + ids[1] = 24339; + YAZ_CHECK(tl_meta_query(zh, "@attr 4=3 @attr 1=any mand", 2, ids)); + + /* no limit */ + zebra_set_limit(zh, 1, 0); + YAZ_CHECK(tl_query(zh, "@attr 4=3 @attr 1=any mand", 3)); + + YAZ_CHECK(tl_close_down(zh, zs)); } + +TL_MAIN +/* + * Local variables: + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + * vim: shiftwidth=4 tabstop=8 expandtab + */ +