mirror of
https://gitea.wildfiregames.com/0ad/0ad
synced 2026-06-17 22:03:56 -07:00
* vsnprintf2: Made compatible between GCC and MSVC - it now always null-terminates the buffer, and returns -1 on overflow. Fixes #158. Added tests. * MeshManager: Use shared_ptr.expired() instead of checking for bad_weak_ptr exception. * Xeromyces: Added tests for GetXMBPath, because it does unusual things in sscanf which MSVC's /analyze complains about. * ConfigDB, ScriptGlue: Replaced some asserts with return-on-failure, to avoid invalid array accesses when continuing after the assert (as complained about by /analyze). * CStr: Removed "using namespace std". Added tests for handling of invalid UTF-8. This was SVN commit r4625.
73 lines
1.8 KiB
C++
73 lines
1.8 KiB
C++
#include "lib/lib.h"
|
|
#include "lib/self_test.h"
|
|
|
|
class TestPrintf : public CxxTest::TestSuite
|
|
{
|
|
// Split some bits into separate functions, so we can get
|
|
// a legitimate va_list to pass to vsnprintf2:
|
|
|
|
void _test_truncate(int buffer_size, char* expected_output, int expected_return, /* char* input_string */...)
|
|
{
|
|
char buf[17] = "................"; // fill with dots so null-termination is made obvious
|
|
|
|
va_list ap;
|
|
va_start(ap, expected_return);
|
|
|
|
int ret = vsnprintf2(buf, buffer_size, "%s", ap);
|
|
|
|
TS_ASSERT_STR_EQUALS(buf, expected_output);
|
|
TS_ASSERT_EQUALS(ret, expected_return);
|
|
|
|
std::string past_buffer (buf + buffer_size);
|
|
TS_ASSERT(past_buffer.find_first_not_of('.') == past_buffer.npos);
|
|
|
|
va_end(ap);
|
|
}
|
|
|
|
void _test_sprintf(char* expected_output, char* format, ...)
|
|
{
|
|
char buf[256];
|
|
|
|
va_list ap;
|
|
va_start(ap, format);
|
|
|
|
vsnprintf2(buf, sizeof(buf), format, ap);
|
|
TS_ASSERT_STR_EQUALS(buf, expected_output);
|
|
|
|
va_end(ap);
|
|
}
|
|
|
|
public:
|
|
void test_truncate()
|
|
{
|
|
_test_truncate(8, "1234", 4, "1234");
|
|
_test_truncate(8, "1234567", 7, "1234567");
|
|
_test_truncate(8, "1234567", -1, "12345678");
|
|
_test_truncate(8, "1234567", -1, "123456789");
|
|
_test_truncate(8, "1234567", -1, "123456789abcdef");
|
|
}
|
|
|
|
void test_lld()
|
|
{
|
|
i64 z = 0;
|
|
i64 n = 65536;
|
|
_test_sprintf("0", "%lld", z);
|
|
_test_sprintf("65536", "%lld", n);
|
|
_test_sprintf("4294967296", "%lld", n*n);
|
|
_test_sprintf("281474976710656", "%lld", n*n*n);
|
|
_test_sprintf("-281474976710656", "%lld", -n*n*n);
|
|
_test_sprintf("123 456 281474976710656 789", "%d %d %lld %d", 123, 456, n*n*n, 789);
|
|
}
|
|
|
|
void test_pos()
|
|
{
|
|
_test_sprintf("a b", "%1$c %2$c", 'a', 'b');
|
|
_test_sprintf("b a", "%2$c %1$c", 'a', 'b');
|
|
}
|
|
|
|
void test_pos_lld()
|
|
{
|
|
_test_sprintf("1 2 3", "%1$d %2$lld %3$d", 1, (i64)2, 3);
|
|
_test_sprintf("2 1 3", "%2$lld %1$d %3$d", 1, (i64)2, 3);
|
|
}
|
|
};
|