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 \ | linkhash.c \ | ||||
printbuf.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_SOURCES = test1.c | ||||
test1_LDADD = $(lib_LTLIBRARIES) | test1_LDADD = $(lib_LTLIBRARIES) | ||||
@@ -49,7 +49,10 @@ test_parse_int64_LDADD = $(lib_LTLIBRARIES) | |||||
test_null_SOURCES = test_null.c | test_null_SOURCES = test_null.c | ||||
test_null_LDADD = $(lib_LTLIBRARIES) | 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) | EXTRA_DIST += $(TESTS) | ||||
testsubdir=testSubDir | testsubdir=testSubDir | ||||
TESTS_ENVIRONMENT = top_builddir=$(top_builddir) | 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 $? |