aboutsummaryrefslogtreecommitdiff
path: root/tests/test_str_normalize_space.c
blob: 286353d434d1d7ca50b5f6f65ba5db07a2019016 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#include "spm.h"
#include "framework.h"

const char *testFmt = "case: '%s': returned '%s', expected '%s'\n";
struct TestCase testCase[] = {
        {.caseValue.sptr = "no extra whitespace in the string", .truthValue.sptr = "no extra whitespace in the string"},
        {.caseValue.sptr = "two  extra  spaces  in  the  string", .truthValue.sptr = "two extra spaces in the string"},
        {.caseValue.sptr = "three   extra   spaces   in   the   string", .truthValue.sptr = "three extra spaces in the string"},
        {.caseValue.sptr = "    leading    whitespace", .truthValue.sptr = "leading whitespace"},
        {.caseValue.sptr = "trailing     whitespace    ", .truthValue.sptr = "trailing whitespace"},
        {.caseValue.sptr = "    leading    and    trailing     whitespace    ", .truthValue.sptr = "leading and trailing whitespace"},
        {.caseValue.sptr = " varying  degrees           of    whitespace        everywhere ", .truthValue.sptr = "varying degrees of whitespace everywhere"},
        {.caseValue.sptr = "nowhitespace", .truthValue.sptr = "nowhitespace"},
        {.caseValue.sptr = NULL, .truthValue.sptr = NULL},
};
size_t numCases = sizeof(testCase) / sizeof(struct TestCase);

int main(int argc, char *argv[]) {
    for (size_t i = 0; i < numCases; i++) {
        if (testCase[i].caseValue.sptr == NULL && testCase[i].truthValue.sptr == NULL) {
            // null input is null output
            continue;
        }
        char *result = strdup(testCase[i].caseValue.sptr);
        normalize_space(result);
        myassert(strcmp(result, testCase[i].truthValue.sptr) == 0, testFmt, testCase[i].caseValue.sptr, result, testCase[i].truthValue.sptr);
    }
    return 0;
}