Fixed bug #400: Generic record IDs doesn't match.
[idzebra-moved-to-github.git] / test / sort / sort1.c
index 6b09f25..3ce5353 100644 (file)
@@ -1,6 +1,6 @@
-/* $Id: sort1.c,v 1.1 2004-12-02 15:02:52 adam Exp $
-   Copyright (C) 2003,2004
-   Index Data Aps
+/* $Id: sort1.c,v 1.4 2005-05-04 10:50:09 adam Exp $
+   Copyright (C) 1995-2005
+   Index Data ApS
 
 This file is part of the Zebra server.
 
@@ -20,27 +20,17 @@ Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
 02111-1307, USA.
 */
 
+#include <assert.h>
 #include "../api/testlib.h"
 
-int main(int argc, char **argv)
+static void sort(ZebraHandle zh, const char *query, zint hits, zint *exp)
 {
-    ZebraService zs = start_up(0, argc, argv);
-    ZebraHandle  zh = zebra_open(zs);
     ZebraMetaRecord *recs;
-    char path[256];
+    zint i;
     int errs = 0;
 
-    zebra_select_database(zh, "Default");
-
-    zebra_init(zh);
-
-    zebra_begin_trans(zh, 1);
-    sprintf(path, "%.200s/recs", get_srcdir());
-    zebra_repository_update(zh, path);
-    zebra_end_trans(zh);
-    zebra_commit(zh);
-
-    do_query(__LINE__,zh, "@or computer @attr 7=1 @attr 1=30 0", 4);
+    assert(query);
+    do_query(__LINE__, zh, query, hits);
 
     recs = zebra_meta_records_create_range (zh, "rsetname", 1, 4);
     if (!recs)
@@ -48,22 +38,61 @@ int main(int argc, char **argv)
        fprintf(stderr, "recs==0\n");
        exit(1);
     }
-    if (recs[0].sysno != 3)
-       errs++;
-    if (recs[1].sysno != 2)
-       errs++;
-    if (recs[2].sysno != 4)
-       errs++;
-    if (recs[3].sysno != 5)
-       errs++;
-
+    for (i = 0; i<hits; i++)
+       if (recs[i].sysno != exp[i])
+           errs++;
+    if (errs)
+    {
+       printf("Sequence not in right order for query\n%s\ngot exp\n",
+              query);
+       for (i = 0; i<hits; i++)
+           printf(" " ZINT_FORMAT "   " ZINT_FORMAT "\n",
+                  recs[i].sysno, exp[i]);
+    }
     zebra_meta_records_destroy (zh, recs, 4);
 
     if (errs)
-    {
-       fprintf(stderr, "%d sysnos did not match\n", errs);
        exit(1);
+}
+
+int main(int argc, char **argv)
+{
+    ZebraService zs = start_up(0, argc, argv);
+    ZebraHandle  zh = zebra_open(zs);
+    zint ids[5];
+    char path[256];
+    int i;
+
+    zebra_select_database(zh, "Default");
+
+    zebra_init(zh);
+
+    zebra_begin_trans(zh, 1);
+    for (i = 1; i <= 4; i++)
+    {
+        sprintf(path, "%.200s/rec%d.xml", get_srcdir(), i);
+        zebra_repository_update(zh, path);
     }
+    zebra_end_trans(zh);
+    zebra_commit(zh);
+
+    ids[0] = 3;
+    ids[1] = 2;
+    ids[2] = 4;
+    ids[3] = 5;
+    sort(zh, "@or computer @attr 7=1 @attr 1=30 0", 4, ids);
+
+    ids[0] = 5;
+    ids[1] = 4;
+    ids[2] = 2;
+    ids[3] = 3;
+    sort(zh, "@or computer @attr 7=1 @attr 1=1021 0", 4, ids);
+
+    ids[0] = 2;
+    ids[1] = 5;
+    ids[2] = 4;
+    ids[3] = 3;
+    sort(zh, "@or computer @attr 7=1 @attr 1=1021 @attr 4=109 0", 4, ids);
 
     return close_down(zh, zs, 0);
 }