Path: blob/main/contrib/libcbor/test/float_ctrl_test.c
39507 views
/*1* Copyright (c) 2014-2020 Pavel Kalvoda <[email protected]>2*3* libcbor is free software; you can redistribute it and/or modify4* it under the terms of the MIT license. See LICENSE for details.5*/67#include <math.h>8#include <setjmp.h>9#include <stdarg.h>10#include <stddef.h>11#include <stdint.h>12#include <tgmath.h>1314#include <cmocka.h>1516#include "cbor.h"17#include "test_allocator.h"1819cbor_item_t *float_ctrl;20struct cbor_load_result res;2122static const float eps = 0.00001f;2324unsigned char float2_data[] = {0xF9, 0x7B, 0xFF};2526static void test_float2(void **_CBOR_UNUSED(_state)) {27float_ctrl = cbor_load(float2_data, 3, &res);28assert_true(cbor_isa_float_ctrl(float_ctrl));29assert_true(cbor_is_float(float_ctrl));30assert_true(cbor_float_get_width(float_ctrl) == CBOR_FLOAT_16);31assert_true(cbor_float_get_float2(float_ctrl) == 65504.0F);32assert_float_equal(cbor_float_get_float(float_ctrl), 65504.0F, eps);33cbor_decref(&float_ctrl);34assert_null(float_ctrl);35}3637unsigned char float4_data[] = {0xFA, 0x47, 0xC3, 0x50, 0x00};3839static void test_float4(void **_CBOR_UNUSED(_state)) {40float_ctrl = cbor_load(float4_data, 5, &res);41assert_true(cbor_isa_float_ctrl(float_ctrl));42assert_true(cbor_is_float(float_ctrl));43assert_true(cbor_float_get_width(float_ctrl) == CBOR_FLOAT_32);44assert_true(cbor_float_get_float4(float_ctrl) == 100000.0F);45assert_float_equal(cbor_float_get_float(float_ctrl), 100000.0F, eps);46cbor_decref(&float_ctrl);47assert_null(float_ctrl);48}4950unsigned char float8_data[] = {0xFB, 0x7E, 0x37, 0xE4, 0x3C,510x88, 0x00, 0x75, 0x9C};5253static void test_float8(void **_CBOR_UNUSED(_state)) {54float_ctrl = cbor_load(float8_data, 9, &res);55assert_true(cbor_isa_float_ctrl(float_ctrl));56assert_true(cbor_is_float(float_ctrl));57assert_true(cbor_float_get_width(float_ctrl) == CBOR_FLOAT_64);58// XXX: the cast prevents promotion to 80-bit floats on 32-bit x8659assert_true(cbor_float_get_float8(float_ctrl) == (double)1.0e+300);60// Not using `assert_double_equal` since CI has an old version of cmocka61assert_true(fabs(cbor_float_get_float(float_ctrl) - (double)1.0e+300) < eps);62cbor_decref(&float_ctrl);63assert_null(float_ctrl);64}6566unsigned char null_data[] = {0xF6};6768static void test_null(void **_CBOR_UNUSED(_state)) {69float_ctrl = cbor_load(null_data, 1, &res);70assert_true(cbor_isa_float_ctrl(float_ctrl));71assert_true(cbor_is_null(float_ctrl));72cbor_decref(&float_ctrl);73assert_null(float_ctrl);74}7576unsigned char undef_data[] = {0xF7};7778static void test_undef(void **_CBOR_UNUSED(_state)) {79float_ctrl = cbor_load(undef_data, 1, &res);80assert_true(cbor_isa_float_ctrl(float_ctrl));81assert_true(cbor_is_undef(float_ctrl));82cbor_decref(&float_ctrl);83assert_null(float_ctrl);84}8586unsigned char bool_data[] = {0xF4, 0xF5};8788static void test_bool(void **_CBOR_UNUSED(_state)) {89_CBOR_TEST_DISABLE_ASSERT({90float_ctrl = cbor_load(bool_data, 1, &res);91assert_true(cbor_isa_float_ctrl(float_ctrl));92assert_true(cbor_is_bool(float_ctrl));93assert_false(cbor_get_bool(float_ctrl));94cbor_set_bool(float_ctrl, true);95assert_true(cbor_get_bool(float_ctrl));96assert_true(isnan(cbor_float_get_float(float_ctrl)));97cbor_decref(&float_ctrl);98assert_null(float_ctrl);99100float_ctrl = cbor_load(bool_data + 1, 1, &res);101assert_true(cbor_isa_float_ctrl(float_ctrl));102assert_true(cbor_is_bool(float_ctrl));103assert_true(cbor_get_bool(float_ctrl));104cbor_set_bool(float_ctrl, false);105assert_false(cbor_get_bool(float_ctrl));106assert_true(isnan(cbor_float_get_float(float_ctrl)));107cbor_decref(&float_ctrl);108assert_null(float_ctrl);109});110}111112static void test_float_ctrl_creation(void **_CBOR_UNUSED(_state)) {113WITH_FAILING_MALLOC({ assert_null(cbor_new_ctrl()); });114WITH_FAILING_MALLOC({ assert_null(cbor_new_float2()); });115WITH_FAILING_MALLOC({ assert_null(cbor_new_float4()); });116WITH_FAILING_MALLOC({ assert_null(cbor_new_float8()); });117WITH_FAILING_MALLOC({ assert_null(cbor_new_null()); });118WITH_FAILING_MALLOC({ assert_null(cbor_new_undef()); });119120WITH_FAILING_MALLOC({ assert_null(cbor_build_bool(false)); });121WITH_FAILING_MALLOC({ assert_null(cbor_build_float2(3.14)); });122WITH_FAILING_MALLOC({ assert_null(cbor_build_float4(3.14)); });123WITH_FAILING_MALLOC({ assert_null(cbor_build_float8(3.14)); });124WITH_FAILING_MALLOC({ assert_null(cbor_build_ctrl(0xAF)); });125}126127int main(void) {128const struct CMUnitTest tests[] = {129cmocka_unit_test(test_float2),130cmocka_unit_test(test_float4),131cmocka_unit_test(test_float8),132cmocka_unit_test(test_null),133cmocka_unit_test(test_undef),134cmocka_unit_test(test_bool),135cmocka_unit_test(test_float_ctrl_creation),136};137return cmocka_run_group_tests(tests, NULL, NULL);138}139140141