aboutsummaryrefslogtreecommitdiff
path: root/test/testutil.h
blob: 9a1eb2d65cf3bec0a4f08f497b8b1fd5225ca25d (plain)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#ifndef __TEST_UTIL_H__
#define __TEST_UTIL_H__

#include "../jsmn.c"

static int vtokeq(const char *s, jsmntok_t *t, int numtok, va_list ap) {
	if (numtok > 0) {
		int i, start, end, size;
		int type;
		char *value;

		size = -1;
		value = NULL;
		for (i = 0; i < numtok; i++) {
			type = va_arg(ap, int);
			if (type == JSMN_STRING) {
				value = va_arg(ap, char *);
				size = va_arg(ap, int);
				start = end = -1;
			} else if (type == JSMN_PRIMITIVE) {
				value = va_arg(ap, char *);
				start = end = size = -1;
			} else {
				start = va_arg(ap, int);
				end = va_arg(ap, int);
				size = va_arg(ap, int);
				value = NULL;
			}
			if (t[i].type != type) {
				printf("token %d type is %d, not %d\n", i, t[i].type, type);
				return 0;
			}
			if (start != -1 && end != -1) {
				if (t[i].start != start) {
					printf("token %d start is %d, not %d\n", i, t[i].start, start);
					return 0;
				}
				if (t[i].end != end ) {
					printf("token %d end is %d, not %d\n", i, t[i].end, end);
					return 0;
				}
			}
			if (size != -1 && t[i].size != size) {
				printf("token %d size is %d, not %d\n", i, t[i].size, size);
				return 0;
			}

			if (s != NULL && value != NULL) {
				const char *p = s + t[i].start;
				if (strlen(value) != t[i].end - t[i].start ||
						strncmp(p, value, t[i].end - t[i].start) != 0) {
					printf("token %d value is %.*s, not %s\n", i, t[i].end-t[i].start,
							s+t[i].start, value);
					return 0;
				}
			}
		}
	}
	return 1;
}

static int tokeq(const char *s, jsmntok_t *tokens, int numtok, ...) {
	int ok;
	va_list args;
	va_start(args, numtok);
	ok = vtokeq(s, tokens, numtok, args); 
	va_end(args);
	return ok;
}

static int parse(const char *s, int status, int numtok, ...) {
	int r;
	int ok = 1;
	va_list args;
	jsmn_parser p;
	jsmntok_t *t = malloc(numtok * sizeof(jsmntok_t));

	jsmn_init(&p);
	r = jsmn_parse(&p, s, strlen(s), t, numtok);
	if (r != status) {
		printf("status is %d, not %d\n", r, status);
		return 0;
	}

	if (status >= 0) {
		va_start(args, numtok);
		ok = vtokeq(s, t, numtok, args); 
		va_end(args);
	}
	free(t);
	return ok;
}

#endif /* __TEST_UTIL_H__ */