X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Fsafari1.c;h=8ecaca9f05a1d4d17e4e1de11279b83ba61ae324;hb=d59e8fa050e2ed66b5152df48dbafb26f490e0e9;hp=1121061010ea42466892f4c9d71e1f090705aa38;hpb=b09c1d0aa414cb43fb667be54a29b3cc7279ea85;p=idzebra-moved-to-github.git diff --git a/test/api/safari1.c b/test/api/safari1.c index 1121061..8ecaca9 100644 --- a/test/api/safari1.c +++ b/test/api/safari1.c @@ -1,4 +1,4 @@ -/* $Id: safari1.c,v 1.4 2005-03-05 09:19:16 adam Exp $ +/* $Id: safari1.c,v 1.8 2005-11-10 08:08:19 adam Exp $ Copyright (C) 1995-2005 Index Data ApS @@ -24,39 +24,87 @@ 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}; - + "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 +}; + int main(int argc, char **argv) { - zint ids[2]; + zint ids[3]; + zint limits[3]; ZebraService zs = start_up("safari.cfg", argc, argv); - ZebraHandle zh = zebra_open(zs); + ZebraHandle zh = zebra_open(zs, 0); init_data(zh, myrec); - do_query(__LINE__, zh, "@attr 1=any the", 1); + do_query(__LINE__, zh, "@attr 1=any the", 3); do_query(__LINE__, zh, "@attr 1=any {the art}", 1); - do_query(__LINE__, zh, "@attr 1=any {den gamle}", 1); + do_query(__LINE__, zh, "@attr 1=any {den gamle}", 0); + do_query(__LINE__, zh, "@attr 1=any {the gamle}", 1); do_query(__LINE__, zh, "@attr 1=any {the of}", 0); + /* verify that we get these records exactly */ + ids[0] = 24338; + ids[1] = 24339; + ids[2] = 24340; + meta_query(__LINE__, zh, "@attr 1=any mand", 3, ids); + + /* limit to 125061 */ + limits[0] = 125061; + limits[1] = 0; + zebra_set_limit(zh, 0, limits); + ids[0] = 24339; + meta_query(__LINE__, zh, "@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; + meta_query(__LINE__, zh, "@attr 1=any mand", 2, ids); + + /* all except 125062 */ + limits[0] = 125062; + limits[1] = 0; + zebra_set_limit(zh, 1, limits); + ids[0] = 24338; - meta_query(__LINE__, zh, "@attr 1=any the", 1, ids); - + ids[1] = 24339; + meta_query(__LINE__, zh, "@attr 1=any mand", 2, ids); + + /* no limit */ + zebra_set_limit(zh, 1, 0); + do_query(__LINE__, zh, "@attr 1=any mand", 3); + return close_down(zh, zs, 0); }