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
|
#include "spm.h"
#include "shell.h"
#include "framework.h"
const char *testFmt = "returned '%s', expected '%s'\n";
struct TestCase testCase[] = {
{.caseValue.sptr = "check this hash", .truthValue.sptr = "72a9728d7b00d42fe573d91d023e2ebe4fa2c3c5d38c67306cbcd4f5e410aa33"},
{.caseValue.sptr = "check this hash", .truthValue.sptr = "72a9728d7b00d42fe573d91d023e2ebe4fa2c3c5d38c67306cbcd4f5e410aa33"},
{.caseValue.sptr = "check this hash", .truthValue.sptr = "72a9728d7b00d42fe573d91d023e2ebe4fa2c3c5d38c67306cbcd4f5e410aa33"},
{.caseValue.sptr = "check this hash", .truthValue.sptr = "72a9728d7b00d42fe573d91d023e2ebe4fa2c3c5d38c67306cbcd4f5e410aa33"},
};
size_t numCases = sizeof(testCase) / sizeof(struct TestCase);
int main(int argc, char *argv[]) {
char filename[NAME_MAX] = {0};
sprintf(filename, "%s.%s.mock", basename(__FILE__), __FUNCTION__);
for (size_t i = 0; i < numCases; i++) {
char *result = NULL;
char *data = strdup(testCase[i].caseValue.sptr);
mock(filename, data, sizeof(char), strlen(testCase[i].caseValue.sptr));
result = sha256sum(filename);
myassert(strcmp(result, testCase[i].truthValue.sptr) == 0, testFmt, result, testCase[i].truthValue.sptr);
free(result);
free(data);
unlink(filename);
}
return 0;
}
|