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 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
|
#include <string.h>
#include "cmor.h"
int fail(int code, char *expect, char *got)
{
printf("failed test %d, expect '%s' got '%s'\n", code, expect, got);
return code;
}
int test_cmor_stringinstring(void)
{
printf("running cmor_stringinstring tests\n");
if (cmor_stringinstring("Inverted axis: rlat.", "Inverted axis: rlat")) {
/* should match */
} else {
printf("failed stringinstring test with period after string\n");
return 1;
}
}
int test_cat_unique_string(void)
{
char dest[CMOR_MAX_STRING];
char src[CMOR_MAX_STRING];
char expected[CMOR_MAX_STRING];
strcpy(dest, "");
strcpy(src, "rumble");
strcpy(expected, "rumble");
/* 1. simple test: add string to blank */
printf("running cat_unique_string tests\n");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(1, expected, dest);
}
/* 2. simple test: add string to itself. Should be identical to above */
strcpy(dest, "rumble");
strcpy(src, "rumble");
strcpy(expected, "rumble");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(2, expected, dest);
}
/* 3. simple test: add string to non-blank, unique */
strcpy(src, "jungle");
strcpy(expected, "rumble jungle");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(3, expected, dest);
}
/* 4. simple test: add string that exists within another word */
strcpy(dest, "rumble jungle");
strcpy(src, "umb");
strcpy(expected, "rumble jungle umb");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(4, expected, dest);
}
/* 5. simple test: add string to blank */
strcpy(dest, "rumble");
strcpy(src, "rum");
strcpy(expected, "rumble rum");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(5, expected, dest);
}
/* 6. simple test: add string to blank */
strcpy(dest, "rumble");
strcpy(src, "ble");
strcpy(expected, "rumble ble");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(6, expected, dest);
}
/* 7. simple test: add string to blank */
strcpy(dest, "rumble jungle happy");
strcpy(src, "ppy");
strcpy(expected, "rumble jungle happy ppy");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(7, expected, dest);
}
/* 8. simple test: add string to blank */
strcpy(dest, "rumble jungle happy");
strcpy(src, "gle");
strcpy(expected, "rumble jungle happy gle");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(8, expected, dest);
}
/* 9. simple test: add string to blank */
strcpy(dest, "rumble jungle happy");
strcpy(src, "jung");
strcpy(expected, "rumble jungle happy jung");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(9, expected, dest);
}
/* 10. simple test: add string to blank */
strcpy(dest, "rumble jumble ble");
strcpy(src, "ble");
strcpy(expected, "rumble jumble ble");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(10, expected, dest);
}
/* 11. simple test: add latest */
strcpy(dest, "rumble jumble");
strcpy(src, "jumble");
strcpy(expected, "rumble jumble");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(11, expected, dest);
}
/* 12. simple test: add latest */
strcpy(dest, "rumble jumble");
strcpy(src, "rumble");
strcpy(expected, "rumble jumble");
cmor_cat_unique_string(dest, src);
if (strcmp(dest, expected)) {
return fail(12, expected, dest);
}
return 0;
}
int main(int argc, char **argv)
{
test_cmor_stringinstring();
test_cat_unique_string();
}
|