langatator/tests/test_utils.c
Matthieu Bessat a62dd411aa feat(Evaluator): add pow operator
feat(Evaluator): add minus sign reducing
fix(Evaluator): trim spaces
test: add base for unit testing
2022-04-30 16:16:37 +02:00

65 lines
No EOL
1.8 KiB
C

#include <stdio.h>
#include <assert.h>
#include <string.h>
#include "../src/number_parsing.h"
#include "../src/utils.h"
void test_utils()
{
printf("== test utils == \n");
// test int parsing
char test1[] = "151087";
int res = 0;
parse_clean_positive_integer(strlen(test1), test1, &res);
assert(res == 151087);
char test2[] = "-428579";
parse_int(test2, &res);
assert(res == -428579);
float res3 = 0;
char test3[] = "3121.897";
parse_float(test3, &res3);
assert(float_almost_equal(3121.897, res3));
float res4 = 0;
char test4[] = "-0.4397";
parse_float(test4, &res4);
assert(float_almost_equal(-0.4397, res4));
assert(integer_pow(1, 0) == 1);
assert(integer_pow(2, 1) == 2);
assert(integer_pow(2, 6) == 64);
assert(m_factorial(0) == 1);
assert(m_factorial(1) == 1);
assert(m_factorial(2) == 2);
assert(m_factorial(3) == 6);
assert(m_factorial(4) == 2*3*4);
assert(float_almost_equal(2.7182, m_exp(1.0)));
assert(float_almost_equal(1, m_exp(0)));
assert(float_almost_equal(0, m_sin(0)));
assert(float_almost_equal(1, m_sin(CST_PI/2)));
assert(float_almost_equal(0, m_sin(CST_PI)));
assert(float_almost_equal(-1, m_sin(3*CST_PI/2)));
assert(float_almost_equal(0, m_sin(2*CST_PI)));
assert(float_almost_equal(0, m_sin(4*CST_PI)));
assert(float_almost_equal(1.41421, m_sqrt(2)));
assert(float_almost_equal(2.2360, m_sqrt(5)));
assert(float_almost_equal(0, m_ln(1)));
assert(float_almost_equal(1, m_ln(2.7182818)));
// char src[] = " hello world ";
// char* trimed = trim_space(src);
// assert(strcmp("hello world", trimed) == 0);
// char src2[] = "hello";
// char* trimed2 = trim_space(&src2);
// assert(strcmp("hello", trimed2) == 0);
}