CloverBootloader/rEFIt_UEFI/cpp_unit_test/strlen_test.cpp

95 lines
2.0 KiB
C++
Raw Normal View History

#include <Platform.h>
#include "../cpp_foundation/XString.h"
#include "../cpp_foundation/unicode_conversions.h"
#include "global_test.h"
//size_t clover_strlen (const char *str);
static int len(const char* s1, size_t count, int code)
{
//DebugLog(2, "strlen of '%s'\n", s1);
size_t ret1 = strlen(s1);
if ( ret1 != count ) {
DebugLog(2, "strlen of '%s' gives %zu and should have given %zu\n", s1, ret1, count);
return code;
}
return 0;
}
static int strlen_s1_all_length(const char* s1, size_t count, int code)
{
for ( size_t i=0 ; i < count; i++ )
{
int ret = len(s1+i, count-i, code);
if ( ret != 0 ) return ret;
}
return 0;
}
static int strlen_s1_all_offset(const char* s1, size_t count, int code)
{
for ( size_t i=0 ; i < count; i++ )
{
int ret = strlen_s1_all_length(s1+i, count-i, code);
if ( ret != 0 ) return ret;
}
return 0;
}
//
//static int compare_with_variable_sizes(int code)
//{
// unsigned char s1[514];
// for ( size_t i=0 ; i < sizeof(s1) ; i++ ) {
// size_t j=0;
// for ( j = 0 ; j < sizeof(s1) && j < i ; j++ ) { // not using strcpy to not depend of another test.
// s1[j] = (unsigned char)(rndf()*255.0);
// }
// s1[i] = 0;
// int ret = compare_s1_with_variable_sizes((const char*)s1, code+(int)i);
// if ( ret != 0 ) return ret;
// }
// return 0;
//}
int strlen_tests()
{
#ifdef JIEF_DEBUG
// DebugLog(2, "XStringW_tests -> Enter\n");
#endif
const char* s;
s = "1234567890"; // use intermediary var to not be optimized out.
if ( strlen(s) != 10 ) return 1;
s = "";
if ( strlen(s) != 0 ) return 2;
int ret;
s = "12345678901234567890123456789012345678901234567890"; // use intermediary var to not be optimized out.
ret = strlen_s1_all_offset(s, 50, 10);
if ( ret != 0 ) return ret;
#ifdef CLOVER_BUILD
// UINTN start = AsmReadTsc();
// DebugLog(2, "strlen_tests -> Enter\n");
//
// for ( UINTN i=0 ; i<100000 ; i++ ) {
// ret = strlen_s1_all_offset(s, 50, 10);
// }
//
// DebugLog(2, "strlen_tests -> Exit\n");
// UINTN end = AsmReadTsc();
// DebugLog(2, "Strlen bench time = %d\n", end - start);
#endif
return 0;
}