X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=test%2Fapi%2Fsafari1.c;h=c1b0a813619e8b460d13a4886fdf03d2f95cb459;hb=1fde4f52fc72af8e10a600a81c6f0924105add6a;hp=a812639e38b52872a807ab5b20f58e4f47d24406;hpb=9af25502b9e14213d1d44e99e38f752c3a174b44;p=idzebra-moved-to-github.git diff --git a/test/api/safari1.c b/test/api/safari1.c index a812639..c1b0a81 100644 --- a/test/api/safari1.c +++ b/test/api/safari1.c @@ -1,6 +1,6 @@ -/* $Id: safari1.c,v 1.2 2004-12-02 11:28:20 adam Exp $ - Copyright (C) 2004 - Index Data Aps +/* $Id: safari1.c,v 1.7 2005-09-16 09:58:39 adam Exp $ + Copyright (C) 1995-2005 + Index Data ApS This file is part of the Zebra server. @@ -24,39 +24,85 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA #include "testlib.h" -const char *myrec[] = { +const char *myrec[] = +{ "1234\n" /* first record */ "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 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=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); + 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}", 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=1016 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); }