test-printf-format-fix.c revision ba1a5db879b08d2fefcb42160af67853cdfe7687
183bea41fa640dc8117f3eb45ff935cd81377a84Timo Sirainen/* Copyright (c) 2001-2017 Dovecot authors, see the included COPYING file */
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen/* Unit tests for printf-format-fix helper */
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen static const char *tests[] = {
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Hello world",
d176f84ce5ca2073f4dfbafb457b9c74f6bf0d76Timo Sirainen "Embedded %%, %u, %f, %s, etc. are OK",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Allow %#0- +s flags",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "duplicate flags in different args %0-123s %0-123s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Minimum length %9999s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Minimum length parameter %*s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Precision %.9999s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Precision %1.9999s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Precision parameter %1.*s %.*s",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Length modifiers %hd %hhd %ld %lld %Lg %jd %zd %td",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Specifiers %s %u %d %c %i %x %X %p %o %e %E %f %F %g %G %a %A",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "%%doesn't cause confusion in %%m and %%n",
cf0ad1a0bddb0787f3d7b408a96d721a8b2a98a3Timo Sirainen unsigned int i;
4d4d6d4745682790c20d759ba93dbea46b812c5dTimo Sirainen test_assert_idx(printf_format_fix_get_len(tests[i], &len)
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen static const char *tests[] = {
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "OK to have a trailing %m",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "%m can appear at the start too",
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen "Even %m in the middle with a confusing %%m elsewhere is OK",
b437874782ad048daa155e0ac863c2326c3f5e43Timo Sirainen unsigned int i;
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen unsigned int needlen;
b437874782ad048daa155e0ac863c2326c3f5e43Timo Sirainen unsigned int offs;
cf0ad1a0bddb0787f3d7b408a96d721a8b2a98a3Timo Sirainen test_assert_idx(memcmp(chgd, tests[i], offs) == 0, i);
cf0ad1a0bddb0787f3d7b408a96d721a8b2a98a3Timo Sirainen test_assert_idx(memcmp(chgd+offs, needle, needlen) == 0, i);
cf0ad1a0bddb0787f3d7b408a96d721a8b2a98a3Timo Sirainen test_assert_idx(strcmp(chgd+offs+needlen, tests[i]+offs+2) == 0, i);
cf0ad1a0bddb0787f3d7b408a96d721a8b2a98a3Timo Sirainen chgd = printf_format_fix_get_len(tests[i], &len);
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen test_assert_idx(memcmp(chgd, tests[i], offs) == 0, i);
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen test_assert_idx(memcmp(chgd+offs, needle, needlen) == 0, i);
7fe37c2b0e4cd2a39896ab16e47eb418a59e3934Timo Sirainen test_assert_idx(memcmp(chgd+offs+needlen, tests[i]+offs+2, len-needlen-offs) == 0, i);
0c22bef8f5b35c645de8affd8746307fc53bd222Timo Sirainen/* Want to test the panics too? go for it! */
78fa3c578c14ee8a612f86cf73b6181c7f16463fTimo Sirainenenum fatal_test_state fatal_printf_format_fix(unsigned int stage)
78fa3c578c14ee8a612f86cf73b6181c7f16463fTimo Sirainen static const struct {
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "no no no %-1234567890123n's with extra stuff", "Too large minimum field width" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "%m allowed once, but not twice: %m", "%m used twice" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "%m must not obscure a later %n", "%n modifier used" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "definitely can't have a tailing %", "Missing % specifier" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "Evil %**%n", "Unsupported 0x2a specifier" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "Evil %*#%99999$s", "Unsupported 0x23 specifier" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "No weird %% with %0%", "Unsupported 0x25 specifier" },
8451c4b5afc1ff5366438b2766f75b592c33e1ecTimo Sirainen { "No duplicate modifiers %00s", "Duplicate % flag '0'" },
78fa3c578c14ee8a612f86cf73b6181c7f16463fTimo Sirainen { "Minimum length can't be too long %10000s", "Too large minimum field width" },
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen { "Minimum length doesn't support %*1$s", "Unsupported 0x31 specifier" },
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen { "Precision can't be too long %.10000s", "Too large precision" },
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen { "Precision can't be too long %1.10000s", "Too large precision" },
8d3278a82b964217d95c340ec6f82037cdc59d19Timo Sirainen { "Precision doesn't support %1.-1s", "Unsupported 0x2d specifier" },
cd2ed64888b42b481cde6bb9548c8520516fa3e9Timo Sirainen /* let's crash! */
a3fe8c0c54d87822f4b4f8f0d10caac611861b2bTimo Sirainen test_expect_fatal_string(fatals[stage].expected_fatal);