📄 modp_numtoa_test.c
字号:
/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil; tab-width: 4 -*- *//* vi: set expandtab shiftwidth=4 tabstop=4: */#include "modp_numtoa.h"#include <stdio.h>#include <limits.h>#include <stdlib.h>#include <string.h>#include "minunit.h"static char* testITOA(){ char buf1[100]; char buf2[100]; int i; for (i = 0; i < 100000; ++i) { sprintf(buf1, "%d", i); modp_itoa10(i, buf2); mu_assert_str_equals(buf1, buf2); sprintf(buf1, "%d", -i); modp_itoa10(-i, buf2); mu_assert_str_equals(buf1, buf2); sprintf(buf1, "%d", INT_MAX - i); modp_itoa10(INT_MAX - i, buf2); mu_assert_str_equals(buf1, buf2); sprintf(buf1, "%d", -(INT_MAX - i)); modp_itoa10(-(INT_MAX - i), buf2); mu_assert_str_equals(buf1, buf2); } return 0;}static char* testUITOA(){ char buf1[100]; char buf2[100]; uint32_t i; for (i = 0; i < 1000000; ++i) { sprintf(buf1, "%u", i); modp_uitoa10(i, buf2); mu_assert_str_equals(buf1, buf2); } for (i = 0; i < 1000000; ++i) { sprintf(buf1, "%u", 0xFFFFFFFFu - i); modp_uitoa10(0xFFFFFFFFu -i, buf2); mu_assert_str_equals(buf1, buf2); } return 0;}static char* testDoubleToA(){ char buf1[100]; char buf2[100]; double d; double wholes[] = {1.0,2.0,3.0,4.0,5.0,6.0,7.0,8.0,9.0,10.0,11.0,67.0,101.0,10000, 99999}; double frac[] = {0.0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.9, 0.01, 0.25, 0.125, 0.001, 0.00001}; int imax = sizeof(wholes)/sizeof(double); int jmax = sizeof(frac)/sizeof(double); int i,j; for (i = 0; i < imax; ++i) { for (j = 0; j < jmax; ++j) { d = wholes[i] + frac[j]; sprintf(buf1, "%.6f", d); modp_dtoa(d, buf2, 6); mu_assert_str_equals(buf1, buf2); d = -d; sprintf(buf1, "%f", d); modp_dtoa(d, buf2, 6); mu_assert_str_equals(buf1, buf2); } } d = 1.0e200; modp_dtoa(d, buf2, 6); mu_assert_str_equals("1.000000e+200", buf2); d = -1.0e200; modp_dtoa(d, buf2, 6); mu_assert_str_equals("-1.000000e+200", buf2); // test bad precision values d = 1.1; modp_dtoa(d, buf2, -1); mu_assert_str_equals("1.0", buf2); modp_dtoa(d, buf2, 10); mu_assert_str_equals("1.100000000", buf2); return 0;}static char* all_tests() { mu_run_test(testITOA); mu_run_test(testUITOA); mu_run_test(testDoubleToA); return 0;}UNITTESTS
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -