forked from github/server
added test for removal of atributes.
refactor existing tests a bit, free up memory.
This commit is contained in:
parent
b37e8ac138
commit
a58afb9d15
1 changed files with 43 additions and 3 deletions
|
@ -12,6 +12,7 @@ static void test_attrib_new(CuTest * tc)
|
||||||
CuAssertPtrEquals(tc, 0, a->next);
|
CuAssertPtrEquals(tc, 0, a->next);
|
||||||
CuAssertPtrEquals(tc, 0, a->nexttype);
|
CuAssertPtrEquals(tc, 0, a->nexttype);
|
||||||
CuAssertPtrEquals(tc, (void *)a->type, (void *)&at_test);
|
CuAssertPtrEquals(tc, (void *)a->type, (void *)&at_test);
|
||||||
|
a_free(a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,18 +21,55 @@ static void test_attrib_add(CuTest * tc)
|
||||||
attrib_type at_foo = { "foo" };
|
attrib_type at_foo = { "foo" };
|
||||||
attrib_type at_bar = { "bar" };
|
attrib_type at_bar = { "bar" };
|
||||||
attrib *a, *alist = 0;
|
attrib *a, *alist = 0;
|
||||||
|
|
||||||
CuAssertPtrNotNull(tc, (a = a_new(&at_foo)));
|
CuAssertPtrNotNull(tc, (a = a_new(&at_foo)));
|
||||||
CuAssertPtrEquals(tc, a, a_add(&alist, a));
|
CuAssertPtrEquals(tc, a, a_add(&alist, a));
|
||||||
CuAssertPtrEquals(tc, a, alist);
|
CuAssertPtrEquals(tc, a, alist);
|
||||||
CuAssertPtrEquals(tc, 0, alist->nexttype);
|
|
||||||
|
|
||||||
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_foo))));
|
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_foo))));
|
||||||
CuAssertPtrEquals(tc, alist->next, a);
|
CuAssertPtrEquals_Msg(tc, "new attribute not added after existing", alist->next, a);
|
||||||
|
|
||||||
|
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_bar))));
|
||||||
|
CuAssertPtrEquals_Msg(tc, "new atribute not added at end of list", alist->next->next, a);
|
||||||
|
|
||||||
|
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_foo))));
|
||||||
|
CuAssertPtrEquals_Msg(tc, "messages not sorted by type", alist->next->next, a);
|
||||||
|
a_removeall(&alist, &at_foo);
|
||||||
|
a_removeall(&alist, &at_bar);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_attrib_remove(CuTest * tc)
|
||||||
|
{
|
||||||
|
attrib_type at_foo = { "foo" };
|
||||||
|
attrib *a, *alist = 0;
|
||||||
|
|
||||||
|
CuAssertPtrNotNull(tc, a_add(&alist, a_new(&at_foo)));
|
||||||
|
CuAssertPtrNotNull(tc, a = a_add(&alist, a_new(&at_foo)));
|
||||||
|
CuAssertIntEquals(tc, 1, a_remove(&alist, a));
|
||||||
|
CuAssertPtrNotNull(tc, alist);
|
||||||
|
CuAssertIntEquals(tc, 1, a_remove(&alist, alist));
|
||||||
|
CuAssertPtrEquals(tc, 0, alist);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_attrib_nexttype(CuTest * tc)
|
||||||
|
{
|
||||||
|
attrib_type at_foo = { "foo" };
|
||||||
|
attrib_type at_bar = { "bar" };
|
||||||
|
attrib *a, *alist = 0;
|
||||||
|
CuAssertPtrNotNull(tc, (a = a_new(&at_foo)));
|
||||||
|
CuAssertPtrEquals(tc, 0, a->nexttype);
|
||||||
|
CuAssertPtrEquals(tc, a, a_add(&alist, a));
|
||||||
|
CuAssertPtrEquals(tc, 0, alist->nexttype);
|
||||||
|
|
||||||
|
CuAssertPtrNotNull(tc, a_add(&alist, a_new(&at_foo)));
|
||||||
CuAssertPtrEquals(tc, 0, alist->nexttype);
|
CuAssertPtrEquals(tc, 0, alist->nexttype);
|
||||||
|
|
||||||
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_bar))));
|
CuAssertPtrNotNull(tc, (a = a_add(&alist, a_new(&at_bar))));
|
||||||
CuAssertPtrEquals(tc, alist->next->next, a);
|
|
||||||
CuAssertPtrEquals(tc, a, alist->nexttype);
|
CuAssertPtrEquals(tc, a, alist->nexttype);
|
||||||
|
CuAssertPtrEquals(tc, 0, a->nexttype);
|
||||||
|
|
||||||
|
a_removeall(&alist, &at_foo);
|
||||||
|
a_removeall(&alist, &at_bar);
|
||||||
}
|
}
|
||||||
|
|
||||||
CuSuite *get_attrib_suite(void)
|
CuSuite *get_attrib_suite(void)
|
||||||
|
@ -39,5 +77,7 @@ CuSuite *get_attrib_suite(void)
|
||||||
CuSuite *suite = CuSuiteNew();
|
CuSuite *suite = CuSuiteNew();
|
||||||
SUITE_ADD_TEST(suite, test_attrib_new);
|
SUITE_ADD_TEST(suite, test_attrib_new);
|
||||||
SUITE_ADD_TEST(suite, test_attrib_add);
|
SUITE_ADD_TEST(suite, test_attrib_add);
|
||||||
|
SUITE_ADD_TEST(suite, test_attrib_remove);
|
||||||
|
SUITE_ADD_TEST(suite, test_attrib_nexttype);
|
||||||
return suite;
|
return suite;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue