File: test_hash.c

package info (click to toggle)
libdebian-installer 0.50
  • links: PTS
  • area: main
  • in suites: etch-m68k
  • size: 1,900 kB
  • ctags: 702
  • sloc: sh: 8,774; ansic: 4,576; makefile: 211
file content (62 lines) | stat: -rw-r--r-- 1,399 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <autounit/autounit.h>

#include <debian-installer/hash.h>
#include <debian-installer/string.h>

#define STRING_MAX_LENGTH 10
#define KEY_VALUE_NBR 20

void get_key( const char *name, di_rstring *key) {

  size_t size;

  size = strlen (name);

  /* i know that is bad, but i know it is not written by the lookup */
  key->string = (char *) name;
  key->size = size;
}

gint
test_hash(autounit_test_t *t) 
{
  di_hash_table *table;
  int i,nbr_of_insert=20;
  char str[KEY_VALUE_NBR][STRING_MAX_LENGTH];
  di_rstring key[KEY_VALUE_NBR];


  table = di_hash_table_new(di_rstring_hash, di_rstring_equal);

  for (i=0;i<nbr_of_insert;i++) {
    snprintf(str[i],STRING_MAX_LENGTH,"%d",i);
    get_key(str[i],&key[i]);
    di_hash_table_insert (table, &key[i], str[i]);
  }
  au_assert(t,di_hash_table_size(table) == nbr_of_insert,"hash table size is different with the number of data inserted");

  return TRUE;
}

autounit_test_group_t test_hash_tests[] = {
  {"hash", test_hash, TRUE, TRUE},
  {0, 0, FALSE, FALSE}
};

int test_hash_run() {
  autounit_suite_t *c_unit_test_suite;
  int result;

  c_unit_test_suite = 
    au_new_suite(g_string_new("test di_hash"), 0, 0);
  au_add_test_group(c_unit_test_suite, test_hash_tests);

  result = au_run_suite(c_unit_test_suite);

  au_delete_suite(c_unit_test_suite);

  return result;
};