git-svn-id: http://svn.metaparadigm.com/svn/json-c/trunk@68 327403b1-1117-474d-bef2-5cb71233fd97tags/json-c-0.10-20120530
@@ -32,7 +32,7 @@ libjson_la_SOURCES = \ | |||
linkhash.c \ | |||
printbuf.c | |||
check_PROGRAMS = test1 test2 test4 test_parse_int64 test_null | |||
check_PROGRAMS = test1 test2 test4 test_parse_int64 test_null test_cast | |||
test1_SOURCES = test1.c | |||
test1_LDADD = $(lib_LTLIBRARIES) | |||
@@ -49,7 +49,10 @@ test_parse_int64_LDADD = $(lib_LTLIBRARIES) | |||
test_null_SOURCES = test_null.c | |||
test_null_LDADD = $(lib_LTLIBRARIES) | |||
TESTS = test1.test test2.test test4.test parse_int64.test test_null.test | |||
test_cast_SOURCES = test_cast.c | |||
test_cast_LDADD = $(lib_LTLIBRARIES) | |||
TESTS = test1.test test2.test test4.test parse_int64.test test_null.test test_cast.test | |||
EXTRA_DIST += $(TESTS) | |||
testsubdir=testSubDir | |||
TESTS_ENVIRONMENT = top_builddir=$(top_builddir) | |||
@@ -0,0 +1,64 @@ | |||
/* | |||
* Tests if casting within the json_object_get_* functions work correctly. | |||
*/ | |||
#include <stdio.h> | |||
#include <string.h> | |||
#include <stdlib.h> | |||
#include "config.h" | |||
#include "json_inttypes.h" | |||
#include "json_object.h" | |||
#include "json_tokener.h" | |||
#include "json_util.h" | |||
static void getit(struct json_object *new_obj, const char *field); | |||
int main(int argc, char **argv) | |||
{ | |||
const char *input = "{\n\ | |||
\"string_of_digits\": \"123\",\n\ | |||
\"regular_number\": 222,\n\ | |||
\"decimal_number\": 99.55,\n\ | |||
\"boolean_true\": true,\n\ | |||
\"boolean_false\": false,\n\ | |||
\"big_number\": 2147483649,\n\ | |||
}"; | |||
/* Note: 2147483649 = INT_MAX + 2 */ | |||
struct json_object *new_obj; | |||
new_obj = json_tokener_parse(input); | |||
printf("Parsed input: %s\n", input); | |||
printf("Result is %s\n", (new_obj == NULL) ? "NULL (error!)" : "not NULL"); | |||
if (!new_obj) | |||
return 1; // oops, we failed. | |||
getit(new_obj, "string_of_digits"); | |||
getit(new_obj, "regular_number"); | |||
getit(new_obj, "decimal_number"); | |||
getit(new_obj, "boolean_true"); | |||
getit(new_obj, "boolean_false"); | |||
getit(new_obj, "big_number"); | |||
json_object_put(new_obj); | |||
return 0; | |||
} | |||
static void getit(struct json_object *new_obj, const char *field) | |||
{ | |||
struct json_object *o = json_object_object_get(new_obj, field); | |||
enum json_type o_type = json_object_get_type(o); | |||
printf("new_obj.%s json_object_get_type()=%s\n", field, | |||
json_type_to_name(o_type)); | |||
printf("new_obj.%s json_object_get_int()=%d\n", field, | |||
json_object_get_int(o)); | |||
printf("new_obj.%s json_object_get_int64()=%" PRId64 "\n", field, | |||
json_object_get_int64(o)); | |||
printf("new_obj.%s json_object_get_boolean()=%d\n", field, | |||
json_object_get_boolean(o)); | |||
printf("new_obj.%s json_object_get_double()=%f\n", field, | |||
json_object_get_double(o)); | |||
} |
@@ -0,0 +1,39 @@ | |||
Parsed input: { | |||
"string_of_digits": "123", | |||
"regular_number": 222, | |||
"decimal_number": 99.55, | |||
"boolean_true": true, | |||
"boolean_false": false, | |||
"big_number": 2147483649, | |||
} | |||
Result is not NULL | |||
new_obj.string_of_digits json_object_get_type()=string | |||
new_obj.string_of_digits json_object_get_int()=123 | |||
new_obj.string_of_digits json_object_get_int64()=123 | |||
new_obj.string_of_digits json_object_get_boolean()=1 | |||
new_obj.string_of_digits json_object_get_double()=123.000000 | |||
new_obj.regular_number json_object_get_type()=int | |||
new_obj.regular_number json_object_get_int()=222 | |||
new_obj.regular_number json_object_get_int64()=222 | |||
new_obj.regular_number json_object_get_boolean()=1 | |||
new_obj.regular_number json_object_get_double()=222.000000 | |||
new_obj.decimal_number json_object_get_type()=double | |||
new_obj.decimal_number json_object_get_int()=99 | |||
new_obj.decimal_number json_object_get_int64()=99 | |||
new_obj.decimal_number json_object_get_boolean()=1 | |||
new_obj.decimal_number json_object_get_double()=99.550000 | |||
new_obj.boolean_true json_object_get_type()=boolean | |||
new_obj.boolean_true json_object_get_int()=1 | |||
new_obj.boolean_true json_object_get_int64()=1 | |||
new_obj.boolean_true json_object_get_boolean()=1 | |||
new_obj.boolean_true json_object_get_double()=1.000000 | |||
new_obj.boolean_false json_object_get_type()=boolean | |||
new_obj.boolean_false json_object_get_int()=0 | |||
new_obj.boolean_false json_object_get_int64()=0 | |||
new_obj.boolean_false json_object_get_boolean()=0 | |||
new_obj.boolean_false json_object_get_double()=0.000000 | |||
new_obj.big_number json_object_get_type()=int | |||
new_obj.big_number json_object_get_int()=2147483647 | |||
new_obj.big_number json_object_get_int64()=2147483649 | |||
new_obj.big_number json_object_get_boolean()=1 | |||
new_obj.big_number json_object_get_double()=2147483649.000000 |
@@ -0,0 +1,12 @@ | |||
#!/bin/sh | |||
# Common definitions | |||
if test -z "$srcdir"; then | |||
srcdir="${0%/*}" | |||
test "$srcdir" = "$0" && srcdir=. | |||
test -z "$srcdir" && srcdir=. | |||
fi | |||
. "$srcdir/test-defs.sh" | |||
run_output_test test_cast | |||
exit $? |