Cleaned the test programs a bit, used routines in testlib
[idzebra-moved-to-github.git] / test / api / t6.c
1 /* $Id: t6.c,v 1.4 2004-10-28 15:24:36 heikki Exp $
2    Copyright (C) 1995,1996,1997,1998,1999,2000,2001,2002,2003,2004
3    Index Data Aps
4
5 This file is part of the Zebra server.
6
7 Zebra is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 2, or (at your option) any later
10 version.
11
12 Zebra is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
15 for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with Zebra; see the file LICENSE.zebra.  If not, write to the
19 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 02111-1307, USA.
21 */
22
23 #include <stdlib.h>
24
25 #include <yaz/log.h>
26 #include <yaz/pquery.h>
27 #include <idzebra/api.h>
28
29 #include "testlib.h"
30
31         
32 int main(int argc, char **argv)
33 {
34     int i;
35     ZebraService zs;
36     ZebraHandle zh;
37
38     yaz_log_init_file("t6.log");
39
40     nmem_init ();
41     
42     srand(17);
43     
44     zs = start_service("");
45     zh = zebra_open(zs);
46     zebra_select_database(zh, "Default");
47     zebra_init(zh);
48     zebra_close(zh);
49
50     for (i = 0; i<100; i++)
51     {
52         char rec_buf[5120];
53         int j;
54
55         zh = zebra_open (zs);
56         zebra_select_database(zh, "Default");
57         
58         zebra_begin_trans (zh, 1);
59
60         *rec_buf = '\0';
61         strcat(rec_buf, "<gils><title>");
62         j = (rand() & 15) + 1;
63         while (--j >= 0)
64         {
65             int c = 65 + (rand() & 15);
66             sprintf(rec_buf + strlen(rec_buf), "%c ", c);
67         }
68         strcat(rec_buf, "</title><Control-Identifier>");
69         j = rand() & 31;
70         sprintf(rec_buf + strlen(rec_buf), "%d", j);
71         strcat(rec_buf, "</Control-Identifier></gils>");
72         zebra_add_record (zh, rec_buf, strlen(rec_buf));
73
74         zebra_end_trans (zh);
75         zebra_close(zh);
76     }
77     zebra_stop(zs);
78
79     nmem_exit ();
80     xmalloc_trav ("x");
81     logf(LOG_LOG,"========= all tests OK");
82     exit (0);
83 }