forked from github/server
add a happy test for mt_new.
refactor to not use strncpy.
This commit is contained in:
parent
d4dd9b4bc6
commit
47c8b20f68
4 changed files with 42 additions and 10 deletions
|
@ -65,6 +65,7 @@ int RunAllTests(int argc, char *argv[])
|
|||
ADD_SUITE(direction);
|
||||
ADD_SUITE(skill);
|
||||
ADD_SUITE(keyword);
|
||||
ADD_SUITE(message);
|
||||
ADD_SUITE(order);
|
||||
ADD_SUITE(race);
|
||||
/* util */
|
||||
|
|
|
@ -14,7 +14,7 @@ gamedata.test.c
|
|||
language.test.c
|
||||
# lists.test.c
|
||||
# log.test.c
|
||||
# message.test.c
|
||||
message.test.c
|
||||
# nrmessage.test.c
|
||||
parser.test.c
|
||||
password.test.c
|
||||
|
|
|
@ -87,19 +87,21 @@ message_type *mt_new(const char *name, const char *args[])
|
|||
for (i = 0; args[i]; ++i) {
|
||||
const char *x = args[i];
|
||||
const char *spos = strchr(x, ':');
|
||||
if (spos == NULL) {
|
||||
mtype->pnames[i] = _strdup(x);
|
||||
mtype->types[i] = NULL;
|
||||
struct arg_type *atype = NULL;
|
||||
if (spos != NULL) {
|
||||
atype = find_argtype(spos + 1);
|
||||
}
|
||||
if (!atype) {
|
||||
log_error("unknown argument type %s for message type %s\n", spos + 1, mtype->name);
|
||||
assert(atype);
|
||||
}
|
||||
else {
|
||||
char *cp = strncpy((char *)malloc(spos - x + 1), x, spos - x);
|
||||
char *cp;
|
||||
cp = malloc(spos - x + 1);
|
||||
memcpy(cp, x, spos - x);
|
||||
cp[spos - x] = '\0';
|
||||
mtype->pnames[i] = cp;
|
||||
mtype->types[i] = find_argtype(spos + 1);
|
||||
if (mtype->types[i] == NULL) {
|
||||
log_error("unknown argument type %s for message type %s\n", spos + 1, mtype->name);
|
||||
}
|
||||
assert(mtype->types[i]);
|
||||
mtype->types[i] = atype;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
29
src/util/message.test.c
Normal file
29
src/util/message.test.c
Normal file
|
@ -0,0 +1,29 @@
|
|||
#include <platform.h>
|
||||
#include "message.h"
|
||||
|
||||
#include <CuTest.h>
|
||||
#include <tests.h>
|
||||
|
||||
static void test_mt_new(CuTest *tc)
|
||||
{
|
||||
message_type *mt;
|
||||
test_setup();
|
||||
mt = mt_new_va("test", "name:string", "number:int", NULL);
|
||||
CuAssertPtrNotNull(tc, mt);
|
||||
CuAssertStrEquals(tc, "test", mt->name);
|
||||
CuAssertIntEquals(tc, 2, mt->nparameters);
|
||||
CuAssertPtrNotNull(tc, mt->pnames);
|
||||
CuAssertStrEquals(tc, "name", mt->pnames[0]);
|
||||
CuAssertStrEquals(tc, "number", mt->pnames[1]);
|
||||
CuAssertPtrNotNull(tc, mt->types);
|
||||
CuAssertStrEquals(tc, "string", mt->types[0]->name);
|
||||
CuAssertStrEquals(tc, "int", mt->types[1]->name);
|
||||
test_cleanup();
|
||||
}
|
||||
|
||||
CuSuite *get_message_suite(void)
|
||||
{
|
||||
CuSuite *suite = CuSuiteNew();
|
||||
SUITE_ADD_TEST(suite, test_mt_new);
|
||||
return suite;
|
||||
}
|
Loading…
Reference in a new issue