2
** Copyright (c) 2005-2008 Sendmail, Inc. and its suppliers.
3
** All rights reserved.
5
** Copyright (c) 2009, The OpenDKIM Project. All rights reserved.
9
static char t_test61_c_id[] = "@(#)$Id: t-test61.c,v 1.3 2009/07/23 17:40:24 cm-msk Exp $";
13
#include <sys/types.h>
19
/* libopendkim includes */
21
#include "t-testdata.h"
23
#define MAXHEADER 4096
25
#define SIG2 "v=1; a=rsa-sha0; c=relaxed/simple; d=example.com; s=test;\r\n\tt=1172620939; bh=ll/0h2aWgG+D3ewmE4Y3pY7Ukz8=; h=Received:Received:\r\n\t Received:From:To:Date:Subject:Message-ID; b=bj9kVUbnBYfe9sVzH9lT45\r\n\tTFKO3eQnDbXLfgmgu/b5QgxcnhT9ojnV2IAM4KUO8+hOo5sDEu5Co/0GASH0vHpSV4P\r\n\t377Iwew3FxvLpHsVbVKgXzoKD4QSbHRpWNxyL6LypaaqFa96YqjXuYXr0vpb88hticn\r\n\t6I16//WThMz8fMU="
28
** MAIN -- program mainline
38
main(int argc, char **argv)
40
#ifdef TEST_KEEP_FILES
42
#endif /* TEST_KEEP_FILES */
46
dkim_query_t qtype = DKIM_QUERY_FILE;
47
unsigned char hdr[MAXHEADER + 1];
49
printf("*** relaxed/simple verifying with bogus signature algorithm\n");
51
/* instantiate the library */
52
lib = dkim_init(NULL, NULL);
55
#ifdef TEST_KEEP_FILES
57
flags = (DKIM_LIBFLAGS_TMPFILES|DKIM_LIBFLAGS_KEEPFILES);
58
(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags,
60
#endif /* TEST_KEEP_FILES */
62
(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYMETHOD,
63
&qtype, sizeof qtype);
64
(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYINFO,
65
KEYFILE, strlen(KEYFILE));
67
dkim = dkim_verify(lib, JOBID, NULL, &status);
70
snprintf(hdr, sizeof hdr, "%s: %s", DKIM_SIGNHEADER, SIG2);
71
status = dkim_header(dkim, hdr, strlen(hdr));
72
assert(status == DKIM_STAT_OK);
74
status = dkim_header(dkim, HEADER01, strlen(HEADER01));
75
assert(status == DKIM_STAT_OK);
77
status = dkim_header(dkim, HEADER02, strlen(HEADER02));
78
assert(status == DKIM_STAT_OK);
80
status = dkim_header(dkim, HEADER03, strlen(HEADER03));
81
assert(status == DKIM_STAT_OK);
83
status = dkim_header(dkim, HEADER04, strlen(HEADER04));
84
assert(status == DKIM_STAT_OK);
86
status = dkim_header(dkim, HEADER05, strlen(HEADER05));
87
assert(status == DKIM_STAT_OK);
89
status = dkim_header(dkim, HEADER06, strlen(HEADER06));
90
assert(status == DKIM_STAT_OK);
92
status = dkim_header(dkim, HEADER07, strlen(HEADER07));
93
assert(status == DKIM_STAT_OK);
95
status = dkim_header(dkim, HEADER08, strlen(HEADER08));
96
assert(status == DKIM_STAT_OK);
98
status = dkim_header(dkim, HEADER09, strlen(HEADER09));
99
assert(status == DKIM_STAT_OK);
101
status = dkim_eoh(dkim);
102
assert(status == DKIM_STAT_OK);
104
status = dkim_body(dkim, BODY00, strlen(BODY00));
105
assert(status == DKIM_STAT_OK);
107
status = dkim_body(dkim, BODY01, strlen(BODY01));
108
assert(status == DKIM_STAT_OK);
110
status = dkim_body(dkim, BODY01A, strlen(BODY01A));
111
assert(status == DKIM_STAT_OK);
112
status = dkim_body(dkim, BODY01B, strlen(BODY01B));
113
assert(status == DKIM_STAT_OK);
114
status = dkim_body(dkim, BODY01C, strlen(BODY01C));
115
assert(status == DKIM_STAT_OK);
116
status = dkim_body(dkim, BODY01D, strlen(BODY01D));
117
assert(status == DKIM_STAT_OK);
118
status = dkim_body(dkim, BODY01E, strlen(BODY01E));
119
assert(status == DKIM_STAT_OK);
121
status = dkim_body(dkim, BODY02, strlen(BODY02));
122
assert(status == DKIM_STAT_OK);
124
status = dkim_body(dkim, BODY03, strlen(BODY03));
125
assert(status == DKIM_STAT_OK);
127
status = dkim_body(dkim, BODY04, strlen(BODY04));
128
assert(status == DKIM_STAT_OK);
130
status = dkim_body(dkim, BODY03, strlen(BODY03));
131
assert(status == DKIM_STAT_OK);
133
status = dkim_body(dkim, BODY03, strlen(BODY03));
134
assert(status == DKIM_STAT_OK);
136
status = dkim_body(dkim, BODY05, strlen(BODY05));
137
assert(status == DKIM_STAT_OK);
139
status = dkim_body(dkim, BODY03, strlen(BODY03));
140
assert(status == DKIM_STAT_OK);
142
status = dkim_body(dkim, BODY03, strlen(BODY03));
143
assert(status == DKIM_STAT_OK);
145
status = dkim_eom(dkim, NULL);
146
assert(status == DKIM_STAT_CANTVRFY);
148
status = dkim_free(dkim);
149
assert(status == DKIM_STAT_OK);