aboutsummaryrefslogtreecommitdiffstats
path: root/skeletons/tests/check-REAL.c
diff options
context:
space:
mode:
authorLev Walkin <vlm@lionet.info>2004-09-27 20:52:36 +0000
committerLev Walkin <vlm@lionet.info>2004-09-27 20:52:36 +0000
commited46543c404eb5cf6fc1d563ef388d00bdd05c33 (patch)
tree12266067b2247c2f3fb533470f3c452862b36421 /skeletons/tests/check-REAL.c
parent92b35d2b2bf8832311afca29d6050e5ac6e9a7eb (diff)
pretty-printing check cases
Diffstat (limited to 'skeletons/tests/check-REAL.c')
-rw-r--r--skeletons/tests/check-REAL.c128
1 files changed, 89 insertions, 39 deletions
diff --git a/skeletons/tests/check-REAL.c b/skeletons/tests/check-REAL.c
index 0d6d0736..198113ce 100644
--- a/skeletons/tests/check-REAL.c
+++ b/skeletons/tests/check-REAL.c
@@ -7,8 +7,53 @@
#include <der_encoder.c>
#include <constraints.c>
+static char reconstructed[2][512];
+static int reconstr_lens[2];
+
+static int
+callback(const void *buffer, size_t size, void *app_key) {
+ char *buf = reconstructed[app_key ? 1 : 0];
+ int *len = &reconstr_lens[app_key ? 1 : 0];
+
+ if(*len + size >= sizeof(reconstructed[0]))
+ return -1;
+
+ memcpy(buf + *len, buffer, size);
+ *len += size;
+
+ return 0;
+}
+
+static void
+check_str_repr(double d, const char *sample, const char *canonical_sample) {
+ ssize_t s1, s2;
+
+ reconstr_lens[1] = reconstr_lens[0] = 0;
+
+ s1 = REAL__dump(d, 0, callback, 0);
+ assert(s1 < sizeof(reconstructed[0]));
+ assert(s1 == reconstr_lens[0]);
+ reconstructed[0][s1] = '\0';
+
+ s2 = REAL__dump(d, 1, callback, (void *)1);
+ assert(s2 < sizeof(reconstructed[1]));
+ assert(s2 == reconstr_lens[1]);
+ reconstructed[1][s2] = '\0';
+
+ if(sample) {
+ printf("Checking [%s] against [%s]\n",
+ reconstructed[0], sample);
+ assert(!strcmp(reconstructed[0], sample));
+ }
+ if(canonical_sample) {
+ printf("Checking [%s] against [%s] (canonical)\n",
+ reconstructed[1], canonical_sample);
+ assert(!strcmp(reconstructed[1], canonical_sample));
+ }
+}
+
static void
-check(REAL_t *rn, double orig_dbl) {
+check(REAL_t *rn, double orig_dbl, const char *sample, const char *canonical_sample) {
double val;
uint8_t *p, *end;
int ret;
@@ -44,17 +89,19 @@ check(REAL_t *rn, double orig_dbl) {
assert(orig_dbl == val);
printf("OK\n");
+
+ check_str_repr(val, sample, canonical_sample);
}
uint8_t buf_1_0[] = { 0x80, 0xcc, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
uint8_t buf_1_1[] = { 0x80, 0xcc, 0x11, 0x99, 0x99, 0x99, 0x99, 0x99, 0x9a };
uint8_t buf_3_14[] = { 0x80, 0xcd, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f };
/* These ones are very interesting! It checks mantissa overflow! */
-uint8_t buf_mo1[] = { 0x80, 0xc5, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3};
+uint8_t buf_mo1[] = { 0xC0, 0xc5, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3};
uint8_t buf_mo2[] = { 0x80, 0xbd, 0x19, 0x1e, 0xb8, 0x51, 0xeb, 0x85, 0x1f,3,2};
static void
-check_buf(uint8_t *buf, size_t bufsize, double verify) {
+check_buf(uint8_t *buf, size_t bufsize, double verify, const char *sample, const char *canonical_sample) {
REAL_t rn;
double val;
uint8_t *p, *end;
@@ -90,6 +137,8 @@ check_buf(uint8_t *buf, size_t bufsize, double verify) {
printf("%.12f vs %.12f\n", verify, val);
assert(val == verify);
+
+ check_str_repr(val, sample, canonical_sample);
}
int
@@ -98,42 +147,43 @@ main() {
memset(&rn, 0, sizeof(rn));
- check(&rn, 0.0);
- check(&rn, 1.0);
- check(&rn, -1.0);
- check(&rn, 1.5);
- check(&rn, 0.1);
- check(&rn, 0.33333);
- check(&rn, 2);
- check(&rn, 2.1);
- check(&rn, 3);
- check(&rn, 3.1);
- check(&rn, 3.14);
- check(&rn, 3.1415);
- check(&rn, 3.141592);
- check(&rn, 3.14159265);
- check(&rn, -3.14159265);
- check(&rn, 14159265.0);
- check(&rn, -123456789123456789.0);
- check(&rn, 0.00000000001);
- check(&rn, 0.00000000002);
- check(&rn, 0.00000000009);
- check(&rn, 0.0000000000000000000001);
- check(&rn, 0.000000000000000000000000000001); /* proved 2B a problem */
- check(&rn,-0.000000000000000000000000000001); /* proved 2B a problem */
- check(&rn, 0.0000000000010000000001000000000001);
- check(&rn, 0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
- check(&rn, 0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
- check(&rn,-0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
- check(&rn,-3.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333);
- check(&rn, 0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000033333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333);
- check(&rn, -0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001);
-
- check_buf(buf_1_0, sizeof(buf_1_0), 1.0);
- check_buf(buf_1_1, sizeof(buf_1_1), 1.1);
- check_buf(buf_3_14, sizeof(buf_3_14), 3.14);
- check_buf(buf_mo1, sizeof(buf_mo1), 3.14);
- check_buf(buf_mo2, sizeof(buf_mo2), 3.14);
+ check(&rn, 0.0, "0", "0");
+ check(&rn, -0.0, "-0", "-0"); /* minus-zero */
+ check(&rn, 1.0, "1.0", "1.0E0");
+ check(&rn, -1.0, "-1.0", "-1.0E0");
+ check(&rn, 1.5, "1.5", "1.5E0");
+ check(&rn, 0.1, "0.1", "1.0E-1");
+ check(&rn, 0.33333, "0.33333", "3.3333E-1");
+ check(&rn, 2, "2.0", "2.0E0");
+ check(&rn, 2.1, "2.1", "2.1E0");
+ check(&rn, 3, "3.0", "3.0E0");
+ check(&rn, 3.1, "3.1", "3.1E0");
+ check(&rn, 3.14, "3.14", "3.14E0");
+ check(&rn, 3.1415, "3.1415", "3.1415E0");
+ check(&rn, 3.141592, "3.141592", "3.141592E0");
+ check(&rn, 3.14159265, "3.14159265", "3.14159265E0");
+ check(&rn, -3.14159265, "-3.14159265", "-3.14159265E0");
+ check(&rn, 14159265.0, "14159265.0", "1.4159265E7");
+ check(&rn, -123456789123456789.0, "-123456789123456784.0", "-1.234567891234568E17");
+ check(&rn, 0.00000000001, "0.0", "9.999999999999999E-12");
+ check(&rn, 0.00000000002, "0.0", "2.0E-11");
+ check(&rn, 0.00000000009, "0.0", "9.0E-11");
+ check(&rn, 0.0000000000000000000001, "0.0", "1.0E-22");
+ check(&rn, 0.000000000000000000000000000001, "0.0", "1.0E-30"); /* proved 2B a problem */
+ check(&rn,-0.000000000000000000000000000001, "-0.0", "-1.0E-30"); /* proved 2B a problem */
+ check(&rn, 0.0000000000010000000001000000000001, 0, 0);
+ check(&rn, 0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+ check(&rn, 0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+ check(&rn,-0.000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+ check(&rn,-3.33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333, 0, 0);
+ check(&rn, 0.0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000033333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333, 0, 0);
+ check(&rn, -0.00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000001, 0, 0);
+
+ check_buf(buf_1_0, sizeof(buf_1_0), 1.0, "1.0", "1.0E0");
+ check_buf(buf_1_1, sizeof(buf_1_1), 1.1, "1.1", "1.1E0");
+ check_buf(buf_3_14, sizeof(buf_3_14), 3.14, "3.14", "3.14E0");
+ check_buf(buf_mo1, sizeof(buf_mo1), -3.14, "-3.14", "-3.14E0");
+ check_buf(buf_mo2, sizeof(buf_mo2), 3.14, "3.14", "3.14E0");
return 0;
}