strtolfp.c revision 1.1.1.3 1 1.1.1.2 christos /* $NetBSD: strtolfp.c,v 1.1.1.3 2015/10/23 17:47:45 christos Exp $ */
2 1.1.1.2 christos
3 1.1 christos #include "config.h"
4 1.1 christos
5 1.1 christos #include "ntp_stdlib.h"
6 1.1 christos #include "ntp_calendar.h"
7 1.1 christos
8 1.1 christos #include "unity.h"
9 1.1 christos #include "lfptest.h"
10 1.1 christos
11 1.1 christos /* This file tests both atolfp and mstolfp */
12 1.1 christos
13 1.1.1.3 christos void test_PositiveInteger(void);
14 1.1.1.3 christos void test_NegativeInteger(void);
15 1.1.1.3 christos void test_PositiveFraction(void);
16 1.1.1.3 christos void test_NegativeFraction(void);
17 1.1.1.3 christos void test_PositiveMsFraction(void);
18 1.1.1.3 christos void test_NegativeMsFraction(void);
19 1.1.1.3 christos void test_InvalidChars(void);
20 1.1.1.3 christos
21 1.1.1.3 christos
22 1.1 christos void test_PositiveInteger(void) {
23 1.1 christos const char *str = "500";
24 1.1 christos const char *str_ms = "500000";
25 1.1 christos
26 1.1.1.3 christos l_fp expected = {{500},0};
27 1.1 christos l_fp actual, actual_ms;
28 1.1 christos
29 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
30 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
31 1.1 christos
32 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
33 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
34 1.1 christos }
35 1.1 christos
36 1.1 christos void test_NegativeInteger(void) {
37 1.1 christos const char *str = "-300";
38 1.1 christos const char *str_ms = "-300000";
39 1.1 christos
40 1.1 christos l_fp expected;
41 1.1 christos expected.l_i = -300;
42 1.1 christos expected.l_uf = 0;
43 1.1 christos
44 1.1 christos l_fp actual, actual_ms;
45 1.1 christos
46 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
47 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
48 1.1 christos
49 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
50 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
51 1.1 christos }
52 1.1 christos
53 1.1 christos void test_PositiveFraction(void) {
54 1.1 christos const char *str = "+500.5";
55 1.1 christos const char *str_ms = "500500.0";
56 1.1 christos
57 1.1.1.3 christos l_fp expected = {{500}, HALF};
58 1.1 christos l_fp actual, actual_ms;
59 1.1 christos
60 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
61 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
62 1.1 christos
63 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
64 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
65 1.1 christos }
66 1.1 christos
67 1.1 christos void test_NegativeFraction(void) {
68 1.1 christos const char *str = "-300.75";
69 1.1 christos const char *str_ms = "-300750";
70 1.1 christos
71 1.1 christos l_fp expected;
72 1.1 christos expected.l_i = -301;
73 1.1 christos expected.l_uf = QUARTER;
74 1.1 christos
75 1.1 christos l_fp actual, actual_ms;
76 1.1 christos
77 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
78 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
79 1.1 christos
80 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
81 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
82 1.1 christos }
83 1.1 christos
84 1.1 christos void test_PositiveMsFraction(void) {
85 1.1 christos const char *str = "300.00025";
86 1.1 christos const char *str_ms = "300000.25";
87 1.1 christos
88 1.1.1.3 christos l_fp expected = {{300}, QUARTER_PROMILLE_APPRX};
89 1.1 christos l_fp actual, actual_ms;
90 1.1 christos
91 1.1 christos
92 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
93 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
94 1.1 christos
95 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
96 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
97 1.1 christos
98 1.1 christos }
99 1.1 christos
100 1.1 christos void test_NegativeMsFraction(void) {
101 1.1 christos const char *str = "-199.99975";
102 1.1 christos const char *str_ms = "-199999.75";
103 1.1 christos
104 1.1 christos l_fp expected;
105 1.1 christos expected.l_i = -200;
106 1.1 christos expected.l_uf = QUARTER_PROMILLE_APPRX;
107 1.1 christos
108 1.1 christos l_fp actual, actual_ms;
109 1.1 christos
110 1.1 christos TEST_ASSERT_TRUE(atolfp(str, &actual));
111 1.1 christos TEST_ASSERT_TRUE(mstolfp(str_ms, &actual_ms));
112 1.1 christos
113 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual));
114 1.1 christos TEST_ASSERT_TRUE(IsEqual(expected, actual_ms));
115 1.1 christos
116 1.1 christos }
117 1.1 christos
118 1.1 christos void test_InvalidChars(void) {
119 1.1 christos const char *str = "500.4a2";
120 1.1 christos l_fp actual, actual_ms;
121 1.1 christos
122 1.1 christos TEST_ASSERT_FALSE(atolfp(str, &actual));
123 1.1 christos TEST_ASSERT_FALSE(mstolfp(str, &actual_ms));
124 1.1 christos }
125 1.1 christos
126