2004-01-15 03:59:26 +03:00
|
|
|
/*
|
2005-11-05 22:57:48 +03:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 23:09:25 +03:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2009-12-04 05:30:34 +03:00
|
|
|
* Copyright (c) 2008-2009 Cisco Systems, Inc. All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-01-15 03:59:26 +03:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-10-20 05:03:09 +04:00
|
|
|
#include "ompi_config.h"
|
2004-02-05 02:54:22 +03:00
|
|
|
#include <assert.h>
|
|
|
|
|
2004-01-15 03:59:26 +03:00
|
|
|
#include "support.h"
|
2005-07-03 20:22:16 +04:00
|
|
|
#include "opal/class/opal_list.h"
|
2005-08-25 20:28:41 +04:00
|
|
|
#include "opal/runtime/opal.h"
|
2008-03-06 17:55:32 +03:00
|
|
|
#include "opal/constants.h"
|
2004-01-15 03:59:26 +03:00
|
|
|
|
2004-02-05 02:54:22 +03:00
|
|
|
/*
|
|
|
|
* Data type used for testing
|
|
|
|
*/
|
|
|
|
typedef struct test_data {
|
|
|
|
/* link list data structure */
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_item_t ll_element;
|
2004-02-05 02:54:22 +03:00
|
|
|
/* test data */
|
2005-03-23 16:37:46 +03:00
|
|
|
size_t data;
|
2004-02-05 02:54:22 +03:00
|
|
|
} test_data_t;
|
|
|
|
|
2005-04-08 22:05:13 +04:00
|
|
|
OBJ_CLASS_INSTANCE(test_data_t,
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_item_t,
|
2005-04-08 22:05:13 +04:00
|
|
|
NULL, NULL);
|
|
|
|
|
2004-01-15 03:59:26 +03:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
2004-01-26 23:32:19 +03:00
|
|
|
/* local variables */
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_t list, x;
|
2005-03-23 16:37:46 +03:00
|
|
|
size_t indx,i,list_size, tmp_size_1, tmp_size_2,size_elements;
|
2008-03-06 17:55:32 +03:00
|
|
|
int error_cnt, rc;
|
2004-02-05 02:54:22 +03:00
|
|
|
test_data_t *elements, *ele;
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_item_t *item;
|
2004-01-26 23:32:19 +03:00
|
|
|
|
2009-12-04 05:30:34 +03:00
|
|
|
rc = opal_init(&argc, &argv);
|
2008-03-06 17:55:32 +03:00
|
|
|
test_verify_int(OPAL_SUCCESS, rc);
|
|
|
|
if (OPAL_SUCCESS != rc) {
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
2005-08-25 20:28:41 +04:00
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
test_init("opal_list_t");
|
2004-01-26 23:32:19 +03:00
|
|
|
|
|
|
|
/* initialize list */
|
2005-07-03 20:22:16 +04:00
|
|
|
OBJ_CONSTRUCT(&list, opal_list_t);
|
|
|
|
OBJ_CONSTRUCT(&x, opal_list_t);
|
2004-01-26 23:32:19 +03:00
|
|
|
|
|
|
|
/* check length of list */
|
2005-07-03 20:22:16 +04:00
|
|
|
list_size=opal_list_get_size(&list);
|
2004-01-26 23:32:19 +03:00
|
|
|
if( 0 == list_size ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" opal_list_get_size");
|
2004-01-26 23:32:19 +03:00
|
|
|
}
|
|
|
|
|
2004-08-17 23:31:07 +04:00
|
|
|
/* check for empty */
|
2005-07-03 20:22:16 +04:00
|
|
|
if (opal_list_is_empty(&list)) {
|
2004-08-17 23:31:07 +04:00
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" opal_list_is_empty(empty list)");
|
2004-08-17 23:31:07 +04:00
|
|
|
}
|
|
|
|
|
2004-02-05 02:54:22 +03:00
|
|
|
/* create test elements */
|
|
|
|
size_elements=4;
|
|
|
|
elements=(test_data_t *)malloc(sizeof(test_data_t)*size_elements);
|
|
|
|
assert(elements);
|
|
|
|
for(i=0 ; i < size_elements ; i++) {
|
2005-04-08 22:05:13 +04:00
|
|
|
OBJ_CONSTRUCT(elements + i, test_data_t);
|
2004-02-05 02:54:22 +03:00
|
|
|
(elements+i)->data=i;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* populate list */
|
|
|
|
for(i=0 ; i < size_elements ; i++) {
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_append(&list,(opal_list_item_t *)(elements+i));
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
2005-07-03 20:22:16 +04:00
|
|
|
list_size=opal_list_get_size(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
if( list_size == size_elements ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
|
|
|
test_failure(" populating list");
|
|
|
|
}
|
|
|
|
|
2004-08-17 23:31:07 +04:00
|
|
|
/* checking for empty on non-empty list */
|
2005-07-03 20:22:16 +04:00
|
|
|
if (!opal_list_is_empty(&list)) {
|
2004-08-17 23:31:07 +04:00
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" opal_list_is_empty(non-empty list)");
|
2004-08-17 23:31:07 +04:00
|
|
|
}
|
|
|
|
|
2004-02-05 02:54:22 +03:00
|
|
|
/* check that list is ordered as expected */
|
|
|
|
i=0;
|
|
|
|
error_cnt=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
if( ele->data != i )
|
|
|
|
error_cnt++;
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( 0 == error_cnt ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
|
|
|
test_failure(" error in list order ");
|
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* check opal_list_get_first */
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_get_first(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( 0 == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_get_first");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( size_elements == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_get_first - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* check opal_list_get_last */
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_get_last(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( (size_elements-1) == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_get_last");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( size_elements == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_get_first - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* check opal_list_remove_first */
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_remove_first(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( 0 == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove_first");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( (size_elements-1) == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove_first - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* test opal_list_prepend */
|
|
|
|
opal_list_prepend(&list,(opal_list_item_t *)elements);
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_get_first(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( 0 == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_prepend");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( size_elements == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_prepend - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* check opal_list_remove_last */
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_remove_last(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( (size_elements-1) == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove_last");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( (size_elements-1) == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove_last - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
/* test opal_list_append */
|
|
|
|
opal_list_append(&list,(opal_list_item_t *)(elements+size_elements-1));
|
2004-02-05 02:54:22 +03:00
|
|
|
ele = (test_data_t *)NULL;
|
2005-07-03 20:22:16 +04:00
|
|
|
ele = (test_data_t *) opal_list_get_last(&list);
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( (size_elements-1) == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_append");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( size_elements == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_append - list size changed ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* remove element from list */
|
|
|
|
indx=size_elements/2;
|
|
|
|
if( 0 == indx )
|
|
|
|
indx=1;
|
|
|
|
assert(2 <= size_elements);
|
|
|
|
ele = (test_data_t *)NULL;
|
|
|
|
ele = (test_data_t *)
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_remove_item(&list,(opal_list_item_t *)(elements+indx));
|
2004-02-05 02:54:22 +03:00
|
|
|
assert(ele);
|
|
|
|
if( (indx-1) == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove - previous");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
2005-07-03 20:22:16 +04:00
|
|
|
ele=(test_data_t *)(((opal_list_item_t *)ele)->opal_list_next);
|
2004-02-05 02:54:22 +03:00
|
|
|
if( (indx+1) == ele->data ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove - next");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( (size_elements-1) == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove - list size changed incorrectly");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
2005-04-14 01:25:25 +04:00
|
|
|
|
2004-02-05 02:54:22 +03:00
|
|
|
/* test the insert function */
|
2005-07-03 20:22:16 +04:00
|
|
|
i=opal_list_insert(&list,(opal_list_item_t *)(elements+indx),indx);
|
2004-02-05 02:54:22 +03:00
|
|
|
if( 1 == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_remove_item \n");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
2004-02-05 03:05:18 +03:00
|
|
|
|
|
|
|
i=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 03:05:18 +03:00
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( size_elements == i ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in opal_list_insert - incorrect list length");
|
2004-02-05 03:05:18 +03:00
|
|
|
}
|
2004-02-05 02:54:22 +03:00
|
|
|
i=0;
|
|
|
|
error_cnt=0;
|
2005-07-03 20:22:16 +04:00
|
|
|
for(ele = (test_data_t *) opal_list_get_first(&list);
|
|
|
|
ele != (test_data_t *) opal_list_get_end(&list);
|
|
|
|
ele = (test_data_t *) ((opal_list_item_t *)ele)->opal_list_next) {
|
2004-02-05 02:54:22 +03:00
|
|
|
if( ele->data != i )
|
|
|
|
error_cnt++;
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
if( 0 == error_cnt ) {
|
|
|
|
test_success();
|
|
|
|
} else {
|
2005-07-03 20:22:16 +04:00
|
|
|
test_failure(" error in list order - opal_list_remove_item ");
|
2004-02-05 02:54:22 +03:00
|
|
|
}
|
2004-01-26 23:32:19 +03:00
|
|
|
|
2004-08-17 23:31:07 +04:00
|
|
|
/* test the splice and join functions */
|
2005-07-03 20:22:16 +04:00
|
|
|
list_size = opal_list_get_size(&list);
|
|
|
|
for (i = 0, item = opal_list_get_first(&list) ;
|
|
|
|
i < list_size / 2 ; ++i, item = opal_list_get_next(item)) {
|
|
|
|
}
|
|
|
|
opal_list_splice(&x, opal_list_get_end(&x),
|
|
|
|
&list, item, opal_list_get_end(&list));
|
|
|
|
tmp_size_1 = opal_list_get_size(&list);
|
|
|
|
tmp_size_2 = opal_list_get_size(&x);
|
2004-08-17 23:31:07 +04:00
|
|
|
if (tmp_size_1 != i) {
|
|
|
|
test_failure(" error in splice (size of list)");
|
|
|
|
} else if (tmp_size_2 != list_size - tmp_size_1) {
|
|
|
|
test_failure(" error in splice (size of x)");
|
|
|
|
} else {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_join(&list, opal_list_get_end(&list), &x);
|
|
|
|
tmp_size_1 = opal_list_get_size(&list);
|
|
|
|
tmp_size_2 = opal_list_get_size(&x);
|
2004-08-17 23:31:07 +04:00
|
|
|
if (tmp_size_1 != list_size) {
|
|
|
|
test_failure(" error in join (size of list)");
|
|
|
|
} else if (tmp_size_2 != 0) {
|
|
|
|
test_failure(" error in join (size of x)");
|
|
|
|
} else {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
|
2005-08-25 20:28:41 +04:00
|
|
|
if (NULL != elements) free(elements);
|
|
|
|
|
|
|
|
opal_finalize();
|
|
|
|
|
2004-02-11 17:45:35 +03:00
|
|
|
return test_finalize();
|
2004-01-15 03:59:26 +03:00
|
|
|
}
|