/* * Copyright (C) 2019 Freie Universität Berlin. * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @ingroup unittests * @{ * * @file * @brief Test scanf with floating-point numbers (scanf_float). * * @author Juan Carrano <j.carrano@fu-berlin.de> * * @} */ #include <stdio.h> #include "embUnit/embUnit.h" #include "tests-scanf_float.h" #define TEST_EASY(name, format, constant) static void test_ ## name (void) \ {\ int items;\ float x = 0;\ items = sscanf(#constant, format, &x);\ TEST_ASSERT_EQUAL_INT(items, 1); \ TEST_ASSERT(x == constant##f);\ } TEST_EASY(f, "%f", 2.71828) TEST_EASY(e, "%e", 2.71828) TEST_EASY(E, "%E", 2.71828) TEST_EASY(g, "%g", 2.71828) /* This does not seem to be supported in newlib-nano. */ /*TEST_EASY(a, "%a", 2.71828)*/ TEST_EASY(sign, "%f", -.785398) static void test_scientific(void) { int items; float x = 0; items = sscanf("-3.21e2", "%f", &x); TEST_ASSERT_EQUAL_INT(items, 1); TEST_ASSERT(x == -321.0f); } /* This does not seem to be supported in newlib-nano. */ /* static void test_hexa(void) { int items; float x = 0; items = sscanf("0xA.A", "%f", &x); TEST_ASSERT_EQUAL_INT(items, 1); TEST_ASSERT(x == 0xA.Ap0f); } */ Test *tests_scanf_float_tests(void) { EMB_UNIT_TESTFIXTURES(fixtures) { new_TestFixture(test_f), new_TestFixture(test_e), new_TestFixture(test_E), new_TestFixture(test_g), /* new_TestFixture(test_a), */ new_TestFixture(test_sign), new_TestFixture(test_scientific), /* new_TestFixture(test_hexa), */ }; EMB_UNIT_TESTCALLER(scanf_float_tests, NULL, NULL, fixtures); return (Test *)&scanf_float_tests; } void tests_scanf_float(void) { TESTS_RUN(tests_scanf_float_tests()); }