Project

General

Profile

Bug #126 » 0005-Unittest-used-to-check-the-radix-memleak-located-at-.patch

a unittest that should increase the memory dramatically if the search have memleaks - Pablo Rincon, 04/12/2010 08:13 AM

View differences:

src/util-radix-tree.c
return result;
}
/**
* \test SCRadixTestIPV4NetblockInsertion15 insert a node and
* loop multiple times searching on it. Should always return true
* but the purposse of the test is to monitor the memory usage to
* detect memleaks (there was one on searching)
*/
int SCRadixTestIPV4NetblockInsertion15(void)
{
SCRadixTree *tree = NULL;
SCRadixNode *node = NULL;
struct sockaddr_in servaddr;
int result = 1;
tree = SCRadixCreateRadixTree(free, NULL);
bzero(&servaddr, sizeof(servaddr));
if (inet_pton(AF_INET, "192.168.0.0", &servaddr.sin_addr) <= 0)
return 0;
SCRadixAddKeyIPV4Netblock((uint8_t *)&servaddr.sin_addr, tree, NULL, 16);
uint64_t i = 0;
uint64_t limit = 100000;
/* test for the existance of a key */
bzero(&servaddr, sizeof(servaddr));
if (inet_pton(AF_INET, "192.168.128.53", &servaddr.sin_addr) <= 0)
return 0;
for (; i < limit; i++) {
result &= (SCRadixFindKeyIPV4BestMatch((uint8_t *)&servaddr.sin_addr, tree) != NULL);
}
SCRadixReleaseRadixTree(tree);
return result;
}
#endif
void SCRadixRegisterTests(void)
......
SCRadixTestIPV6NetblockInsertion13, 1);
UtRegisterTest("SCRadixTestIPV6NetblockInsertion14",
SCRadixTestIPV6NetblockInsertion14, 1);
UtRegisterTest("SCRadixTestIPV4NetblockInsertion15",
SCRadixTestIPV4NetblockInsertion15, 1);
#endif
return;
(2-2/3)