4 * Copyright (C) 2009 Red Hat Inc.
5 * Copyright IBM, Corp. 2009
8 * Luiz Capitulino <lcapitulino@redhat.com>
9 * Anthony Liguori <aliguori@us.ibm.com>
11 * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
12 * See the COPYING.LIB file in the top-level directory.
15 #include "qemu/osdep.h"
17 #include "qapi/qmp/qnum.h"
20 * Public Interface test-cases
22 * (with some violations to access 'private' data)
25 static void qnum_from_int_test(void)
28 const int value
= -42;
30 qn
= qnum_from_int(value
);
32 g_assert_cmpint(qn
->kind
, ==, QNUM_I64
);
33 g_assert_cmpint(qn
->u
.i64
, ==, value
);
34 g_assert_cmpint(qn
->base
.refcnt
, ==, 1);
35 g_assert_cmpint(qobject_type(QOBJECT(qn
)), ==, QTYPE_QNUM
);
40 static void qnum_from_uint_test(void)
43 const uint64_t value
= UINT64_MAX
;
45 qn
= qnum_from_uint(value
);
47 g_assert_cmpint(qn
->kind
, ==, QNUM_U64
);
48 g_assert(qn
->u
.u64
== value
);
49 g_assert(qn
->base
.refcnt
== 1);
50 g_assert(qobject_type(QOBJECT(qn
)) == QTYPE_QNUM
);
55 static void qnum_from_double_test(void)
58 const double value
= -42.23423;
60 qn
= qnum_from_double(value
);
62 g_assert_cmpint(qn
->kind
, ==, QNUM_DOUBLE
);
63 g_assert_cmpfloat(qn
->u
.dbl
, ==, value
);
64 g_assert_cmpint(qn
->base
.refcnt
, ==, 1);
65 g_assert_cmpint(qobject_type(QOBJECT(qn
)), ==, QTYPE_QNUM
);
70 static void qnum_from_int64_test(void)
73 const int64_t value
= 0x1234567890abcdefLL
;
75 qn
= qnum_from_int(value
);
76 g_assert_cmpint((int64_t) qn
->u
.i64
, ==, value
);
81 static void qnum_get_int_test(void)
84 const int value
= 123456;
86 qn
= qnum_from_int(value
);
87 g_assert_cmpint(qnum_get_int(qn
), ==, value
);
92 static void qnum_get_uint_test(void)
95 const int value
= 123456;
99 qn
= qnum_from_uint(value
);
100 g_assert(qnum_get_try_uint(qn
, &val
));
101 g_assert_cmpuint(val
, ==, value
);
104 qn
= qnum_from_int(value
);
105 g_assert(qnum_get_try_uint(qn
, &val
));
106 g_assert_cmpuint(val
, ==, value
);
110 qn
= qnum_from_int(-1);
111 g_assert(!qnum_get_try_uint(qn
, &val
));
114 qn
= qnum_from_uint(-1ULL);
115 g_assert(!qnum_get_try_int(qn
, &ival
));
118 qn
= qnum_from_double(0.42);
119 g_assert(!qnum_get_try_uint(qn
, &val
));
123 static void qobject_to_qnum_test(void)
127 qn
= qnum_from_int(0);
128 g_assert(qobject_to(QNum
, QOBJECT(qn
)) == qn
);
131 qn
= qnum_from_double(0);
132 g_assert(qobject_to(QNum
, QOBJECT(qn
)) == qn
);
136 static void qnum_to_string_test(void)
141 qn
= qnum_from_int(123456);
142 tmp
= qnum_to_string(qn
);
143 g_assert_cmpstr(tmp
, ==, "123456");
147 qn
= qnum_from_double(0.42);
148 tmp
= qnum_to_string(qn
);
149 g_assert_cmpstr(tmp
, ==, "0.41999999999999998");
153 qn
= qnum_from_double(2.718281828459045);
154 tmp
= qnum_to_string(qn
);
155 g_assert_cmpstr(tmp
, ==, "2.7182818284590451");
160 int main(int argc
, char **argv
)
162 g_test_init(&argc
, &argv
, NULL
);
164 g_test_add_func("/qnum/from_int", qnum_from_int_test
);
165 g_test_add_func("/qnum/from_uint", qnum_from_uint_test
);
166 g_test_add_func("/qnum/from_double", qnum_from_double_test
);
167 g_test_add_func("/qnum/from_int64", qnum_from_int64_test
);
168 g_test_add_func("/qnum/get_int", qnum_get_int_test
);
169 g_test_add_func("/qnum/get_uint", qnum_get_uint_test
);
170 g_test_add_func("/qnum/to_qnum", qobject_to_qnum_test
);
171 g_test_add_func("/qnum/to_string", qnum_to_string_test
);