blob: f871dbb4c03212712a717eec02c139581d20307b [file] [log] [blame]
Lev Walkin1eded352006-07-13 11:19:01 +00001#undef NDEBUG
2#include <stdio.h>
3#include <stdlib.h>
4#include <sys/types.h>
5#include <string.h>
6#include <assert.h>
7#include <errno.h>
8
9#include <T1.h>
10#include <T2.h>
11
12static unsigned char buf[4096];
13static int buf_offset;
14
15static int
16_buf_writer(const void *buffer, size_t size, void *app_key) {
17 unsigned char *b, *bend;
18 (void)app_key;
19 assert(buf_offset + size < sizeof(buf));
20 memcpy(buf + buf_offset, buffer, size);
21 b = buf + buf_offset;
22 bend = b + size;
23 printf("=> [");
24 for(; b < bend; b++)
25 printf(" %02X", *b);
Lev Walkin1715b322013-03-28 04:02:13 -070026 printf("]:%zd\n", size);
Lev Walkin1eded352006-07-13 11:19:01 +000027 buf_offset += size;
28 return 0;
29}
30
31static int
32save_object(void *bs, asn_TYPE_descriptor_t *td) {
33 asn_enc_rval_t rval; /* Return value */
34 int i;
35
36 buf_offset = 0;
37
38 rval = der_encode(td, bs, _buf_writer, 0);
39 if (rval.encoded == -1) {
40 fprintf(stderr,
41 "Cannot encode %s: %s\n",
42 rval.failed_type->name, strerror(errno));
43 assert(rval.encoded != -1);
44 return -1; /* JIC */
45 }
46
47 buf[buf_offset++] = 0xab; /* Finalize with garbage */
48
49 asn_fprint(stderr, td, bs);
50
51 printf("OUT: [");
52 for(i = 0; i < buf_offset; i++)
53 printf(" %02x", buf[i]);
54 printf("]\n");
55
56 return 0;
57}
58
59static int
60load_object(void *bs, asn_TYPE_descriptor_t *td) {
61 asn_dec_rval_t rval;
62
63 fprintf(stderr, "\nLOADING OBJECT OF SIZE %d\n", buf_offset);
64
65 rval = ber_decode(0, td, (void **)&bs, buf, buf_offset);
66 assert(rval.code == RC_OK);
67
68 asn_fprint(stderr, td, bs);
69
70 return (rval.code == RC_OK)?0:-1;
71}
72
73/* [3] IMPLICIT SEQUENCE { b BOOLEAN } */
74uint8_t test_any_buf1[] = { 0xa3, 0x80, /* [3], constructed, indefinite */
75 0x01, 0x01, 0xff, /* b BOOLEAN ::= TRUE */
76 0x00, 0x00 /* End of content octets */ };
77
78/* b BOOLEAN */
79uint8_t test_any_buf2[] = { 0x01, 0x01, 0x13 };
80
81int
82main() {
83 asn_TYPE_descriptor_t *td1 = &asn_DEF_T1;
84 asn_TYPE_descriptor_t *td2 = &asn_DEF_T2;
85 T1_t t1, t1_new;
86 T2_t t2, t2_new;
87 int ret;
88
89 /*
90 * Test the T1 with constructed indefinite length ANY encoding.
91 */
92 memset(&t1, 0, sizeof(t1));
93 memset(&t1_new, 0, sizeof(t1_new));
94
95 t1.i = 112233;
96 t1.any.buf = test_any_buf1;
97 t1.any.size = sizeof(test_any_buf1);
98
99 /* Save->Load must succeed */
100 save_object(&t1, td1);
101 ret = load_object(&t1_new, td1);
102
103 assert(ret == 0);
104 assert(t1_new.i == 112233);
Lev Walkin5b63acf2014-01-14 01:48:37 -0800105 assert(t1_new.any.size == (ssize_t)sizeof(test_any_buf1));
Lev Walkin1eded352006-07-13 11:19:01 +0000106 assert(memcmp(t1_new.any.buf, test_any_buf1, sizeof(test_any_buf1)) == 0);
107
108 /*
109 * Test the T1 with primitive encoding.
110 */
111 memset(&t1, 0, sizeof(t1));
112 memset(&t1_new, 0, sizeof(t1_new));
113
114 t1.i = -112233;
115 t1.any.buf = test_any_buf2;
116 t1.any.size = sizeof(test_any_buf2);
117
118 /* Save->Load must succeed */
119 save_object(&t1, td1);
120 ret = load_object(&t1_new, td1);
121
122 assert(ret == 0);
123 assert(t1_new.i == -112233);
Lev Walkin5b63acf2014-01-14 01:48:37 -0800124 assert(t1_new.any.size == (ssize_t)sizeof(test_any_buf2));
Lev Walkin1eded352006-07-13 11:19:01 +0000125 assert(memcmp(t1_new.any.buf, test_any_buf2, sizeof(test_any_buf2)) == 0);
126
127 /*
128 * Test the T2 empty sequence.
129 */
130 memset(&t2, 0, sizeof(t2));
131 memset(&t2_new, 0, sizeof(t2_new));
132
133 t2.i = 332211;
134 t2.any = calloc(1, sizeof(*t2.any));
135 t2.any->buf = 0;
136 t2.any->size = 0;
137
138 /* Save->Load must succeed */
139 save_object(&t2, td2);
140 ret = load_object(&t2_new, td2);
141
142 assert(ret == 0);
143 assert(t2_new.i == 332211);
144 assert(t2_new.any->size == 0);
145
146 /*
147 * Test the T2 sequence.
148 */
149 memset(&t2, 0, sizeof(t2));
150 memset(&t2_new, 0, sizeof(t2_new));
151
152 t2.i = 332211;
153 t2.any = calloc(1, sizeof(*t2.any));
154 t2.any->buf = test_any_buf1;
155 t2.any->size = sizeof(test_any_buf1);
156
157 /* Save->Load must succeed */
158 save_object(&t2, td2);
159 ret = load_object(&t2_new, td2);
160
161 assert(ret == 0);
162 assert(t2_new.i == 332211);
Lev Walkin5b63acf2014-01-14 01:48:37 -0800163 assert(t2_new.any->size == (ssize_t)sizeof(test_any_buf1));
Lev Walkin1eded352006-07-13 11:19:01 +0000164 assert(memcmp(t2_new.any->buf, test_any_buf1, sizeof(test_any_buf1)) == 0);
165
166 /*
167 * Test the T2 sequence with primitive encoding.
168 */
169 memset(&t2, 0, sizeof(t2));
170 memset(&t2_new, 0, sizeof(t2_new));
171
172 t2.i = 0;
173 t2.any = calloc(1, sizeof(*t2.any));
174 t2.any->buf = test_any_buf2;
175 t2.any->size = sizeof(test_any_buf2);
176
177 /* Save->Load must succeed */
178 save_object(&t2, td2);
179 ret = load_object(&t2_new, td2);
180
181 assert(ret == 0);
182 assert(t2_new.i == 0);
Lev Walkin5b63acf2014-01-14 01:48:37 -0800183 assert(t2_new.any->size == (ssize_t)sizeof(test_any_buf2));
Lev Walkin1eded352006-07-13 11:19:01 +0000184 assert(memcmp(t2_new.any->buf, test_any_buf2, sizeof(test_any_buf2)) == 0);
185
186 /*
187 * Test T2 with ANY element omitted.
188 */
189 free(t2.any);
190 t2.any = 0;
191 memset(&t2_new, 0, sizeof(t2_new));
192
193 save_object(&t2, td2);
194 ret = load_object(&t2_new, td2);
195
196 assert(ret == 0);
197 assert(t2_new.i == 0);
198 assert(t2_new.any == 0);
199
200 printf("OK\n");
201
202 return ret;
203}