2021-01-27 14:19:52 +01:00
|
|
|
From 30484a41cc1ad29344583521ae9478f25206f05d Mon Sep 17 00:00:00 2001
|
|
|
|
From: Alexandre Abadie <alexandre.abadie@inria.fr>
|
|
|
|
Date: Wed, 27 Jan 2021 13:48:26 +0100
|
|
|
|
Subject: [PATCH 2/2] Adapt unittests for RIOT
|
2016-05-12 16:39:03 +02:00
|
|
|
|
|
|
|
---
|
2021-01-27 14:19:52 +01:00
|
|
|
unittests/fix16_exp_unittests.c | 15 ++++++------
|
|
|
|
unittests/fix16_macros_unittests.c | 13 +++++-----
|
|
|
|
unittests/fix16_str_unittests.c | 13 +++++-----
|
|
|
|
unittests/fix16_unittests.c | 39 +++++++++++++++---------------
|
|
|
|
unittests/libfixmath-unittests.h | 6 ++++-
|
|
|
|
5 files changed, 47 insertions(+), 39 deletions(-)
|
2016-05-12 16:39:03 +02:00
|
|
|
|
|
|
|
diff --git a/unittests/fix16_exp_unittests.c b/unittests/fix16_exp_unittests.c
|
2021-01-27 14:19:52 +01:00
|
|
|
index afb6706..532f918 100644
|
2016-05-12 16:39:03 +02:00
|
|
|
--- a/unittests/fix16_exp_unittests.c
|
|
|
|
+++ b/unittests/fix16_exp_unittests.c
|
|
|
|
@@ -2,11 +2,11 @@
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <math.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
-#include "unittests.h"
|
|
|
|
+#include "libfixmath-unittests.h"
|
|
|
|
|
|
|
|
#define delta(a,b) (((a)>=(b)) ? (a)-(b) : (b)-(a))
|
|
|
|
|
|
|
|
-int main()
|
|
|
|
+int fix16_exp_unittests(void)
|
|
|
|
{
|
|
|
|
int status = 0;
|
|
|
|
{
|
|
|
|
@@ -41,7 +41,7 @@ int main()
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("Worst delta %d with input %d\n", max_delta, worst);
|
|
|
|
+ printf("Worst delta %ld with input %ld\n", (long)max_delta, (long)worst);
|
|
|
|
printf("Average delta %0.2f\n", (float)sum / count);
|
|
|
|
|
|
|
|
TEST(max_delta < 200);
|
|
|
|
@@ -80,7 +80,7 @@ int main()
|
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("Worst delta %0.4f%% with input %d\n", max_delta, worst);
|
|
|
|
+ printf("Worst delta %0.4f%% with input %ld\n", max_delta, (long)worst);
|
|
|
|
printf("Average delta %0.4f%%\n", sum / count);
|
|
|
|
|
|
|
|
TEST(max_delta < 1);
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -111,14 +111,15 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
count++;
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("Worst delta %d with input %d\n", max_delta, worst);
|
|
|
|
+ printf("Worst delta %ld with input %ld\n", (long)max_delta, (long)worst);
|
|
|
|
printf("Average delta %0.2f\n", (float)sum / count);
|
|
|
|
|
|
|
|
TEST(max_delta < 20);
|
|
|
|
}
|
|
|
|
|
2021-01-27 14:19:52 +01:00
|
|
|
- if (status != 0)
|
2016-05-12 16:39:03 +02:00
|
|
|
- fprintf(stdout, "\n\nSome tests FAILED!\n");
|
2021-01-27 14:19:52 +01:00
|
|
|
+ if (status != 0) {
|
|
|
|
+ printf("\n\nSome tests FAILED!\n");
|
|
|
|
+ }
|
2016-05-12 16:39:03 +02:00
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
diff --git a/unittests/fix16_macros_unittests.c b/unittests/fix16_macros_unittests.c
|
2021-01-27 14:19:52 +01:00
|
|
|
index cdfcfaf..2e7bc5c 100644
|
2016-05-12 16:39:03 +02:00
|
|
|
--- a/unittests/fix16_macros_unittests.c
|
|
|
|
+++ b/unittests/fix16_macros_unittests.c
|
|
|
|
@@ -4,13 +4,13 @@
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <math.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
-#include "unittests.h"
|
|
|
|
+#include "libfixmath-unittests.h"
|
2019-11-11 15:15:16 +01:00
|
|
|
|
2016-05-12 16:39:03 +02:00
|
|
|
#define DO_TEST(i,m) \
|
|
|
|
TEST(F16(i ## . ## m) == F16C(i,m)) \
|
|
|
|
TEST(F16(i ## . ## m) == fix16_from_dbl(i ## . ## m))
|
|
|
|
|
|
|
|
-int main()
|
|
|
|
+int fix16_macros_unittests(void)
|
|
|
|
{
|
|
|
|
int status = 0;
|
|
|
|
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -101,10 +101,11 @@ int main()
|
|
|
|
DO_TEST( -1,07143)
|
|
|
|
DO_TEST( -1,07737)
|
2016-05-12 16:39:03 +02:00
|
|
|
DO_TEST( -0,22957)
|
2021-01-27 14:19:52 +01:00
|
|
|
-
|
|
|
|
- if (status != 0)
|
2016-05-12 16:39:03 +02:00
|
|
|
- fprintf(stdout, "\n\nSome tests FAILED!\n");
|
2021-01-27 14:19:52 +01:00
|
|
|
-
|
|
|
|
+
|
|
|
|
+ if (status != 0) {
|
|
|
|
+ printf("\n\nSome tests FAILED!\n");
|
|
|
|
+ }
|
|
|
|
+
|
2016-05-12 16:39:03 +02:00
|
|
|
return status;
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
|
2016-05-12 16:39:03 +02:00
|
|
|
diff --git a/unittests/fix16_str_unittests.c b/unittests/fix16_str_unittests.c
|
2021-01-27 14:19:52 +01:00
|
|
|
index 46da171..b1f811d 100644
|
2016-05-12 16:39:03 +02:00
|
|
|
--- a/unittests/fix16_str_unittests.c
|
|
|
|
+++ b/unittests/fix16_str_unittests.c
|
|
|
|
@@ -3,9 +3,9 @@
|
|
|
|
#include <math.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
-#include "unittests.h"
|
|
|
|
+#include "libfixmath-unittests.h"
|
|
|
|
|
|
|
|
-int main()
|
|
|
|
+int fix16_str_unittests(void)
|
|
|
|
{
|
|
|
|
int status = 0;
|
|
|
|
|
|
|
|
@@ -93,14 +93,14 @@ int main()
|
|
|
|
|
|
|
|
if (strcmp(goodbuf, testbuf) != 0)
|
|
|
|
{
|
|
|
|
- printf("Value (fix16_t)%d gave %s, should be %s\n", value, testbuf, goodbuf);
|
|
|
|
+ printf("Value (fix16_t)%ld gave %s, should be %s\n", (long)value, testbuf, goodbuf);
|
|
|
|
ok = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
fix16_t roundtrip = fix16_from_str(testbuf);
|
|
|
|
if (roundtrip != value)
|
|
|
|
{
|
|
|
|
- printf("Roundtrip failed: (fix16_t)%d -> %s -> (fix16_t)%d\n", value, testbuf, roundtrip);
|
|
|
|
+ printf("Roundtrip failed: (fix16_t)%ld -> %s -> (fix16_t)%ld\n", (long)value, testbuf, (long)roundtrip);
|
|
|
|
ok = false;
|
|
|
|
}
|
|
|
|
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -110,8 +110,9 @@ int main()
|
|
|
|
TEST(ok);
|
2016-05-12 16:39:03 +02:00
|
|
|
}
|
|
|
|
|
2021-01-27 14:19:52 +01:00
|
|
|
- if (status != 0)
|
2016-05-12 16:39:03 +02:00
|
|
|
- fprintf(stdout, "\n\nSome tests FAILED!\n");
|
2021-01-27 14:19:52 +01:00
|
|
|
+ if (status != 0) {
|
|
|
|
+ printf("\n\nSome tests FAILED!\n");
|
|
|
|
+ }
|
2016-05-12 16:39:03 +02:00
|
|
|
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
diff --git a/unittests/fix16_unittests.c b/unittests/fix16_unittests.c
|
2021-01-27 14:19:52 +01:00
|
|
|
index 51d8f61..265b637 100644
|
2016-05-12 16:39:03 +02:00
|
|
|
--- a/unittests/fix16_unittests.c
|
|
|
|
+++ b/unittests/fix16_unittests.c
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -3,7 +3,7 @@
|
2016-05-12 16:39:03 +02:00
|
|
|
#include <math.h>
|
|
|
|
#include <stdbool.h>
|
2021-01-27 14:19:52 +01:00
|
|
|
#include "int64.h"
|
2016-05-12 16:39:03 +02:00
|
|
|
-#include "unittests.h"
|
|
|
|
+#include "libfixmath-unittests.h"
|
2019-11-11 15:15:16 +01:00
|
|
|
|
2016-05-12 16:39:03 +02:00
|
|
|
const fix16_t testcases[] = {
|
|
|
|
// Small numbers
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -48,7 +48,7 @@ const fix16_t max_delta = 1;
|
2016-05-12 16:39:03 +02:00
|
|
|
const fix16_t max_delta = 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
-int main()
|
|
|
|
+int fix16_unittests(void)
|
|
|
|
{
|
|
|
|
int status = 0;
|
|
|
|
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -102,7 +102,7 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
#ifndef FIXMATH_NO_OVERFLOW
|
|
|
|
if (result != fix16_overflow)
|
|
|
|
{
|
|
|
|
- printf("\n%d * %d overflow not detected!\n", a, b);
|
|
|
|
+ printf("\n%ld * %ld overflow not detected!\n", (long)a, (long)b);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
#endif
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -110,8 +110,8 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("\n%d * %d = %d\n", a, b, result);
|
|
|
|
- printf("%f * %f = %d\n", fa, fb, fresult);
|
|
|
|
+ printf("\n%ld * %ld = %ld\n", (long)a, (long)b, (long)result);
|
|
|
|
+ printf("%f * %f = %ld\n", fa, fb, (long)fresult);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -177,7 +177,7 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
#ifndef FIXMATH_NO_OVERFLOW
|
|
|
|
if (result != fix16_overflow)
|
|
|
|
{
|
|
|
|
- printf("\n%d / %d overflow not detected!\n", a, b);
|
|
|
|
+ printf("\n%ld / %ld overflow not detected!\n", (long)a, (long)b);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
#endif
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -223,7 +223,7 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
#ifndef FIXMATH_NO_OVERFLOW
|
|
|
|
if (result != fix16_overflow)
|
|
|
|
{
|
|
|
|
- printf("\n%d + %d overflow not detected!\n", a, b);
|
|
|
|
+ printf("\n%ld + %ld overflow not detected!\n", (long)a, (long)b);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
#endif
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -231,8 +231,8 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
- printf("\n%d + %d = %d\n", a, b, result);
|
|
|
|
- printf("%f + %f = %d\n", fa, fb, fresult);
|
|
|
|
+ printf("\n%ld + %ld = %ld\n", (long)a, (long)b, (long)result);
|
|
|
|
+ printf("%f + %f = %ld\n", fa, fb, (long)fresult);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -269,16 +269,16 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
#ifndef FIXMATH_NO_OVERFLOW
|
|
|
|
if (result != fix16_overflow)
|
|
|
|
{
|
|
|
|
- printf("\n%d - %d overflow not detected!\n", a, b);
|
|
|
|
+ printf("\n%ld - %ld overflow not detected!\n", (long)a, (long)b);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
#endif
|
2021-01-27 14:19:52 +01:00
|
|
|
// Legitimate overflow
|
2016-05-12 16:39:03 +02:00
|
|
|
continue;
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
-
|
2016-05-12 16:39:03 +02:00
|
|
|
- printf("\n%d - %d = %d\n", a, b, result);
|
|
|
|
- printf("%f - %f = %d\n", fa, fb, fresult);
|
2021-01-27 14:19:52 +01:00
|
|
|
+
|
2016-05-12 16:39:03 +02:00
|
|
|
+ printf("\n%ld - %ld = %ld\n", (long)a, (long)b, (long)result);
|
|
|
|
+ printf("%f - %f = %ld\n", fa, fb, (long)fresult);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -322,8 +322,8 @@ int main()
|
2016-05-12 16:39:03 +02:00
|
|
|
|
|
|
|
if (delta(fresult, result) > max_delta)
|
|
|
|
{
|
|
|
|
- printf("\nfix16_sqrt(%d) = %d\n", a, result);
|
|
|
|
- printf("sqrt(%f) = %d\n", fa, fresult);
|
|
|
|
+ printf("\nfix16_sqrt(%ld) = %ld\n", (long)a, (long)result);
|
|
|
|
+ printf("sqrt(%f) = %ld\n", fa, (long)fresult);
|
|
|
|
failures++;
|
|
|
|
}
|
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -383,9 +383,10 @@ int main()
|
|
|
|
TEST(fix16_lerp32(fix16_minimum, fix16_maximum, 0xffffffff) == (fix16_maximum - 1));
|
|
|
|
TEST(fix16_lerp32(-fix16_maximum, fix16_maximum, 0x80000000) == 0);
|
2016-05-12 16:39:03 +02:00
|
|
|
}
|
2021-01-27 14:19:52 +01:00
|
|
|
-
|
|
|
|
- if (status != 0)
|
2016-05-12 16:39:03 +02:00
|
|
|
- fprintf(stdout, "\n\nSome tests FAILED!\n");
|
2021-01-27 14:19:52 +01:00
|
|
|
-
|
|
|
|
+
|
|
|
|
+ if (status != 0) {
|
|
|
|
+ printf( "\n\nSome tests FAILED!\n");
|
|
|
|
+ }
|
|
|
|
+
|
2016-05-12 16:39:03 +02:00
|
|
|
return status;
|
|
|
|
}
|
|
|
|
diff --git a/unittests/libfixmath-unittests.h b/unittests/libfixmath-unittests.h
|
2021-01-27 14:19:52 +01:00
|
|
|
index 57ad8f8..cab51ca 100644
|
2016-05-12 16:39:03 +02:00
|
|
|
--- a/unittests/libfixmath-unittests.h
|
|
|
|
+++ b/unittests/libfixmath-unittests.h
|
2021-01-27 14:19:52 +01:00
|
|
|
@@ -7,7 +7,7 @@
|
2016-05-12 16:39:03 +02:00
|
|
|
if (!(x)) { \
|
2021-01-27 14:19:52 +01:00
|
|
|
fflush(stdout); \
|
|
|
|
fflush(stderr); \
|
2016-05-12 16:39:03 +02:00
|
|
|
- fprintf(stderr, "\033[31;1mFAILED:\033[22;39m " __FILE__ ":" STR2(__LINE__) " " #x "\n"); \
|
2021-01-27 14:19:52 +01:00
|
|
|
+ printf("\033[31;1mFAILED:\033[22;39m " RIOT_FILE_NOPATH ":" STR2(__LINE__) " " #x "\n"); \
|
2016-05-12 16:39:03 +02:00
|
|
|
status = 1; \
|
|
|
|
} else { \
|
2021-01-27 14:19:52 +01:00
|
|
|
fflush(stdout); \
|
|
|
|
@@ -15,3 +15,7 @@
|
2016-05-12 16:39:03 +02:00
|
|
|
printf("\033[32;1mOK:\033[22;39m " #x "\n"); \
|
|
|
|
}
|
|
|
|
|
|
|
|
+int fix16_exp_unittests(void);
|
|
|
|
+int fix16_macros_unittests(void);
|
|
|
|
+int fix16_str_unittests(void);
|
|
|
|
+int fix16_unittests(void);
|
|
|
|
--
|
2021-01-27 14:19:52 +01:00
|
|
|
2.27.0
|
2016-05-12 16:39:03 +02:00
|
|
|
|