-/* $Id: test_record.c,v 1.1 2007-04-23 12:33:00 marc Exp $
- Copyright (c) 2006-2007, Index Data.
-
-This file is part of Pazpar2.
+/* This file is part of Pazpar2.
+ Copyright (C) 2006-2008 Index Data
Pazpar2 is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
for more details.
You should have received a copy of the GNU General Public License
-along with Pazpar2; see the file LICENSE. If not, write to the
-Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
-02111-1307, USA.
- */
+along with this program; if not, write to the Free Software
+Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include <sys/time.h>
-#include <unistd.h>
-#include <sys/socket.h>
-#include <netdb.h>
-#include <signal.h>
-#include <ctype.h>
-#include <assert.h>
+*/
#if HAVE_CONFIG_H
-#include "cconfig.h"
+#include <config.h>
#endif
#define USE_TIMING 0
#include <yaz/test.h>
-
-//#include "pazpar2.h"
-#include "config.h"
+#include "pazpar2_config.h"
#include "record.h"
-//#include "pazpar2.h"
+
void test_record(int argc, char **argv)
struct record *record = 0;
struct client *client = 0;
+ char * bla = "blabla";
+ union data_types data_text;
+ data_text.text.disp = bla;
+ data_text.text.sort = bla;
+
+
+ union data_types data_num;
+ data_num.number.min = 2;
+ data_num.number.max = 5;
+
+ struct record_metadata * tmp_md = 0;
service = conf_service_create(nmem, 4, 3);
YAZ_CHECK(service);
YAZ_CHECK(conf_service_add_metadata(nmem, service, 0, "title",
Metadata_type_generic, Metadata_merge_unique,
- 1, 1, 1, 0));
+ Metadata_setting_no, 1, 1, 1, 0));
YAZ_CHECK(conf_service_add_metadata(nmem, service, 1, "author",
Metadata_type_generic, Metadata_merge_longest,
- 1, 1, 1, 0));
+ Metadata_setting_no,1, 1, 1, 0));
YAZ_CHECK(conf_service_add_metadata(nmem, service, 2, "isbn",
Metadata_type_number, Metadata_merge_no,
- 1, 1, 1, 0));
+ Metadata_setting_no, 1, 1, 1, 0));
YAZ_CHECK(conf_service_add_metadata(nmem, service, 3, "year",
Metadata_type_year, Metadata_merge_range,
- 1, 1, 1, 0));
+ Metadata_setting_no, 1, 1, 1, 0));
YAZ_CHECK(conf_service_add_sortkey(nmem, service, 0, "relevance",
Metadata_sortkey_relevance));
// testing record things
- record = record_create(nmem, 4, 3);
+ record = record_create(nmem, 4, 3, client, 1);
YAZ_CHECK(record);
- // why on earth do we have a client dangeling from the record ??
- record->client = client;
-
- char * bla = "blabla";
- union data_types data_text;
- data_text.text = bla;
-
-
- union data_types data_num;
- data_num.number.min = 2;
- data_num.number.max = 5;
-
- struct record_metadata * tmp_md = 0;
tmp_md = record_metadata_insert(nmem, &(record->metadata[0]), data_text);
YAZ_CHECK(tmp_md);
- tmp_md = record_metadata_insert(nmem, &tmp_md, data_text);
+ YAZ_CHECK(0 == record->metadata[0]->next);
+
+ tmp_md = record_metadata_insert(nmem, &(record->metadata[0]->next),
+ data_text);
YAZ_CHECK(tmp_md);
+ YAZ_CHECK(record->metadata[0]->next);
YAZ_CHECK(record_add_metadata_field_id(nmem, record, 3, data_num));
+ YAZ_CHECK(0 == record->metadata[3]->next);
YAZ_CHECK(record_add_metadata_field_id(nmem, record, 3, data_num));
+ YAZ_CHECK(record->metadata[3]->next);
YAZ_CHECK(record_add_metadata(nmem, record, service, "author", data_text));
+ YAZ_CHECK(0 == record->metadata[1]->next);
YAZ_CHECK(record_add_metadata(nmem, record, service, "author", data_text));
+ YAZ_CHECK(record->metadata[1]->next);
+ YAZ_CHECK(0 == record->sortkeys[0]);
YAZ_CHECK(record_assign_sortkey_field_id(nmem, record, 0, data_text));
+ YAZ_CHECK(record->sortkeys[0]);
+ YAZ_CHECK(0 == record->sortkeys[1]);
YAZ_CHECK(record_assign_sortkey_field_id(nmem, record, 1, data_text));
+ YAZ_CHECK(record->sortkeys[1]);
+ YAZ_CHECK(0 == record->sortkeys[2]);
YAZ_CHECK(record_assign_sortkey_field_id(nmem, record, 2, data_num));
+ YAZ_CHECK(record->sortkeys[2]);
+
YAZ_CHECK(record_assign_sortkey(nmem, record, service, "relevance", data_text));
YAZ_CHECK(record_assign_sortkey(nmem, record, service, "title", data_text));