1 /* $NetBSD: test_base.c,v 1.1.1.2 2014/04/24 12:45:26 pettai Exp $ */
2
3 /*
4 * Copyright (c) 2010 Kungliga Tekniska Högskolan
5 * (Royal Institute of Technology, Stockholm, Sweden).
6 * All rights reserved.
7 *
8 * Portions Copyright (c) 2010 Apple Inc. All rights reserved.
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 *
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions and the following disclaimer.
16 *
17 * 2. Redistributions in binary form must reproduce the above copyright
18 * notice, this list of conditions and the following disclaimer in the
19 * documentation and/or other materials provided with the distribution.
20 *
21 * 3. Neither the name of the Institute nor the names of its contributors
22 * may be used to endorse or promote products derived from this software
23 * without specific prior written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
26 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
29 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 * SUCH DAMAGE.
36 */
37
38 #include <stdio.h>
39 #include <err.h>
40
41 #include <krb5/heimbase.h>
42 #include "heimbasepriv.h"
43
44 static void
memory_free(heim_object_t obj)45 memory_free(heim_object_t obj)
46 {
47 }
48
49 static int
test_memory(void)50 test_memory(void)
51 {
52 void *ptr;
53
54 ptr = heim_alloc(10, "memory", memory_free);
55
56 heim_retain(ptr);
57 heim_release(ptr);
58
59 heim_retain(ptr);
60 heim_release(ptr);
61
62 heim_release(ptr);
63
64 ptr = heim_alloc(10, "memory", NULL);
65 heim_release(ptr);
66
67 return 0;
68 }
69
70 static int
test_dict(void)71 test_dict(void)
72 {
73 heim_dict_t dict;
74 heim_number_t a1 = heim_number_create(1);
75 heim_string_t a2 = heim_string_create("hejsan");
76 heim_number_t a3 = heim_number_create(3);
77 heim_string_t a4 = heim_string_create("foosan");
78
79 dict = heim_dict_create(10);
80
81 heim_dict_add_value(dict, a1, a2);
82 heim_dict_add_value(dict, a3, a4);
83
84 heim_dict_delete_key(dict, a3);
85 heim_dict_delete_key(dict, a1);
86
87 heim_release(a1);
88 heim_release(a2);
89 heim_release(a3);
90 heim_release(a4);
91
92 heim_release(dict);
93
94 return 0;
95 }
96
97 static int
test_auto_release(void)98 test_auto_release(void)
99 {
100 heim_auto_release_t ar1, ar2;
101 heim_number_t n1;
102 heim_string_t s1;
103
104 ar1 = heim_auto_release_create();
105
106 s1 = heim_string_create("hejsan");
107 heim_auto_release(s1);
108
109 n1 = heim_number_create(1);
110 heim_auto_release(n1);
111
112 ar2 = heim_auto_release_create();
113
114 n1 = heim_number_create(1);
115 heim_auto_release(n1);
116
117 heim_release(ar2);
118 heim_release(ar1);
119
120 return 0;
121 }
122
123 static int
test_string(void)124 test_string(void)
125 {
126 heim_string_t s1, s2;
127 const char *string = "hejsan";
128
129 s1 = heim_string_create(string);
130 s2 = heim_string_create(string);
131
132 if (heim_cmp(s1, s2) != 0) {
133 printf("the same string is not the same\n");
134 exit(1);
135 }
136
137 heim_release(s1);
138 heim_release(s2);
139
140 return 0;
141 }
142
143 int
main(int argc,char ** argv)144 main(int argc, char **argv)
145 {
146 int res = 0;
147
148 res |= test_memory();
149 res |= test_dict();
150 res |= test_auto_release();
151 res |= test_string();
152
153 return res;
154 }
155