tstRTList.cpp revision 99dfe084aaa87733b2e26f5f9a86054d0461ff60
/* $Id$ */
/** @file
* IPRT Testcase - List interface.
*/
/*
* Copyright (C) 2010 Sun Microsystems, Inc.
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
*
* The contents of this file may alternatively be used under the terms
* of the Common Development and Distribution License Version 1.0
* (CDDL) only, as it comes in the "COPYING.CDDL" file of the
* VirtualBox OSE distribution, in which case the provisions of the
* CDDL are applicable instead of those of the GPL.
*
* You may elect to license modified versions of this file under the
* terms and conditions of either the GPL or the CDDL or both.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
* Clara, CA 95054 USA or visit http://www.sun.com if you need
* additional information or have any questions.
*/
/*******************************************************************************
* Header Files *
*******************************************************************************/
/*******************************************************************************
* Structures and Typedefs *
*******************************************************************************/
typedef struct LISTELEM
{
/** Test data */
unsigned idx;
/** Node */
{
if (cElements > 1)
RTTEST_CHECK(hTest, RTListNodeGetLast(pList, LISTELEM, Node) != RTListNodeGetFirst(pList, LISTELEM, Node));
else
RTTEST_CHECK(hTest, RTListNodeGetLast(pList, LISTELEM, Node) == RTListNodeGetFirst(pList, LISTELEM, Node));
/* Check that the order is right. */
{
}
/* Check reverse order */
{
}
/* The list enumeration. */
{
}
{
}
}
{
/* Create the list */
for (unsigned i = 0; i< cElements; i++)
{
}
/* Move the list to a new one. */
/* Remove elements now */
if (cElements > 1)
{
/* Remove every second */
RTTestISub("Remove every second node");
for (unsigned i = 0; i < cElements; i++)
{
{
}
}
cElements /= 2;
}
/* Remove the rest now. */
RTTestISub("Remove all nodes");
for (unsigned i = 0; i < cElements; i++)
{
}
/* List should be empty again */
}
int main()
{
if (rc)
return rc;
/*
* Summary.
*/
return RTTestSummaryAndDestroy(hTest);
}