9d7691e494bfb600906c743a3d03b597eb17edf3
[jansson.git] / test / testprogs / test_simple.c
1 /*
2  * Copyright (c) 2009 Petri Lehtinen <petri@digip.org>
3  *
4  * Jansson is free software; you can redistribute it and/or modify
5  * it under the terms of the MIT license. See LICENSE for details.
6  */
7
8 #include <string.h>
9 #include <jansson.h>
10 #include "util.h"
11
12 /* Call the simple functions not covered by other tests of the public API */
13 int main()
14 {
15     json_t *value;
16
17     value = json_integer(1);
18     if(json_typeof(value) != JSON_INTEGER)
19         fail("json_typeof failed");
20
21     if(json_is_object(value))
22         fail("json_is_object failed");
23
24     if(json_is_array(value))
25         fail("json_is_array failed");
26
27     if(json_is_string(value))
28         fail("json_is_string failed");
29
30     if(!json_is_integer(value))
31         fail("json_is_integer failed");
32
33     if(json_is_real(value))
34         fail("json_is_real failed");
35
36     if(!json_is_number(value))
37         fail("json_is_number failed");
38
39     if(json_is_true(value))
40         fail("json_is_true failed");
41
42     if(json_is_false(value))
43         fail("json_is_false failed");
44
45     if(json_is_boolean(value))
46         fail("json_is_boolean failed");
47
48     if(json_is_null(value))
49         fail("json_is_null failed");
50
51     json_decref(value);
52
53
54     value = json_string("foo");
55     if(!value)
56         fail("json_string failed");
57     if(strcmp(json_string_value(value), "foo"))
58         fail("invalid string value");
59
60     if(json_string_set(value, "bar"))
61         fail("json_string_set failed");
62     if(strcmp(json_string_value(value), "bar"))
63         fail("invalid string value");
64
65     json_decref(value);
66
67     value = json_string(NULL);
68     if(value)
69         fail("json_string(NULL) failed");
70
71     /* invalid UTF-8  */
72     value = json_string("a\xefz");
73     if(value)
74         fail("json_string(<invalid utf-8>) failed");
75
76
77     value = json_integer(123);
78     if(!value)
79         fail("json_integer failed");
80     if(json_integer_value(value) != 123)
81         fail("invalid integer value");
82     if(json_number_value(value) != 123.0)
83         fail("invalid number value");
84
85     if(json_integer_set(value, 321))
86         fail("json_integer_set failed");
87     if(json_integer_value(value) != 321)
88         fail("invalid integer value");
89     if(json_number_value(value) != 321.0)
90         fail("invalid number value");
91
92     json_decref(value);
93
94     value = json_real(123.123);
95     if(!value)
96         fail("json_real failed");
97     if(json_real_value(value) != 123.123)
98         fail("invalid integer value");
99     if(json_number_value(value) != 123.123)
100         fail("invalid number value");
101
102     if(json_real_set(value, 321.321))
103         fail("json_real_set failed");
104     if(json_real_value(value) != 321.321)
105         fail("invalid real value");
106     if(json_number_value(value) != 321.321)
107         fail("invalid number value");
108
109     json_decref(value);
110
111     value = json_true();
112     if(!value)
113         fail("json_true failed");
114     json_decref(value);
115
116     value = json_false();
117     if(!value)
118         fail("json_false failed");
119     json_decref(value);
120
121     value = json_null();
122     if(!value)
123         fail("json_null failed");
124     json_decref(value);
125
126     return 0;
127 }