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 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
|
/*
* Copyright (c) 2022 Balazs Scheidler <bazsi77@gmail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
* As an additional exemption you are allowed to compile & link against the
* OpenSSL libraries as published by the OpenSSL project. See the file
* COPYING for details.
*
*/
#include <criterion/criterion.h>
#include "generic-number.h"
#include <math.h>
Test(generic_number, test_set_signed_int_retrieves_the_value_specified)
{
GenericNumber gn;
gn_set_int64(&gn, 1);
cr_assert_eq(gn_as_int64(&gn), 1);
gn_set_int64(&gn, -1);
cr_assert_eq(gn_as_int64(&gn), -1);
gn_set_int64(&gn, G_MAXINT64);
cr_assert_eq(gn_as_int64(&gn), G_MAXINT64);
gn_set_int64(&gn, G_MININT64);
cr_assert_eq(gn_as_int64(&gn), G_MININT64);
}
Test(generic_number, test_set_double_retrieves_the_value_specified)
{
GenericNumber gn;
gn_set_double(&gn, 1.0, -1);
cr_assert_float_eq(gn_as_double(&gn), 1.0, DBL_EPSILON);
gn_set_double(&gn, -1.0, -1);
cr_assert_float_eq(gn_as_double(&gn), -1.0, DBL_EPSILON);
}
Test(generic_number, test_integer_is_converted_to_double)
{
GenericNumber gn;
gn_set_int64(&gn, -5000);
cr_assert_float_eq(gn_as_double(&gn), -5000.0, DBL_EPSILON);
}
Test(generic_number, test_double_is_converted_to_integer_by_rounding)
{
GenericNumber gn;
gn_set_double(&gn, 1.5, -1);
cr_assert_eq(gn_as_int64(&gn), 2);
gn_set_double(&gn, -1.5, -1);
cr_assert_eq(gn_as_int64(&gn), -2);
}
Test(generic_number, test_double_outside_of_the_int64_range_is_represented_as_extremal_values)
{
GenericNumber gn;
gn_set_double(&gn, ((gdouble) G_MAXINT64) + 1.0, -1);
cr_assert_eq(gn_as_int64(&gn), G_MAXINT64);
gn_set_double(&gn, ((gdouble) G_MAXINT64) + 1e6, -1);
cr_assert_eq(gn_as_int64(&gn), G_MAXINT64);
gn_set_double(&gn, ((gdouble) G_MININT64) - 1e6, -1);
cr_assert_eq(gn_as_int64(&gn), G_MININT64);
gn_set_double(&gn, ((gdouble) G_MININT64) - 1.0, -1);
cr_assert_eq(gn_as_int64(&gn), G_MININT64);
}
Test(generic_number, test_set_nan_becomes_a_nan)
{
GenericNumber gn;
gn_set_nan(&gn);
cr_assert(gn_is_nan(&gn));
/* NAN requires _GNU_SOURCE */
gn_set_double(&gn, (gdouble) NAN, -1);
cr_assert(gn_is_nan(&gn));
}
Test(generic_number, test_nan_operation_is_zero_triggers_an_abort, .signal=SIGABRT)
{
GenericNumber gn;
gn_set_nan(&gn);
gn_is_zero(&gn);
cr_assert(FALSE, "Should not be reached");
}
Test(generic_number, test_nan_operation_compare_triggers_an_abort, .signal=SIGABRT)
{
GenericNumber gn1, gn2;
gn_set_nan(&gn1);
gn_set_double(&gn2, 0.0, -1);
gn_compare(&gn1, &gn2);
cr_assert(FALSE, "Should not be reached");
}
|