r22279: add a lot more detailed strtoll() and strtoull() tests
[ira/wip.git] / source / lib / replace / test / testsuite.c
index e921a7fc97d9f2ce93329520acd7acd9cd20c5e1..2d068c559f3f3bb5a96d231a59f63249eb4844c8 100644 (file)
@@ -46,6 +46,7 @@
 #include "system/terminal.h"
 #include "system/time.h"
 #include "system/wait.h"
+#include "system/aio.h"
 
 #define TESTFILE "testfile.dat"
 
@@ -78,6 +79,7 @@ static int test_ftruncate(void)
                       (int)st.st_size, size);
                return false;
        }
+       unlink(TESTFILE);
        printf("success: ftruncate\n");
        return true;
 }
@@ -113,17 +115,31 @@ static int test_strlcpy(void)
 
 static int test_strlcat(void)
 {
-       /* FIXME */
-       return true;
-}
+       char tmp[10];
+       printf("test: strlcat\n");
+       strlcpy(tmp, "", sizeof(tmp));
+       if (strlcat(tmp, "bla", 3) != 3) {
+               printf("failure: strlcat [\ninvalid return code\n]\n");
+               return false;
+       }
+       if (strcmp(tmp, "bl") != 0) {
+               printf("failure: strlcat [\nexpected \"bl\", got \"%s\"\n]\n", 
+                          tmp);
+               return false;
+       }
 
-static int test_mktime(void)
-{
-       /* FIXME */
+       strlcpy(tmp, "da", sizeof(tmp));
+       if (strlcat(tmp, "me", 4) != 4) {
+               printf("failure: strlcat [\nexpected \"dam\", got \"%s\"\n]\n",
+                          tmp);
+               return false;
+       }
+
+       printf("success: strlcat\n");
        return true;
 }
 
-static int test_innetgr(void)
+static int test_mktime(void)
 {
        /* FIXME */
        return true;
@@ -143,7 +159,16 @@ static int test_memmove(void)
 
 static int test_strdup(void)
 {
-       /* FIXME */
+       char *x;
+       printf("test: strdup\n");
+       x = strdup("bla");
+       if (strcmp("bla", x) != 0) {
+               printf("failure: strdup [\nfailed: expected \"bla\", got \"%s\"\n]\n",
+                          x);
+               return false;
+       }
+       free(x);
+       printf("success: strdup\n");
        return true;
 }      
 
@@ -169,19 +194,109 @@ static int test_timegm(void)
 
 static int test_setenv(void)
 {
-       /* FIXME */
+#define TEST_SETENV(key, value, overwrite, result) do { \
+       int _ret; \
+       char *_v; \
+       _ret = setenv(key, value, overwrite); \
+       if (_ret != 0) { \
+               printf("failure: setenv [\n" \
+                       "setenv(%s, %s, %d) failed\n" \
+                       "]\n", \
+                       key, value, overwrite); \
+               return false; \
+       } \
+       _v=getenv(key); \
+       if (!_v) { \
+               printf("failure: setenv [\n" \
+                       "getenv(%s) returned NULL\n" \
+                       "]\n", \
+                       key); \
+               return false; \
+       } \
+       if (strcmp(result, _v) != 0) { \
+               printf("failure: setenv [\n" \
+                       "getenv(%s): '%s' != '%s'\n" \
+                       "]\n", \
+                       key, result, _v); \
+               return false; \
+       } \
+} while(0)
+
+#define TEST_UNSETENV(key) do { \
+       char *_v; \
+       unsetenv(key); \
+       _v=getenv(key); \
+       if (_v) { \
+               printf("failure: setenv [\n" \
+                       "getenv(%s): NULL != '%s'\n" \
+                       "]\n", \
+                       SETENVTEST_KEY, _v); \
+               return false; \
+       } \
+} while (0)
+
+#define SETENVTEST_KEY "SETENVTESTKEY"
+#define SETENVTEST_VAL "SETENVTESTVAL"
+
+       printf("test: setenv\n");
+       TEST_SETENV(SETENVTEST_KEY, SETENVTEST_VAL"1", 0, SETENVTEST_VAL"1");
+       TEST_SETENV(SETENVTEST_KEY, SETENVTEST_VAL"2", 0, SETENVTEST_VAL"1");
+       TEST_SETENV(SETENVTEST_KEY, SETENVTEST_VAL"3", 1, SETENVTEST_VAL"3");
+       TEST_SETENV(SETENVTEST_KEY, SETENVTEST_VAL"4", 1, SETENVTEST_VAL"4");
+       TEST_UNSETENV(SETENVTEST_KEY);
+       TEST_UNSETENV(SETENVTEST_KEY);
+       TEST_SETENV(SETENVTEST_KEY, SETENVTEST_VAL"5", 0, SETENVTEST_VAL"5");
+       TEST_UNSETENV(SETENVTEST_KEY);
+       TEST_UNSETENV(SETENVTEST_KEY);
+       printf("success: setenv\n");
        return true;
 }
 
 static int test_strndup(void)
 {
-       /* FIXME */
+       char *x;
+       printf("test: strndup\n");
+       x = strndup("bla", 0);
+       if (strcmp(x, "") != 0) {
+               printf("failure: strndup [\ninvalid\n]\n");
+               return false;
+       }
+       free(x);
+       x = strndup("bla", 2);
+       if (strcmp(x, "bl") != 0) {
+               printf("failure: strndup [\ninvalid\n]\n");
+               return false;
+       }
+       free(x);
+       x = strndup("bla", 10);
+       if (strcmp(x, "bla") != 0) {
+               printf("failure: strndup [\ninvalid\n]\n");
+               return false;
+       }
+       free(x);
+       printf("success: strndup\n");
        return true;
 }
 
 static int test_strnlen(void)
 {
-       /* FIXME */
+       printf("test: strnlen\n");
+       if (strnlen("bla", 2) != 2) {
+               printf("failure: strnlen [\nunexpected length\n]\n");
+               return false;
+       }
+
+       if (strnlen("some text\n", 0) != 0) {
+               printf("failure: strnlen [\nunexpected length\n]\n");
+               return false;
+       }
+
+       if (strnlen("some text", 20) != 9) {
+               printf("failure: strnlen [\nunexpected length\n]\n");
+               return false;
+       }
+
+       printf("success: strnlen\n");
        return true;
 }
 
@@ -205,13 +320,43 @@ static int test_setegid(void)
 
 static int test_asprintf(void)
 {
-       /* FIXME */
+       char *x;
+       printf("test: asprintf\n");
+       if (asprintf(&x, "%d", 9) != 1) {
+               printf("failure: asprintf [\ngenerate asprintf\n]\n");
+               return false;
+       }
+       if (strcmp(x, "9") != 0) {
+               printf("failure: asprintf [\ngenerate asprintf\n]\n");
+               return false;
+       }
+       if (asprintf(&x, "dat%s", "a") != 4) {
+               printf("failure: asprintf [\ngenerate asprintf\n]\n");
+               return false;
+       }
+       if (strcmp(x, "data") != 0) {
+               printf("failure: asprintf [\ngenerate asprintf\n]\n");
+               return false;
+       }
+       printf("success: asprintf\n");
        return true;
 }
 
 static int test_snprintf(void)
 {
-       /* FIXME */
+       char tmp[10];
+       printf("test: snprintf\n");
+       if (snprintf(tmp, 3, "foo%d", 9) != 4) {
+               printf("failure: snprintf [\nsnprintf return code failed\n]\n");
+               return false;
+       }
+
+       if (strcmp(tmp, "fo") != 0) {
+               printf("failure: snprintf [\nsnprintf failed\n]\n");
+               return false;
+       }
+
+       printf("success: snprintf\n");
        return true;
 }
 
@@ -284,7 +429,14 @@ static int test_strerror(void)
 
 static int test_errno(void)
 {
-       /* FIXME */
+       printf("test: errno\n");
+       errno = 3;
+       if (errno != 3) {
+               printf("failure: errno [\nerrno failed\n]\n");
+               return false;
+       }
+
+       printf("success: errno\n");
        return true;
 }
 
@@ -324,15 +476,275 @@ static int test_inet_ntoa(void)
        return true;
 }
 
+#define TEST_STRTO_X(type,fmt,func,str,base,res,diff,rrnoo) do {\
+       type _v; \
+       char _s[64]; \
+       char *_p = NULL;\
+       char *_ep = NULL; \
+       strlcpy(_s, str, sizeof(_s));\
+       if (diff >= 0) { \
+               _ep = &_s[diff]; \
+       } \
+       errno = 0; \
+       _v = func(_s, &_p, base); \
+       if (errno != rrnoo) { \
+               printf("failure: %s [\n" \
+                      "\t%s\n" \
+                      "\t%s(\"%s\",%d,%d): " fmt " (=/!)= " fmt "\n" \
+                      "\terrno: %d != %d\n" \
+                      "]\n", \
+                       __STRING(func), __location__, __STRING(func), \
+                      str, diff, base, res, _v, rrnoo, errno); \
+               return false; \
+       } else if (_v != res) { \
+               printf("failure: %s [\n" \
+                      "\t%s\n" \
+                      "\t%s(\"%s\",%d,%d): " fmt " != " fmt "\n" \
+                      "]\n", \
+                      __STRING(func), __location__, __STRING(func), \
+                      str, diff, base, res, _v); \
+               return false; \
+       } else if (_p != _ep) { \
+               printf("failure: %s [\n" \
+                      "\t%s\n" \
+                      "\t%s(\"%s\",%d,%d): " fmt " (=/!)= " fmt "\n" \
+                      "\tptr: %p - %p = %d != %d\n" \
+                      "]\n", \
+                      __STRING(func), __location__, __STRING(func), \
+                      str, diff, base, res, _v, _ep, _p, diff - (_ep - _p), diff); \
+               return false; \
+       } \
+} while (0)
+
 static int test_strtoll(void)
 {
-       /* FIXME */
+       printf("test: strtoll\n");
+
+#define TEST_STRTOLL(str,base,res,diff,errnoo) TEST_STRTO_X(int64_t, "%lld", strtoll,str,base,res,diff,errnoo)
+
+       TEST_STRTOLL("15",      10,     15LL,   2, 0);
+       TEST_STRTOLL("  15",    10,     15LL,   4, 0);
+       TEST_STRTOLL("15",      0,      15LL,   2, 0);
+       TEST_STRTOLL(" 15 ",    0,      15LL,   3, 0);
+       TEST_STRTOLL("+15",     10,     15LL,   3, 0);
+       TEST_STRTOLL("  +15",   10,     15LL,   5, 0);
+       TEST_STRTOLL("+15",     0,      15LL,   3, 0);
+       TEST_STRTOLL(" +15 ",   0,      15LL,   4, 0);
+       TEST_STRTOLL("-15",     10,     -15LL,  3, 0);
+       TEST_STRTOLL("  -15",   10,     -15LL,  5, 0);
+       TEST_STRTOLL("-15",     0,      -15LL,  3, 0);
+       TEST_STRTOLL(" -15 ",   0,      -15LL,  4, 0);
+       TEST_STRTOLL("015",     10,     15LL,   3, 0);
+       TEST_STRTOLL("  015",   10,     15LL,   5, 0);
+       TEST_STRTOLL("015",     0,      13LL,   3, 0);
+       TEST_STRTOLL("  015",   0,      13LL,   5, 0);
+       TEST_STRTOLL("0x15",    10,     0LL,    1, 0);
+       TEST_STRTOLL("  0x15",  10,     0LL,    3, 0);
+       TEST_STRTOLL("0x15",    0,      21LL,   4, 0);
+       TEST_STRTOLL("  0x15",  0,      21LL,   6, 0);
+
+       TEST_STRTOLL("10",      16,     16LL,   2, 0);
+       TEST_STRTOLL("  10 ",   16,     16LL,   4, 0);
+       TEST_STRTOLL("0x10",    16,     16LL,   4, 0);
+       TEST_STRTOLL("0x10",    0,      16LL,   4, 0);
+       TEST_STRTOLL(" 0x10 ",  0,      16LL,   5, 0);
+       TEST_STRTOLL("+10",     16,     16LL,   3, 0);
+       TEST_STRTOLL("  +10 ",  16,     16LL,   5, 0);
+       TEST_STRTOLL("+0x10",   16,     16LL,   5, 0);
+       TEST_STRTOLL("+0x10",   0,      16LL,   5, 0);
+       TEST_STRTOLL(" +0x10 ", 0,      16LL,   6, 0);
+       TEST_STRTOLL("-10",     16,     -16LL,  3, 0);
+       TEST_STRTOLL("  -10 ",  16,     -16LL,  5, 0);
+       TEST_STRTOLL("-0x10",   16,     -16LL,  5, 0);
+       TEST_STRTOLL("-0x10",   0,      -16LL,  5, 0);
+       TEST_STRTOLL(" -0x10 ", 0,      -16LL,  6, 0);
+       TEST_STRTOLL("010",     16,     16LL,   3, 0);
+       TEST_STRTOLL("  010 ",  16,     16LL,   5, 0);
+       TEST_STRTOLL("-010",    16,     -16LL,  4, 0);
+
+       TEST_STRTOLL("11",      8,      9LL,    2, 0);
+       TEST_STRTOLL("011",     8,      9LL,    3, 0);
+       TEST_STRTOLL("011",     0,      9LL,    3, 0);
+       TEST_STRTOLL("-11",     8,      -9LL,   3, 0);
+       TEST_STRTOLL("-011",    8,      -9LL,   4, 0);
+       TEST_STRTOLL("-011",    0,      -9LL,   4, 0);
+
+       TEST_STRTOLL("011",     8,      9LL,    3, 0);
+       TEST_STRTOLL("011",     0,      9LL,    3, 0);
+       TEST_STRTOLL("-11",     8,      -9LL,   3, 0);
+       TEST_STRTOLL("-011",    8,      -9LL,   4, 0);
+       TEST_STRTOLL("-011",    0,      -9LL,   4, 0);
+
+       TEST_STRTOLL("Text",    0,      0LL,    0, 0);
+
+       TEST_STRTOLL("9223372036854775807",     10,     9223372036854775807LL,  19, 0);
+       TEST_STRTOLL("9223372036854775807",     0,      9223372036854775807LL,  19, 0);
+       TEST_STRTOLL("9223372036854775808",     0,      9223372036854775807LL,  19, ERANGE);
+       TEST_STRTOLL("9223372036854775808",     10,     9223372036854775807LL,  19, ERANGE);
+       TEST_STRTOLL("0x7FFFFFFFFFFFFFFF",      0,      9223372036854775807LL,  18, 0);
+       TEST_STRTOLL("0x7FFFFFFFFFFFFFFF",      16,     9223372036854775807LL,  18, 0);
+       TEST_STRTOLL("7FFFFFFFFFFFFFFF",        16,     9223372036854775807LL,  16, 0);
+       TEST_STRTOLL("0x8000000000000000",      0,      9223372036854775807LL,  18, ERANGE);
+       TEST_STRTOLL("0x8000000000000000",      16,     9223372036854775807LL,  18, ERANGE);
+       TEST_STRTOLL("80000000000000000",       16,     9223372036854775807LL,  17, ERANGE);
+       TEST_STRTOLL("0777777777777777777777",  0,      9223372036854775807LL,  22, 0);
+       TEST_STRTOLL("0777777777777777777777",  8,      9223372036854775807LL,  22, 0);
+       TEST_STRTOLL("777777777777777777777",   8,      9223372036854775807LL,  21, 0);
+       TEST_STRTOLL("01000000000000000000000", 0,      9223372036854775807LL,  23, ERANGE);
+       TEST_STRTOLL("01000000000000000000000", 8,      9223372036854775807LL,  23, ERANGE);
+       TEST_STRTOLL("1000000000000000000000",  8,      9223372036854775807LL,  22, ERANGE);
+
+       TEST_STRTOLL("-9223372036854775808",    10,     -9223372036854775807LL -1,      20, 0);
+       TEST_STRTOLL("-9223372036854775808",    0,      -9223372036854775807LL -1,      20, 0);
+       TEST_STRTOLL("-9223372036854775809",    0,      -9223372036854775807LL -1,      20, ERANGE);
+       TEST_STRTOLL("-9223372036854775809",    10,     -9223372036854775807LL -1,      20, ERANGE);
+       TEST_STRTOLL("-0x8000000000000000",     0,      -9223372036854775807LL -1,      19, 0);
+       TEST_STRTOLL("-0x8000000000000000",     16,     -9223372036854775807LL -1,      19, 0);
+       TEST_STRTOLL("-8000000000000000",       16,     -9223372036854775807LL -1,      17, 0);
+       TEST_STRTOLL("-0x8000000000000001",     0,      -9223372036854775807LL -1,      19, ERANGE);
+       TEST_STRTOLL("-0x8000000000000001",     16,     -9223372036854775807LL -1,      19, ERANGE);
+       TEST_STRTOLL("-80000000000000001",      16,     -9223372036854775807LL -1,      18, ERANGE);
+       TEST_STRTOLL("-01000000000000000000000",0,      -9223372036854775807LL -1,      24, 0);
+       TEST_STRTOLL("-01000000000000000000000",8,      -9223372036854775807LL -1,      24, 0);
+       TEST_STRTOLL("-1000000000000000000000", 8,      -9223372036854775807LL -1,      23, 0);
+       TEST_STRTOLL("-01000000000000000000001",0,      -9223372036854775807LL -1,      24, ERANGE);
+       TEST_STRTOLL("-01000000000000000000001",8,      -9223372036854775807LL -1,      24, ERANGE);
+       TEST_STRTOLL("-1000000000000000000001", 8,      -9223372036854775807LL -1,      23, ERANGE);
+
+       printf("success: strtoll\n");
        return true;
 }
 
 static int test_strtoull(void)
 {
-       /* FIXME */
+       printf("test: strtoull\n");
+
+#define TEST_STRTOULL(str,base,res,diff,errnoo) TEST_STRTO_X(uint64_t,"%llu",strtoull,str,base,res,diff,errnoo)
+
+       TEST_STRTOULL("15",     10,     15LLU,  2, 0);
+       TEST_STRTOULL("  15",   10,     15LLU,  4, 0);
+       TEST_STRTOULL("15",     0,      15LLU,  2, 0);
+       TEST_STRTOULL(" 15 ",   0,      15LLU,  3, 0);
+       TEST_STRTOULL("+15",    10,     15LLU,  3, 0);
+       TEST_STRTOULL("  +15",  10,     15LLU,  5, 0);
+       TEST_STRTOULL("+15",    0,      15LLU,  3, 0);
+       TEST_STRTOULL(" +15 ",  0,      15LLU,  4, 0);
+       TEST_STRTOULL("-15",    10,     18446744073709551601LLU,        3, 0);
+       TEST_STRTOULL("  -15",  10,     18446744073709551601LLU,        5, 0);
+       TEST_STRTOULL("-15",    0,      18446744073709551601LLU,        3, 0);
+       TEST_STRTOULL(" -15 ",  0,      18446744073709551601LLU,        4, 0);
+       TEST_STRTOULL("015",    10,     15LLU,  3, 0);
+       TEST_STRTOULL("  015",  10,     15LLU,  5, 0);
+       TEST_STRTOULL("015",    0,      13LLU,  3, 0);
+       TEST_STRTOULL("  015",  0,      13LLU,  5, 0);
+       TEST_STRTOULL("0x15",   10,     0LLU,   1, 0);
+       TEST_STRTOULL("  0x15", 10,     0LLU,   3, 0);
+       TEST_STRTOULL("0x15",   0,      21LLU,  4, 0);
+       TEST_STRTOULL("  0x15", 0,      21LLU,  6, 0);
+
+       TEST_STRTOULL("10",     16,     16LLU,  2, 0);
+       TEST_STRTOULL("  10 ",  16,     16LLU,  4, 0);
+       TEST_STRTOULL("0x10",   16,     16LLU,  4, 0);
+       TEST_STRTOULL("0x10",   0,      16LLU,  4, 0);
+       TEST_STRTOULL(" 0x10 ", 0,      16LLU,  5, 0);
+       TEST_STRTOULL("+10",    16,     16LLU,  3, 0);
+       TEST_STRTOULL("  +10 ", 16,     16LLU,  5, 0);
+       TEST_STRTOULL("+0x10",  16,     16LLU,  5, 0);
+       TEST_STRTOULL("+0x10",  0,      16LLU,  5, 0);
+       TEST_STRTOULL(" +0x10 ",        0,      16LLU,  6, 0);
+       TEST_STRTOULL("-10",    16,     -16LLU, 3, 0);
+       TEST_STRTOULL("  -10 ", 16,     -16LLU, 5, 0);
+       TEST_STRTOULL("-0x10",  16,     -16LLU, 5, 0);
+       TEST_STRTOULL("-0x10",  0,      -16LLU, 5, 0);
+       TEST_STRTOULL(" -0x10 ",        0,      -16LLU, 6, 0);
+       TEST_STRTOULL("010",    16,     16LLU,  3, 0);
+       TEST_STRTOULL("  010 ", 16,     16LLU,  5, 0);
+       TEST_STRTOULL("-010",   16,     -16LLU, 4, 0);
+
+       TEST_STRTOULL("11",     8,      9LLU,   2, 0);
+       TEST_STRTOULL("011",    8,      9LLU,   3, 0);
+       TEST_STRTOULL("011",    0,      9LLU,   3, 0);
+       TEST_STRTOULL("-11",    8,      -9LLU,  3, 0);
+       TEST_STRTOULL("-011",   8,      -9LLU,  4, 0);
+       TEST_STRTOULL("-011",   0,      -9LLU,  4, 0);
+
+       TEST_STRTOULL("011",    8,      9LLU,   3, 0);
+       TEST_STRTOULL("011",    0,      9LLU,   3, 0);
+       TEST_STRTOULL("-11",    8,      -9LLU,  3, 0);
+       TEST_STRTOULL("-011",   8,      -9LLU,  4, 0);
+       TEST_STRTOULL("-011",   0,      -9LLU,  4, 0);
+
+       TEST_STRTOULL("Text",   0,      0LLU,   0, 0);
+
+       TEST_STRTOULL("9223372036854775807",    10,     9223372036854775807LLU, 19, 0);
+       TEST_STRTOULL("9223372036854775807",    0,      9223372036854775807LLU, 19, 0);
+       TEST_STRTOULL("9223372036854775808",    0,      9223372036854775808LLU, 19, 0);
+       TEST_STRTOULL("9223372036854775808",    10,     9223372036854775808LLU, 19, 0);
+       TEST_STRTOULL("0x7FFFFFFFFFFFFFFF",     0,      9223372036854775807LLU, 18, 0);
+       TEST_STRTOULL("0x7FFFFFFFFFFFFFFF",     16,     9223372036854775807LLU, 18, 0);
+       TEST_STRTOULL("7FFFFFFFFFFFFFFF",       16,     9223372036854775807LLU, 16, 0);
+       TEST_STRTOULL("0x8000000000000000",     0,      9223372036854775808LLU, 18, 0);
+       TEST_STRTOULL("0x8000000000000000",     16,     9223372036854775808LLU, 18, 0);
+       TEST_STRTOULL("8000000000000000",       16,     9223372036854775808LLU, 16, 0);
+       TEST_STRTOULL("0777777777777777777777", 0,      9223372036854775807LLU, 22, 0);
+       TEST_STRTOULL("0777777777777777777777", 8,      9223372036854775807LLU, 22, 0);
+       TEST_STRTOULL("777777777777777777777",  8,      9223372036854775807LLU, 21, 0);
+       TEST_STRTOULL("01000000000000000000000",0,      9223372036854775808LLU, 23, 0);
+       TEST_STRTOULL("01000000000000000000000",8,      9223372036854775808LLU, 23, 0);
+       TEST_STRTOULL("1000000000000000000000", 8,      9223372036854775808LLU, 22, 0);
+
+       TEST_STRTOULL("-9223372036854775808",   10,     9223372036854775808LLU, 20, 0);
+       TEST_STRTOULL("-9223372036854775808",   0,      9223372036854775808LLU, 20, 0);
+       TEST_STRTOULL("-9223372036854775809",   0,      9223372036854775807LLU, 20, 0);
+       TEST_STRTOULL("-9223372036854775809",   10,     9223372036854775807LLU, 20, 0);
+       TEST_STRTOULL("-0x8000000000000000",    0,      9223372036854775808LLU, 19, 0);
+       TEST_STRTOULL("-0x8000000000000000",    16,     9223372036854775808LLU, 19, 0);
+       TEST_STRTOULL("-8000000000000000",      16,     9223372036854775808LLU, 17, 0);
+       TEST_STRTOULL("-0x8000000000000001",    0,      9223372036854775807LLU, 19, 0);
+       TEST_STRTOULL("-0x8000000000000001",    16,     9223372036854775807LLU, 19, 0);
+       TEST_STRTOULL("-8000000000000001",      16,     9223372036854775807LLU, 17, 0);
+       TEST_STRTOULL("-01000000000000000000000",0,     9223372036854775808LLU, 24, 0);
+       TEST_STRTOULL("-01000000000000000000000",8,     9223372036854775808LLU, 24, 0);
+       TEST_STRTOULL("-1000000000000000000000",8,      9223372036854775808LLU, 23, 0);
+       TEST_STRTOULL("-01000000000000000000001",0,     9223372036854775807LLU, 24, 0);
+       TEST_STRTOULL("-01000000000000000000001",8,     9223372036854775807LLU, 24, 0);
+       TEST_STRTOULL("-1000000000000000000001",8,      9223372036854775807LLU, 23, 0);
+
+       TEST_STRTOULL("18446744073709551615",   0,      18446744073709551615LLU,        20, 0);
+       TEST_STRTOULL("18446744073709551615",   10,     18446744073709551615LLU,        20, 0);
+       TEST_STRTOULL("18446744073709551616",   0,      18446744073709551615LLU,        20, ERANGE);
+       TEST_STRTOULL("18446744073709551616",   10,     18446744073709551615LLU,        20, ERANGE);
+       TEST_STRTOULL("0xFFFFFFFFFFFFFFFF",     0,      18446744073709551615LLU,        18, 0);
+       TEST_STRTOULL("0xFFFFFFFFFFFFFFFF",     16,     18446744073709551615LLU,        18, 0);
+       TEST_STRTOULL("FFFFFFFFFFFFFFFF",       16,     18446744073709551615LLU,        16, 0);
+       TEST_STRTOULL("0x10000000000000000",    0,      18446744073709551615LLU,        19, ERANGE);
+       TEST_STRTOULL("0x10000000000000000",    16,     18446744073709551615LLU,        19, ERANGE);
+       TEST_STRTOULL("10000000000000000",      16,     18446744073709551615LLU,        17, ERANGE);
+       TEST_STRTOULL("01777777777777777777777",0,      18446744073709551615LLU,        23, 0);
+       TEST_STRTOULL("01777777777777777777777",8,      18446744073709551615LLU,        23, 0);
+       TEST_STRTOULL("1777777777777777777777", 8,      18446744073709551615LLU,        22, 0);
+       TEST_STRTOULL("02000000000000000000000",0,      18446744073709551615LLU,        23, ERANGE);
+       TEST_STRTOULL("02000000000000000000000",8,      18446744073709551615LLU,        23, ERANGE);
+       TEST_STRTOULL("2000000000000000000000", 8,      18446744073709551615LLU,        22, ERANGE);
+
+       TEST_STRTOULL("-18446744073709551615",  0,      1LLU,                           21, 0);
+       TEST_STRTOULL("-18446744073709551615",  10,     1LLU,                           21, 0);
+       TEST_STRTOULL("-18446744073709551616",  0,      18446744073709551615LLU,        21, ERANGE);
+       TEST_STRTOULL("-18446744073709551616",  10,     18446744073709551615LLU,        21, ERANGE);
+       TEST_STRTOULL("-0xFFFFFFFFFFFFFFFF",    0,      1LLU,                           19, 0);
+       TEST_STRTOULL("-0xFFFFFFFFFFFFFFFF",    16,     1LLU,                           19, 0);
+       TEST_STRTOULL("-FFFFFFFFFFFFFFFF",      16,     1LLU,                           17, 0);
+       TEST_STRTOULL("-0x10000000000000000",   0,      18446744073709551615LLU,        20, ERANGE);
+       TEST_STRTOULL("-0x10000000000000000",   16,     18446744073709551615LLU,        20, ERANGE);
+       TEST_STRTOULL("-10000000000000000",     16,     18446744073709551615LLU,        18, ERANGE);
+       TEST_STRTOULL("-01777777777777777777777",0,     1LLU,                           24, 0);
+       TEST_STRTOULL("-01777777777777777777777",8,     1LLU,                           24, 0);
+       TEST_STRTOULL("-1777777777777777777777",8,      1LLU,                           23, 0);
+       TEST_STRTOULL("-02000000000000000000000",0,     18446744073709551615LLU,        24, ERANGE);
+       TEST_STRTOULL("-02000000000000000000000",8,     18446744073709551615LLU,        24, ERANGE);
+       TEST_STRTOULL("-2000000000000000000000",8,      18446744073709551615LLU,        23, ERANGE);
+
+       printf("success: strtuoll\n");
        return true;
 }
 
@@ -360,23 +772,46 @@ static int test_va_copy(void)
 
 static int test_FUNCTION(void)
 {
-       /* FIXME: test __FUNCTION__ macro */
+       printf("test: FUNCTION\n");
+       if (strcmp(__FUNCTION__, "test_FUNCTION") != 0) {
+               printf("failure: FAILURE [\nFAILURE invalid\n]\n");
+               return false;
+       }
+       printf("success: FUNCTION\n");
        return true;
 }
 
 static int test_MIN(void)
 {
-       /* FIXME */
+       printf("test: MIN\n");
+       if (MIN(20, 1) != 1) {
+               printf("failure: MIN [\nMIN invalid\n]\n");
+               return false;
+       }
+       if (MIN(1, 20) != 1) {
+               printf("failure: MIN [\nMIN invalid\n]\n");
+               return false;
+       }
+       printf("success: MIN\n");
        return true;
 }
 
 static int test_MAX(void)
 {
-       /* FIXME */
+       printf("test: MAX\n");
+       if (MAX(20, 1) != 20) {
+               printf("failure: MAX [\nMAX invalid\n]\n");
+               return false;
+       }
+       if (MAX(1, 20) != 20) {
+               printf("failure: MAX [\nMAX invalid\n]\n");
+               return false;
+       }
+       printf("success: MAX\n");
        return true;
 }
 
-static bool test_socketpair(void)
+static int test_socketpair(void)
 {
        int sock[2];
        char buf[20];
@@ -390,14 +825,14 @@ static bool test_socketpair(void)
                return false;
        }
 
-       if (write(sock[0], "automatisch", 12) == -1) {
+       if (write(sock[1], "automatisch", 12) == -1) {
                printf("failure: socketpair [\n"
                           "write() failed: %s\n"
                           "]\n", strerror(errno));
                return false;
        }
 
-       if (read(sock[1], buf, 12) == -1) {
+       if (read(sock[0], buf, 12) == -1) {
                printf("failure: socketpair [\n"
                           "read() failed: %s\n"
                           "]\n", strerror(errno));
@@ -416,16 +851,21 @@ static bool test_socketpair(void)
        return true;
 }
 
-struct torture_context;
+extern int libreplace_test_strptime(void);
+
+static int test_strptime(void)
+{
+       return libreplace_test_strptime();
+}
 
-int main()
+struct torture_context;
+bool torture_local_replace(struct torture_context *ctx)
 {
        bool ret = true;
        ret &= test_ftruncate();
        ret &= test_strlcpy();
        ret &= test_strlcat();
        ret &= test_mktime();
-       ret &= test_innetgr();
        ret &= test_initgroups();
        ret &= test_memmove();
        ret &= test_strdup();
@@ -458,15 +898,23 @@ int main()
        ret &= test_getpass();
        ret &= test_inet_ntoa();
        ret &= test_strtoll();
-       ret &= test_strtoll();
        ret &= test_strtoull();
        ret &= test_va_copy();
        ret &= test_FUNCTION();
        ret &= test_MIN();
        ret &= test_MAX();
        ret &= test_socketpair();
+       ret &= test_strptime();
 
+       return ret;
+}
+
+#if _SAMBA_BUILD_<4
+int main(void)
+{
+       bool ret = torture_local_replace(NULL);
        if (ret) 
                return 0;
        return -1;
 }
+#endif