add some unit tests for the formatting routines

master
leitner 11 years ago
parent 73db80daec
commit dd4f86fbfa

@ -2,6 +2,9 @@
add compiletimeassert.h
add haveuint128.h
byte.h now defines UNALIGNED_ACCESS_OK on x86
change buffer to have a destructor function pointer
SECURITY: fmt_strn would write one byte too many (returned right length though, so usually not a problem as that byte would be overwritten with \0 by the caller anyway)
fmt_pad and fmt_fill fail more gracefully when srclen > maxlen
0.29:
save 8 bytes in taia.h for 64-bit systems

@ -0,0 +1,107 @@
#include <fmt.h>
#include <scan.h>
#include <textcode.h>
#include <byte.h>
#include <assert.h>
char buf[100];
void zap() { size_t i; for (i=0; i<sizeof(buf); ++i) buf[i]='_'; }
int main() {
uint32_t x;
// check utf8 encoding
zap(); assert(fmt_utf8(NULL,12345) == 3);
zap(); assert(fmt_utf8(buf,12345) == 3 && byte_equal(buf,4,"\xe3\x80\xb9_"));
zap(); assert(fmt_utf8(buf,0xa9) == 2 && byte_equal(buf,3,"\xc2\xa9_"));
zap(); assert(fmt_utf8(buf,0)==1 && byte_equal(buf,2,"\x00_"));
zap(); assert(fmt_utf8(buf,0x80000000)==0 && buf[0]=='_');
// check utf8 decoding
assert(scan_utf8("",1,&x)==1 && x==0); // one byte
assert(scan_utf8("\xf0",1,&x)==0); // incomplete sequence
assert(scan_utf8("\xc2\xa9",2,&x)==2 && x==0xa9);
assert(scan_utf8("\xe3\x80\xb9",3,&x)==3 && x==12345);
assert(scan_utf8("\xc0\xaf",2,&x)==0); // '/' in non-minimal encoding
assert(scan_utf8("\xc2\x00",2,&x)==0); // second byte does not start with 10 bits
// check ascii encoding of numbers
assert(fmt_long(NULL,12345)==5);
zap(); assert(fmt_long(buf,12345)==5 && byte_equal(buf,6,"12345_"));
assert(fmt_long(NULL,-12345)==6);
zap(); assert(fmt_long(buf,-12345)==6 && byte_equal(buf,7,"-12345_"));
assert(fmt_ulong(NULL,123456)==6);
zap(); assert(fmt_ulong(buf,123456)==6 && byte_equal(buf,7,"123456_"));
assert(fmt_xlong(NULL,0x12345)==5);
zap(); assert(fmt_xlong(buf,0x12345)==5 && byte_equal(buf,6,"12345_"));
assert(fmt_8long(NULL,012345)==5);
zap(); assert(fmt_8long(buf,012345)==5 && byte_equal(buf,6,"12345_"));
assert(fmt_longlong(NULL,12345678900ll)==11);
zap(); assert(fmt_longlong(buf,12345678900ll)==11 && byte_equal(buf,12,"12345678900_"));
assert(fmt_longlong(NULL,-12345678900ll)==12);
zap(); assert(fmt_longlong(buf,-12345678900ll)==12 && byte_equal(buf,13,"-12345678900_"));
assert(fmt_xlonglong(NULL,12345678900ll)==9);
zap(); assert(fmt_xlonglong(buf,12345678900ll)==9 && byte_equal(buf,10,"2dfdc1c34_"));
assert(fmt_ulonglong(NULL,12345678900ull)==11);
zap(); assert(fmt_ulonglong(buf,12345678900ull)==11 && byte_equal(buf,12,"12345678900_"));
assert(fmt_ulong0(NULL,12345,7)==7);
zap(); assert(fmt_ulong0(buf,12345,7)==7 && byte_equal(buf,8,"0012345_"));
assert(fmt_plusminus(NULL,15)==1);
zap(); assert(fmt_plusminus(buf,15)==1 && byte_equal(buf,2,"+_"));
assert(fmt_plusminus(NULL,-15)==1);
zap(); assert(fmt_plusminus(buf,-15)==1 && byte_equal(buf,2,"-_"));
assert(fmt_plusminus(NULL,0)==0);
zap(); assert(fmt_plusminus(buf,0)==0 && buf[0]=='_');
assert(fmt_minus(NULL,15)==0);
zap(); assert(fmt_minus(buf,15)==0 && buf[0]=='_');
assert(fmt_minus(NULL,-15)==1);
zap(); assert(fmt_minus(buf,-15)==1 && byte_equal(buf,2,"-_"));
assert(fmt_minus(NULL,0)==0);
zap(); assert(fmt_minus(buf,0)==0 && buf[0]=='_');
assert(fmt_str(NULL,"blah")==4);
zap(); assert(fmt_str(buf,"blah")==4 && byte_equal(buf,5,"blah_"));
zap(); assert(fmt_strn(buf,"blah",3)==3 && byte_equal(buf,4,"bla_"));
zap(); assert(fmt_strn(buf,"blah",5)==4 && byte_equal(buf,5,"blah_"));
assert(fmt_pad(NULL,"blah",3,5,7)==5);
zap(); assert(fmt_pad(buf,"blah",3,5,7)==5 && byte_equal(buf,6," bla_"));
zap(); assert(fmt_pad(buf,"blah",3,5,5)==5 && byte_equal(buf,6," bla_"));
zap(); assert(fmt_pad(buf,"blah",4,5,5)==5 && byte_equal(buf,6," blah_"));
zap(); assert(fmt_pad(buf,"blah",4,3,5)==4 && byte_equal(buf,5,"blah_"));
zap(); assert(fmt_pad(buf,"blah",4,3,3)==3 && byte_equal(buf,4,"bla_"));
assert(fmt_fill(NULL,3,5,7)==5);
zap(); fmt_str(buf,"bla"); assert(fmt_fill(buf,3,5,7)==5 && byte_equal(buf,6,"bla _"));
zap(); fmt_str(buf,"bla"); assert(fmt_fill(buf,3,5,5)==5 && byte_equal(buf,6,"bla _"));
zap(); fmt_str(buf,"blah"); assert(fmt_fill(buf,4,5,5)==5 && byte_equal(buf,6,"blah _"));
zap(); fmt_str(buf,"blah"); assert(fmt_fill(buf,4,3,5)==4 && byte_equal(buf,5,"blah_"));
zap(); fmt_strn(buf,"blah",3); assert(fmt_fill(buf,4,3,3)==3 && byte_equal(buf,4,"bla_"));
assert(fmt_human(NULL,12345)==5);
zap(); assert(fmt_human(buf,12345)==5 && byte_equal(buf,6,"12.3k_"));
zap(); assert(fmt_human(buf,1024)==4 && byte_equal(buf,5,"1.0k_"));
zap(); assert(fmt_human(buf,1000)==4 && byte_equal(buf,5,"1.0k_"));
assert(fmt_humank(NULL,12345)==5);
zap(); assert(fmt_humank(buf,12345)==5 && byte_equal(buf,6,"12.1k_"));
zap(); assert(fmt_humank(buf,1024)==4 && byte_equal(buf,5,"1.0k_"));
zap(); assert(fmt_humank(buf,1000)==4 && byte_equal(buf,5,"1.0k_"));
zap(); assert(fmt_httpdate(buf,1393353927)==29 && byte_equal(buf,30,"Tue, 25 Feb 2014 18:45:27 GMT_"));
assert(fmt_asn1derlength(NULL,0)==1);
zap(); assert(fmt_asn1derlength(buf,0)==1 && byte_equal(buf,2,"\x00_"));
assert(fmt_asn1derlength(NULL,0xc2)==2);
zap(); assert(fmt_asn1derlength(buf,0xc2)==2 && byte_equal(buf,3,"\x81\xc2_"));
assert(fmt_asn1derlength(NULL,0x1234)==3);
zap(); assert(fmt_asn1derlength(buf,0x1234)==3 && byte_equal(buf,3,"\x82\x12\x34_"));
assert(fmt_asn1dertag(NULL,0)==1);
zap(); assert(fmt_asn1dertag(buf,0)==1 && byte_equal(buf,2,"\x00_"));
assert(fmt_asn1dertag(NULL,0xc2)==2);
zap(); assert(fmt_asn1dertag(buf,0xc2)==2 && byte_equal(buf,3,"\x81\x42_"));
zap(); assert(fmt_strm(buf,"hell","o, worl","d!\n")==14 && byte_equal(buf,15,"hello, world!\n_"));
}
Loading…
Cancel
Save