X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Fsafari1.c;h=f865c51bc7aaa39987bde693de4cdd80e8bf99ee;hb=74fdf8a15af7bb827a256d9df3ecc34a57d2120f;hp=35c1051701e8f7e3c2d8e4c5e7f69b69acc2beaa;hpb=39cb125e7755c6058a93dada8d5172804213cf8e;p=idzebra-moved-to-github.git diff --git a/test/api/safari1.c b/test/api/safari1.c index 35c1051..f865c51 100644 --- a/test/api/safari1.c +++ b/test/api/safari1.c @@ -1,6 +1,6 @@ -/* $Id: safari1.c,v 1.1 2004-11-29 21:55:28 adam Exp $ - Copyright (C) 2004 - Index Data Aps +/* $Id: safari1.c,v 1.10 2006-03-31 15:58:05 adam Exp $ + Copyright (C) 1995-2005 + Index Data ApS This file is part of the Zebra server. @@ -24,39 +24,90 @@ 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)); + + /* 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; + ids[1] = 24339; + YAZ_CHECK(tl_meta_query(zh, "@attr 4=3 @attr 1=any mand", 2, 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); + /* all except 125062 */ + limits[0] = 125062; + limits[1] = 0; + zebra_set_limit(zh, 1, 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)); + + /* 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