Files
silly/tests/test.c

182 lines
3.8 KiB
C

#include "greatest.h"
#include "../silly.h"
#define DELTA 0.01
#define ASSERT_DELTA(expected, actual) {\
double delta = expected-actual;\
ASSERT_IN_RANGE(0, delta, DELTA);\
}
TEST silly_zeros_is_zero() {
silly x = silly_zeros();
ASSERT_EQ_FMT(0, x.sign, "%d");
ASSERT_EQ_FMT(0, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
PASS();
}
TEST silly_string() {
silly x = silly_zeros();
ASSERT_STR_EQ("+0000000000.0000000000", silly_to_string(x));
x.before = 1;
ASSERT_STR_EQ("+0000000001.0000000000", silly_to_string(x));
PASS();
}
TEST silly_addition() {
silly x = silly_zeros();
x.before = 1;
x.after = 1;
silly y = silly_zeros();
y.before = 1;
y.after = 0xffffffff;
x = silly_add(x, y);
ASSERT_EQ_FMT(3, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
y = silly_zeros();
y.sign = 1;
y.before = 4;
x = silly_add(x, y);
ASSERT_EQ_FMT(1, x.sign, "%d");
ASSERT_EQ_FMT(1, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
PASS();
}
TEST silly_subtraction() {
silly x = silly_zeros();
x.before = 2;
silly y = silly_zeros();
y.before = 1;
y.after = 0xffffffff;
x = silly_sub(x, y);
ASSERT_EQ_FMT(0, x.before, "%d");
ASSERT_EQ_FMT(1, x.after, "%d");
x = silly_zeros();
x.before = 2;
y = silly_zeros();
y.sign = 1;
y.before = 4;
x = silly_sub(x, y);
ASSERT_EQ_FMT(6, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
PASS();
}
TEST silly_multiplication() {
silly x = silly_zeros();
x.sign = 1;
x.before = 3;
silly y = silly_zeros();
y.before = 2;
x = silly_mul(x, y);
ASSERT_EQ_FMT(1, x.sign, "%d");
ASSERT_EQ_FMT(6, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
x = silly_zeros();
x.before = 3;
x.after = 1<<31;
y = silly_zeros();
y.before = 2;
x = silly_mul(x, y);
ASSERT_EQ_FMT(7, x.before, "%d");
ASSERT_EQ_FMT(0, x.after, "%d");
PASS();
}
TEST silly_conversion() {
silly x = silly_zeros();
ASSERT_EQ_FMT(0.0, silly_to_double(x), "%f");
x.sign = 1;
x.before = 1;
x.after = (int)(((double)0xffffffff)/10);
ASSERT_DELTA(-1.1, silly_to_double(x));
x = silly_from_float(0.0);
ASSERT_EQ_FMT(0.0, silly_to_double(x), "%f");
x = silly_from_float(-1.1);
ASSERT_DELTA(-1.1, silly_to_double(x));
x = silly_from_double((double) 0.0);
ASSERT_EQ_FMT(0.0, silly_to_double(x), "%f");
x = silly_from_double((double) -1.1);
ASSERT_DELTA(-1.1, silly_to_double(x));
x = silly_from_double((double) -413.25);
ASSERT_DELTA(-413.25, silly_to_double(x));
PASS();
}
TEST silly_integral_division() {
silly x = make_silly(0, 10, 0);
silly y = make_silly(1, 5, 0);
ASSERT_EQ_FMT(-2.0, silly_to_double(silly_idiv(x, y)), "%f");
y = make_silly(1, 2, 0xffffffff/2);
ASSERT_EQ_FMT(-4.0, silly_to_double(silly_idiv(x, y)), "%f");
y = make_silly(1, 2, 3);
ASSERT_EQ_FMT(-4.0, silly_to_double(silly_idiv(x, y)), "%f");
x = make_silly(0, 10000000, 0);
y = make_silly(1, 2, 0xffffffff/2);
ASSERT_EQ_FMT(-4000000.0, silly_to_double(silly_idiv(x, y)), "%f");
PASS();
}
TEST silly_division() {
silly x = make_silly(0, 10, 0);
silly y = make_silly(1, 5, 0);
ASSERT_EQ_FMT(-2.0, silly_to_double(silly_div(x, y)), "%f");
y = make_silly(1, 2, 0xffffffff/2);
ASSERT_DELTA(-4.0, silly_to_double(silly_div(x, y)));
x = make_silly(0, 4, 0);
y = make_silly(0, 8, 0);
ASSERT_DELTA(0.5, silly_to_double(silly_div(x, y)));
PASS();
}
SUITE(tests) {
RUN_TEST(silly_zeros_is_zero);
RUN_TEST(silly_string);
RUN_TEST(silly_addition);
RUN_TEST(silly_subtraction);
RUN_TEST(silly_multiplication);
RUN_TEST(silly_integral_division);
RUN_TEST(silly_division);
RUN_TEST(silly_conversion);
}
GREATEST_MAIN_DEFS();
int main(int argc, char **argv) {
GREATEST_MAIN_BEGIN();
RUN_SUITE(tests);
GREATEST_MAIN_END();
}