summaryrefslogtreecommitdiffstats
path: root/tests/utils/utils_test.c
diff options
context:
space:
mode:
authorNeels Hofmeyr <neels@hofmeyr.de>2018-04-09 00:41:28 +0200
committerNeels Hofmeyr <nhofmeyr@sysmocom.de>2018-04-09 15:56:14 +0000
commit04eb56f146a6c0395645aa2537d7c29f1e234069 (patch)
tree6b52c23abae8096589f355e48c59e4f77577f06f /tests/utils/utils_test.c
parent5a9dbf81a2fdefff860657a9f131c50f9d0ce25f (diff)
add osmo_quote_str(),osmo_quote_str_buf() and test
Rationale: with osmo_escape_str(), you get the escaped contents of the string, but not so graceful handling of NULL strings. The caller needs to quote it, and for NULL strings not quote it. osmo_quote_str() is like osmo_escape_str() but always quotes a non-NULL string, and for a NULL string returns a literal NULL, i.e. it should (tm) give the exact C representation of a string. That's useful in testing, to show exactly what char* situation we have, without jumping through hoops like if (str) printf("\"%s\"", osmo_escape_str(str, -1)); else printf("NULL"); Copy the unit test for osmo_escape_str() and adjust. To indicate that the double quotes are returned by osmo_quote_str(), use single quotes in the test printf()s. I considered allowing to pick the quoting characters by further arguments, but that complicates things: we'd need to escape the quoting characters. Just hardcode double quotes like C. Change-Id: I6f1b3709b32c23fc52f70ad9ecc9439c62b02a12
Diffstat (limited to 'tests/utils/utils_test.c')
-rw-r--r--tests/utils/utils_test.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/utils/utils_test.c b/tests/utils/utils_test.c
index f358e9a5..a1243527 100644
--- a/tests/utils/utils_test.c
+++ b/tests/utils/utils_test.c
@@ -371,6 +371,60 @@ static void str_escape_test(void)
OSMO_ASSERT(out_buf[0] == 0x7f);
}
+static void str_quote_test(void)
+{
+ int i;
+ int j;
+ uint8_t in_buf[32];
+ char out_buf[11];
+ const char *printable = "printable";
+ const char *res;
+
+ printf("\nTesting string quoting\n");
+ printf("- all chars from 0 to 255 in batches of 16:\n");
+ in_buf[16] = '\0';
+ for (j = 0; j < 16; j++) {
+ for (i = 0; i < 16; i++)
+ in_buf[i] = (j << 4) | i;
+ printf("'%s'\n", osmo_quote_str((const char*)in_buf, 16));
+ }
+
+ printf("- nul terminated:\n");
+ printf("'%s'\n", osmo_quote_str("termi\nated", -1));
+
+ printf("- never passthru:\n");
+ res = osmo_quote_str(printable, -1);
+ if (res != printable)
+ printf("NOT passed through. '%s'\n", res);
+ else
+ printf("passed through unchanged '%s'\n", res);
+
+ printf("- zero length:\n");
+ printf("'%s'\n", osmo_quote_str("omitted", 0));
+
+ printf("- truncation when too long:\n");
+ memset(in_buf, 'x', sizeof(in_buf));
+ in_buf[0] = '\a';
+ in_buf[5] = 'E';
+ memset(out_buf, 0x7f, sizeof(out_buf));
+ printf("'%s'\n", osmo_quote_str_buf((const char *)in_buf, sizeof(in_buf), out_buf, 10));
+ OSMO_ASSERT(out_buf[10] == 0x7f);
+
+ printf("- always truncation, even when no escaping needed:\n");
+ memset(in_buf, 'x', sizeof(in_buf));
+ in_buf[6] = 'E'; /* dst has 10, less 2 quotes and nul, leaves 7, i.e. in[6] is last */
+ in_buf[20] = '\0';
+ memset(out_buf, 0x7f, sizeof(out_buf));
+ printf("'%s'\n", osmo_quote_str_buf((const char *)in_buf, -1, out_buf, 10));
+ OSMO_ASSERT(out_buf[0] == '"');
+
+ printf("- try to feed too little buf for quoting:\n");
+ printf("'%s'\n", osmo_quote_str_buf("", -1, out_buf, 2));
+
+ printf("- NULL string becomes a \"NULL\" literal:\n");
+ printf("'%s'\n", osmo_quote_str_buf(NULL, -1, out_buf, 10));
+}
+
int main(int argc, char **argv)
{
static const struct log_info log_info = {};
@@ -382,5 +436,6 @@ int main(int argc, char **argv)
test_is_hexstr();
bcd_test();
str_escape_test();
+ str_quote_test();
return 0;
}