b11f17a294b77eedca71e789ad5865ec49fbb74e
[idzebra-moved-to-github.git] / test / sort / sort1.c
1 /* $Id: sort1.c,v 1.7 2006-03-31 15:58:09 adam Exp $
2    Copyright (C) 1995-2005
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 "../api/testlib.h"
24
25 static void tst(int argc, char **argv)
26 {
27     ZebraService zs = tl_start_up(0, argc, argv);
28     ZebraHandle  zh = zebra_open(zs, 0);
29     zint ids[5];
30     char path[256];
31     int i;
32
33     YAZ_CHECK(zebra_select_database(zh, "Default") == ZEBRA_OK);
34
35     zebra_init(zh);
36
37     YAZ_CHECK(zebra_begin_trans(zh, 1) == ZEBRA_OK);
38     for (i = 1; i <= 4; i++)
39     {
40         sprintf(path, "%.200s/rec%d.xml", tl_get_srcdir(), i);
41         zebra_repository_update(zh, path);
42     }
43     YAZ_CHECK(zebra_end_trans(zh) == ZEBRA_OK);
44     zebra_commit(zh);
45
46     ids[0] = 3;
47     ids[1] = 2;
48     ids[2] = 4;
49     ids[3] = 5;
50     YAZ_CHECK(tl_sort(zh, "@or computer @attr 7=1 @attr 1=30 0", 4, ids));
51
52     ids[0] = 5;
53     ids[1] = 4;
54     ids[2] = 2;
55     ids[3] = 3;
56     YAZ_CHECK(tl_sort(zh, "@or computer @attr 7=1 @attr 1=1021 0", 4, ids));
57
58     ids[0] = 2;
59     ids[1] = 5;
60     ids[2] = 4;
61     ids[3] = 3;
62     YAZ_CHECK(tl_sort(zh, "@or computer @attr 7=1 @attr 1=1021 @attr 4=109 0", 4, ids));
63
64     YAZ_CHECK(tl_close_down(zh, zs));
65 }
66
67
68 TL_MAIN