aboutsummaryrefslogtreecommitdiff
path: root/tests/test_str_isrelational.c
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@users.noreply.github.com>2020-03-24 12:35:30 -0400
committerGitHub <noreply@github.com>2020-03-24 12:35:30 -0400
commitae3eb38592cb40011fd026d3c7c64ebc022bedca (patch)
tree5b576d374cc2d12bc5593c8b09adaa25c4453346 /tests/test_str_isrelational.c
parentccaeb7092b5ad40b1b3833c987ba3ec4d47f0bb8 (diff)
parent239251d34af9137acf7e84c6969e118d3b0593c0 (diff)
downloadspmc-ae3eb38592cb40011fd026d3c7c64ebc022bedca.tar.gz
Merge pull request #2 from jhunkeler/ctest
Implement ctest testing
Diffstat (limited to 'tests/test_str_isrelational.c')
-rw-r--r--tests/test_str_isrelational.c27
1 files changed, 27 insertions, 0 deletions
diff --git a/tests/test_str_isrelational.c b/tests/test_str_isrelational.c
new file mode 100644
index 0000000..92c4803
--- /dev/null
+++ b/tests/test_str_isrelational.c
@@ -0,0 +1,27 @@
+#include "spm.h"
+#include "framework.h"
+
+const char *testFmt = "case: '%c': returned %d, expected %d\n";
+struct TestCase testCase[] = {
+ {.caseValue.character = '~', .truthValue.signed_integer = 1},
+ {.caseValue.character = '!', .truthValue.signed_integer = 1},
+ {.caseValue.character = '=', .truthValue.signed_integer = 1},
+ {.caseValue.character = '<', .truthValue.signed_integer = 1},
+ {.caseValue.character = '>', .truthValue.signed_integer = 1},
+ {.caseValue.character = 'u', .truthValue.signed_integer = 0},
+ {.caseValue.character = 'd', .truthValue.signed_integer = 0},
+ {.caseValue.character = 'l', .truthValue.signed_integer = 0},
+ {.caseValue.character = 'r', .truthValue.signed_integer = 0},
+ {.caseValue.character = 'b', .truthValue.signed_integer = 0},
+ {.caseValue.character = 'a', .truthValue.signed_integer = 0},
+ {.caseValue.character = '\n', .truthValue.signed_integer = 0},
+};
+size_t numCases = sizeof(testCase) / sizeof(struct TestCase);
+
+int main(int argc, char *argv[]) {
+ for (size_t i = 0; i < numCases; i++) {
+ int result = isrelational(testCase[i].caseValue.character);
+ myassert(result == testCase[i].truthValue.signed_integer, testFmt, testCase[i].caseValue.character, result, testCase[i].truthValue.signed_integer);
+ }
+ return 0;
+} \ No newline at end of file