2005-03-14 20:57:21 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2005-03-14 20:57:21 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "orte_config.h"
|
|
|
|
#include "../src/include/orte_constants.h"
|
|
|
|
#include "../src/include/orte_types.h"
|
|
|
|
#include "../src/include/orte_schema.h"
|
|
|
|
#include "../../src/dps/dps_internal.h"
|
|
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#ifdef HAVE_SYS_PARAM_H
|
|
|
|
#include <sys/param.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_NETINET_IN_H
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "include/constants.h"
|
|
|
|
|
|
|
|
#include "support.h"
|
|
|
|
#include "../src/runtime/runtime.h"
|
|
|
|
#include "../src/mca/base/base.h"
|
|
|
|
#include "../src/dps/dps.h"
|
|
|
|
#include "../src/mca/ns/ns_types.h"
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
#define NUM_ITERS 10
|
|
|
|
#define NUM_ELEMS 100
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
static bool test1(void); /* verify different buffer inits */
|
|
|
|
static bool test2(void); /* verify int16 */
|
|
|
|
static bool test3(void); /* verify int32 */
|
|
|
|
static bool test4(void); /* verify string */
|
|
|
|
static bool test5(void); /* verify name */
|
|
|
|
static bool test6(void); /* verify BOOL */
|
|
|
|
static bool test7(void); /* verify OBJECT */
|
|
|
|
static bool test8(void); /* verify composite (multiple types and element counts) */
|
|
|
|
static bool test9(void); /* verify GPR_KEYVAL */
|
|
|
|
static bool test10(void); /* verify GPR_VALUE */
|
|
|
|
static bool test11(void); /* verify APP_INFO (right now ??!!) */
|
|
|
|
static bool test12(void); /* verify APP_CONTEXT */
|
|
|
|
static bool test13(void); /* verify ORTE_GPR_SUBSCRIPTION */
|
|
|
|
static bool test14(void); /* verify ORTE_GPR_NOTIFY_DATA */
|
2005-05-01 00:47:35 +00:00
|
|
|
static bool test15(void); /* verify ORTE_INT */
|
|
|
|
static bool test16(void); /* verify ORTE_UINT */
|
|
|
|
static bool test17(void); /* verify ORTE_SIZE */
|
|
|
|
static bool test18(void); /* verify ORTE_PID */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
FILE *test_out;
|
|
|
|
|
|
|
|
int main (int argc, char* argv[])
|
|
|
|
{
|
2005-04-05 02:32:57 +00:00
|
|
|
int ret;
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
test_init("orte_dps");
|
|
|
|
test_out = stderr;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* Open up the output streams */
|
|
|
|
if (!ompi_output_init()) {
|
|
|
|
return OMPI_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* If threads are supported - assume that we are using threads -
|
|
|
|
* and reset otherwise.
|
|
|
|
*/
|
|
|
|
ompi_set_using_threads(OMPI_HAVE_THREAD_SUPPORT);
|
|
|
|
|
|
|
|
/* For malloc debugging */
|
|
|
|
ompi_malloc_init();
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
/* startup the MCA */
|
|
|
|
if (OMPI_SUCCESS != mca_base_open()) {
|
|
|
|
fprintf(stderr, "can't open mca\n");
|
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* setup the dps */
|
|
|
|
orte_dps_open();
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test1\n");
|
|
|
|
if (test1()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test1 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test2\n");
|
|
|
|
if (test2()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test2 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test3\n");
|
|
|
|
if (test3()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test3 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test4\n");
|
|
|
|
if (test4()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test4 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test5\n");
|
|
|
|
if (test5()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test5 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test6\n");
|
|
|
|
if (test6()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test6 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test7\n");
|
|
|
|
if (test7()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test7 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test8\n");
|
|
|
|
if (test8()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test8 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test9\n");
|
|
|
|
if (test9()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test9 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test10\n");
|
|
|
|
if (test10()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test10 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test11\n");
|
|
|
|
if (test11()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test11 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test12\n");
|
|
|
|
if (test12()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test12 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test13\n");
|
|
|
|
if (test13()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test13 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test14\n");
|
|
|
|
if (test14()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test14 failed");
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
fprintf(test_out, "executing test15\n");
|
|
|
|
if (test15()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test15 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test16\n");
|
|
|
|
if (test16()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test16 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test17\n");
|
|
|
|
if (test17()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test17 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
fprintf(test_out, "executing test18\n");
|
|
|
|
if (test18()) {
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
test_failure("orte_dps test18 failed");
|
|
|
|
}
|
|
|
|
|
|
|
|
orte_dps_close();
|
|
|
|
mca_base_close();
|
|
|
|
ompi_malloc_finalize();
|
|
|
|
ompi_output_finalize();
|
|
|
|
ompi_class_finalize();
|
|
|
|
|
2005-04-05 02:32:57 +00:00
|
|
|
ret = test_finalize();
|
2005-03-14 20:57:21 +00:00
|
|
|
fclose(test_out);
|
2005-04-05 02:32:57 +00:00
|
|
|
return ret;
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool test1(void) /* verify different buffer inits */
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_INT16 pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test2(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
int16_t src[NUM_ELEMS];
|
|
|
|
int16_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_INT16);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = -1;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_INT16);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
2005-05-01 00:47:35 +00:00
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d count %d\n", rc, count);
|
2005-03-14 20:57:21 +00:00
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test2: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_INT32 pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test3(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
int32_t src[NUM_ELEMS];
|
|
|
|
int32_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_INT32);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = -1;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_INT32);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test2: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_STRING pack/unpack
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool test4(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
char* src[NUM_ELEMS];
|
|
|
|
char* dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
asprintf(&src[i], "%d", i);
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_STRING);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = NULL;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_STRING);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test4: orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(strcmp(src[j],dst[j]) != 0) {
|
|
|
|
test_comment ("test4: invalid results from unpack");
|
|
|
|
fprintf(test_out, "item %d src=[%s] len=%d dst=[%s] len=%d\n", j, src[j], (int)strlen(src[j]), dst[j], (int)strlen(dst[j]));
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
free(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
free(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* OMPI_NAME pack/unpack
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool test5(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
orte_process_name_t src[NUM_ELEMS];
|
|
|
|
orte_process_name_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i].cellid = 1000 + i;
|
|
|
|
src[i].jobid = 100 + i;
|
|
|
|
src[i].vpid = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_NAME);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_NAME);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test5: orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(memcmp(&src[j],&dst[j],sizeof(orte_process_name_t)) != 0) {
|
|
|
|
test_comment ("test5: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* OMPI_BOOL pack/unpack
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool test6(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
bool src[NUM_ELEMS];
|
|
|
|
bool dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = ((i % 2) == 0) ? true : false;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test6: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* OMPI_BYTE_OBJECT pack/unpack
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool test7(void)
|
|
|
|
{
|
|
|
|
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
orte_byte_object_t src[NUM_ELEMS];
|
|
|
|
orte_byte_object_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
asprintf((char**)&src[i].bytes, "%d", i);
|
|
|
|
src[i].size = strlen((char*)src[i].bytes) + 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_BYTE_OBJECT);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
memset(dst,0,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_BYTE_OBJECT);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test7: orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_dps.unpack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j].size != dst[j].size ||
|
|
|
|
memcmp(src[j].bytes,dst[j].bytes,src[j].size) != 0) {
|
|
|
|
test_comment ("test7: invalid results from unpack");
|
|
|
|
fprintf(test_out, "test7: element %d has incorrect unpacked value\n", j);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
free(dst[j].bytes);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
free(src[i].bytes);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ompi everything composite multipack/unpack
|
|
|
|
*/
|
|
|
|
|
|
|
|
static bool test8(void)
|
|
|
|
{
|
|
|
|
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* pack and unpack in this order */
|
|
|
|
/* each block now has an offset to make debugging easier.. first block=100, 200,... */
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_byte_object_t srco[NUM_ELEMS];
|
|
|
|
orte_byte_object_t dsto[NUM_ELEMS];
|
|
|
|
orte_process_name_t srcp[NUM_ELEMS];
|
|
|
|
orte_process_name_t dstp[NUM_ELEMS];
|
|
|
|
char* srcs[NUM_ELEMS];
|
|
|
|
char* dsts[NUM_ELEMS];
|
|
|
|
bool srcb[NUM_ELEMS];
|
|
|
|
bool dstb[NUM_ELEMS];
|
|
|
|
int32_t src32[NUM_ELEMS];
|
|
|
|
int32_t dst32[NUM_ELEMS];
|
|
|
|
int16_t src16[NUM_ELEMS];
|
|
|
|
int16_t dst16[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
2005-05-01 00:47:35 +00:00
|
|
|
/* object offset 100 */
|
2005-03-14 20:57:21 +00:00
|
|
|
asprintf((char**)&srco[i].bytes, "%d", i+100);
|
|
|
|
srco[i].size = strlen((char*)srco[i].bytes) + 1;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* process name */
|
|
|
|
srcp[i].cellid = 1000 + i;
|
2005-03-14 20:57:21 +00:00
|
|
|
srcp[i].jobid = 100 + i;
|
|
|
|
srcp[i].vpid = i;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* strings +200 */
|
2005-03-14 20:57:21 +00:00
|
|
|
asprintf(&srcs[i], "%d", i+200);
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* bool */
|
2005-03-14 20:57:21 +00:00
|
|
|
srcb[i] = ((i % 2) == 0) ? true : false;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* INT32 +300 */
|
2005-03-14 20:57:21 +00:00
|
|
|
src32[i] = i+300;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* INT16 +400 */
|
2005-03-14 20:57:21 +00:00
|
|
|
src16[i] = i+400;
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
2005-05-01 00:47:35 +00:00
|
|
|
/* object first */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, srco, NUM_ELEMS, ORTE_BYTE_OBJECT);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on object failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* NAME */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, srcp, NUM_ELEMS, ORTE_NAME);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on name failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* STRING */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, srcs, NUM_ELEMS, ORTE_STRING);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on string failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* BOOL */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, srcb, NUM_ELEMS, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on bool failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* INT32 */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, src32, NUM_ELEMS, ORTE_INT32);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on INT32 failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* INT16 */
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.pack(bufA, src16, NUM_ELEMS, ORTE_INT16);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack on INT16 failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* fprintf(test_out,"test8:packed buffer info for STRING with %d iterations %d elements each\n", NUM_ITERS, NUM_ELEMS); */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count;
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* object */
|
2005-03-14 20:57:21 +00:00
|
|
|
memset(dsto,0,sizeof(dsto));
|
2005-05-01 00:47:35 +00:00
|
|
|
/* name */
|
|
|
|
memset(dstp,-1,sizeof(dstp));
|
|
|
|
/* string */
|
2005-03-14 20:57:21 +00:00
|
|
|
for(j=0; j<NUM_ELEMS; j++) dsts[j] = NULL;
|
2005-05-01 00:47:35 +00:00
|
|
|
/* bool */
|
2005-03-14 20:57:21 +00:00
|
|
|
memset(dstb,-1,sizeof(dstb));
|
2005-05-01 00:47:35 +00:00
|
|
|
/* int32 */
|
2005-03-14 20:57:21 +00:00
|
|
|
for(j=0; j<NUM_ELEMS; j++) dst32[j] = -1;
|
2005-05-01 00:47:35 +00:00
|
|
|
/* int16 */
|
2005-03-14 20:57:21 +00:00
|
|
|
for(j=0; j<NUM_ELEMS; j++) dst16[j] = -1;
|
|
|
|
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* object */
|
|
|
|
count=NUM_ELEMS;
|
2005-03-14 20:57:21 +00:00
|
|
|
rc = orte_dps.unpack(bufA, dsto, &count, ORTE_BYTE_OBJECT);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test8: orte_dps.unpack on object failed");
|
|
|
|
fprintf(test_out, "orte_dps.unpack failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(srco[j].size != dsto[j].size ||
|
|
|
|
memcmp(srco[j].bytes,dsto[j].bytes,srco[j].size) != 0) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
fprintf(test_out, "test8: element %d has incorrect unpacked value\n", j);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
free(dsto[j].bytes);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* name */
|
2005-03-14 20:57:21 +00:00
|
|
|
count = NUM_ELEMS;
|
|
|
|
rc = orte_dps.unpack(bufA, dstp, &count, ORTE_NAME);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test8: orte_dps.unpack on name failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(memcmp(&srcp[j],&dstp[j],sizeof(orte_process_name_t)) != 0) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* string */
|
2005-03-14 20:57:21 +00:00
|
|
|
count = NUM_ELEMS;
|
|
|
|
rc = orte_dps.unpack(bufA, dsts, &count, ORTE_STRING);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("test8: orte_dps.unpack on string failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(strcmp(srcs[j],dsts[j]) != 0) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
fprintf(test_out, "item %d src=[%s] len=%d dst=[%s] len=%d\n", j, srcs[j], (int)strlen(srcs[j]), dsts[j], (int)strlen(dsts[j]));
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
free(dsts[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
|
|
|
|
/* bool */
|
2005-03-14 20:57:21 +00:00
|
|
|
count = NUM_ELEMS;
|
|
|
|
rc = orte_dps.unpack(bufA, dstb, &count, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack on bool failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(srcb[j] != dstb[j]) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* int32 */
|
2005-03-14 20:57:21 +00:00
|
|
|
count = NUM_ELEMS;
|
|
|
|
rc = orte_dps.unpack(bufA, dst32, &count, ORTE_INT32);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack on int32 failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src32[j] != dst32[j]) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* int16 */
|
2005-03-14 20:57:21 +00:00
|
|
|
count = NUM_ELEMS;
|
|
|
|
rc = orte_dps.unpack(bufA, dst16, &count, ORTE_INT16);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack on int16 failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src16[j] != dst16[j]) {
|
|
|
|
test_comment ("test8: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} /* per iteration */
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
free(srco[i].bytes);
|
|
|
|
free(srcs[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ORTE_KEYVAL */
|
|
|
|
static bool test9(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
orte_gpr_keyval_t *src[NUM_ELEMS];
|
|
|
|
orte_gpr_keyval_t *dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
/* setup source array of keyvals */
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
|
|
asprintf(&(src[i]->key), "%d", i);
|
|
|
|
src[i]->type = ((i % 2) == 0) ? ORTE_INT16 : ORTE_INT32;
|
|
|
|
if (ORTE_INT16 == src[i]->type)
|
|
|
|
src[i]->value.i16 = i;
|
|
|
|
else
|
|
|
|
src[i]->value.i32 = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_KEYVAL);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_KEYVAL);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_unpack (KEYVAL) failed on iteration %d with error %s\n",
|
|
|
|
i, ORTE_ERROR_NAME(rc));
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if (0 != strcmp(src[j]->key, dst[j]->key) ||
|
|
|
|
src[j]->type != dst[j]->type) {
|
|
|
|
test_comment ("test9: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if (ORTE_INT16 == src[j]->type) {
|
|
|
|
if (src[j]->value.i16 != dst[j]->value.i16) {
|
|
|
|
test_comment ("test9: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
} else if (ORTE_INT32 == src[j]->type) {
|
|
|
|
if (src[j]->value.i32 != dst[j]->value.i32) {
|
|
|
|
test_comment ("test9: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
OBJ_RELEASE(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
OBJ_RELEASE(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* ORTE_GPR_VALUE */
|
|
|
|
static bool test10(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
2005-05-01 00:47:35 +00:00
|
|
|
int i, tok_cycle, key_cycle;
|
|
|
|
size_t j, k;
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_gpr_value_t *src[NUM_ELEMS];
|
|
|
|
orte_gpr_value_t *dst[NUM_ELEMS];
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
tok_cycle = (NUM_ELEMS/2 ? 1 : NUM_ELEMS/2);
|
|
|
|
key_cycle = (NUM_ELEMS/4 ? 1 : NUM_ELEMS/4);
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i] = OBJ_NEW(orte_gpr_value_t);
|
|
|
|
src[i]->segment = strdup("test-segment");
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->num_tokens = i % tok_cycle;
|
|
|
|
if (0 < src[i]->num_tokens) {
|
|
|
|
src[i]->tokens = (char**)malloc(src[i]->num_tokens * sizeof(char*));
|
|
|
|
for (j=0; j < src[i]->num_tokens; j++) {
|
|
|
|
src[i]->tokens[j] = strdup("test-token");
|
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->cnt = i % key_cycle;
|
|
|
|
if (0 < src[i]->cnt) {
|
|
|
|
src[i]->keyvals = (orte_gpr_keyval_t**)malloc(src[i]->cnt * sizeof(orte_gpr_keyval_t*));
|
|
|
|
for (j=0; j < src[i]->cnt; j++) {
|
|
|
|
src[i]->keyvals[j] = OBJ_NEW(orte_gpr_keyval_t);
|
|
|
|
asprintf(&((src[i]->keyvals[j])->key), "%d", j);
|
|
|
|
(src[i]->keyvals[j])->type = ((j % 2) == 0) ? ORTE_INT16 : ORTE_INT32;
|
|
|
|
if (ORTE_INT16 == (src[i]->keyvals[j])->type)
|
|
|
|
(src[i]->keyvals[j])->value.i16 = j;
|
|
|
|
else
|
|
|
|
(src[i]->keyvals[j])->value.i32 = j;
|
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_GPR_VALUE);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_dps.pack failed with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_GPR_VALUE);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_dps.unpack failed with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(0 != strcmp(src[j]->segment, dst[j]->segment) ||
|
|
|
|
src[j]->num_tokens != dst[j]->num_tokens ||
|
|
|
|
src[j]->cnt != dst[j]->cnt) {
|
|
|
|
test_comment ("test10: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
for (k=0; k<src[j]->num_tokens; k++) {
|
|
|
|
if (0 != strcmp(src[j]->tokens[k], dst[j]->tokens[k])) {
|
|
|
|
test_comment ("test10: invalid results (tokens) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for (k=0; k < src[j]->cnt; k++) {
|
|
|
|
if (0 != strcmp((src[j]->keyvals[k])->key,
|
|
|
|
(dst[j]->keyvals[k])->key)) {
|
|
|
|
test_comment ("test10: invalid results (keyvalues) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if ((src[j]->keyvals[k])->type != (dst[j]->keyvals[k])->type) {
|
|
|
|
test_comment ("test10: invalid results (keyvalue types) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if (ORTE_INT16 == (src[j]->keyvals[k])->type &&
|
|
|
|
(src[j]->keyvals[k])->value.i16 != (dst[j]->keyvals[k])->value.i16) {
|
|
|
|
test_comment ("test10: invalid results (keyvalues.16) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
else if (ORTE_INT32 == (src[j]->keyvals[k])->type &&
|
|
|
|
(src[j]->keyvals[k])->value.i32 != (dst[j]->keyvals[k])->value.i32) {
|
|
|
|
test_comment ("test10: invalid results (keyvalues.32) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
OBJ_RELEASE(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
OBJ_RELEASE(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* ORTE_APP_INFO */
|
|
|
|
static bool test11(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
bool src[NUM_ELEMS];
|
|
|
|
bool dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = ((i % 2) == 0) ? true : false;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_BOOL);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test6: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* ORTE_APP_CONTEXT */
|
|
|
|
static bool test12(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
2005-05-01 00:47:35 +00:00
|
|
|
int32_t i, j, n;
|
|
|
|
size_t k;
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_app_context_t *src[NUM_ELEMS];
|
|
|
|
orte_app_context_t *dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i] = OBJ_NEW(orte_app_context_t);
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->idx = i;
|
2005-03-14 20:57:21 +00:00
|
|
|
src[i]->app = strdup("test-application-name");
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->num_procs = i; /* test between 0 and NUM_ELEMS-1 proc counts */
|
|
|
|
|
|
|
|
/* test arg counts of 1 to NUM_ELEMS+1 */
|
|
|
|
src[i]->argc = i+1;
|
|
|
|
if (src[i]->argc) { /* if to allow testing of argv count of zero */
|
|
|
|
src[i]->argv = (char**)malloc((src[i]->argc+1) * sizeof(char*));
|
|
|
|
for (j=0; j < src[i]->argc; j++) {
|
|
|
|
src[i]->argv[j] = strdup("test-argv");
|
|
|
|
}
|
|
|
|
src[i]->argv[j] = NULL; /* must NULL terminate */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* test env counts of 1 to NUM_ELEMS+1 */
|
|
|
|
src[i]->num_env = i+1;
|
|
|
|
if (src[i]->num_env) { /* if to allow testing of num_env count of zero */
|
|
|
|
src[i]->env = (char**)malloc((src[i]->num_env+1) * sizeof(char*));
|
|
|
|
for (k=0; k < src[i]->num_env; k++) {
|
|
|
|
src[i]->env[k] = strdup("test-env");
|
|
|
|
}
|
|
|
|
src[i]->env[k] = NULL; /* must NULL terminate */
|
|
|
|
}
|
|
|
|
|
|
|
|
src[i]->cwd = strdup ("test-cwd");
|
|
|
|
|
|
|
|
/* test imap data for map count = num_procs */
|
|
|
|
src[i]->num_map = i+1;
|
|
|
|
if (src[i]->num_map) { /* if to allow testing of map count of zero */
|
|
|
|
src[i]->map_data = (orte_app_context_map_t**)malloc(src[i]->num_map * sizeof(orte_app_context_map_t *)); /* map data type */
|
|
|
|
for (k=0; k < src[i]->num_map; k++) {
|
|
|
|
src[i]->map_data[k] = OBJ_NEW(orte_app_context_map_t); /* assume we create with new rather than malloc? */
|
|
|
|
src[i]->map_data[k]->map_type = (uint8_t) k;
|
|
|
|
src[i]->map_data[k]->map_data = strdup("test-map-data");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* source data set, now create buffer and pack source data */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* fprintf(test_out,"New buffer ready\n"); */
|
|
|
|
/* fflush(test_out); */
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* orte_dps_dump_buffer_simple (bufA, 0); */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_APP_CONTEXT);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
/* fprintf(test_out,"Packed iter %d\n", i); */
|
|
|
|
/* fflush(test_out); */
|
|
|
|
/* orte_dps_dump_buffer_simple (bufA, 0); */
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_APP_CONTEXT);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_unpack_value failed with return code %d (count=%d)\n", rc, count);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* fprintf(test_out,"Unpacked iter %d\n", i); */
|
|
|
|
/* fflush(test_out); */
|
|
|
|
/* orte_dps_dump_buffer_simple (bufA, 0); */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
|
|
|
|
if (
|
2005-05-01 00:47:35 +00:00
|
|
|
src[j]->idx != dst[j]->idx ||
|
|
|
|
0 != strcmp(src[j]->app, dst[j]->app) ||
|
2005-03-14 20:57:21 +00:00
|
|
|
src[j]->num_procs != dst[j]->num_procs ||
|
|
|
|
src[j]->argc != dst[j]->argc ||
|
|
|
|
src[j]->num_env != dst[j]->num_env ||
|
2005-05-01 00:47:35 +00:00
|
|
|
0 != strcmp(src[j]->cwd, dst[j]->cwd) ||
|
2005-03-14 20:57:21 +00:00
|
|
|
src[j]->num_map != dst[j]->num_map
|
2005-05-01 00:47:35 +00:00
|
|
|
) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test12: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* now compare each of the size/cnt depedant values */
|
|
|
|
for (n=0; n < src[j]->argc; n++) {
|
|
|
|
if (0 != strcmp(src[j]->argv[n], dst[j]->argv[n])) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test12: invalid results (argv) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for (k=0; k<src[j]->num_env; k++) {
|
|
|
|
if (0 != strcmp(src[j]->env[k], dst[j]->env[k])) {
|
|
|
|
test_comment ("test12: invalid results (envs) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (k=0; k< src[j]->num_map; k++) {
|
|
|
|
if ((src[j]->map_data[k])->map_type != (dst[j]->map_data[k])->map_type) {
|
|
|
|
test_comment ("test12: invalid results (map_data types) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if (0 != strcmp((src[j]->map_data[k])->map_data,
|
|
|
|
(dst[j]->map_data[k])->map_data)) {
|
|
|
|
test_comment ("test12: invalid results (map_data data) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
OBJ_RELEASE(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
OBJ_RELEASE(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ORTE_GPR_SUBSCRIPTION */
|
|
|
|
static bool test13(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
2005-05-01 00:47:35 +00:00
|
|
|
int32_t i;
|
|
|
|
size_t j, k;
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_gpr_subscription_t *src[NUM_ELEMS];
|
|
|
|
orte_gpr_subscription_t *dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i] = OBJ_NEW(orte_gpr_subscription_t);
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->addr_mode = (uint16_t) i;
|
2005-03-14 20:57:21 +00:00
|
|
|
src[i]->segment = strdup("test-segment-name");
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* test token counts of 0! to NUM_ELEMS */
|
|
|
|
src[i]->num_tokens = i;
|
|
|
|
if (src[i]->num_tokens) { /* if to allow testing of token count of zero */
|
|
|
|
src[i]->tokens = (char**)malloc(src[i]->num_tokens * sizeof(char*));
|
|
|
|
for (j=0; j < src[i]->num_tokens; j++) {
|
|
|
|
src[i]->tokens[j] = strdup("test-token");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* test key counts of 0 to NUM_ELEMS */
|
|
|
|
src[i]->num_keys = i;
|
|
|
|
if (src[i]->num_keys) { /* if to allow testing of num_keys count of zero */
|
|
|
|
src[i]->keys = (char**)malloc(src[i]->num_keys * sizeof(char*));
|
|
|
|
for (j=0; j < src[i]->num_keys; j++) {
|
|
|
|
src[i]->keys[j] = strdup("test-key");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* skip the pointers for cb_func and user_tag */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* source data set, now create buffer and pack source data */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_GPR_SUBSCRIPTION);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value (ORTE_GPR_SUBSCRIPTION) failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_GPR_SUBSCRIPTION);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_unpack_value (ORTE_GPR_SUBSCRIPTION) failed with return code %d (count=%d)\n", rc, count);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
|
|
|
|
if (
|
2005-05-01 00:47:35 +00:00
|
|
|
src[j]->addr_mode != dst[j]->addr_mode ||
|
|
|
|
0 != strcmp(src[j]->segment, dst[j]->segment) ||
|
2005-03-14 20:57:21 +00:00
|
|
|
src[j]->num_tokens != dst[j]->num_tokens ||
|
|
|
|
src[j]->num_keys != dst[j]->num_keys
|
2005-05-01 00:47:35 +00:00
|
|
|
) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test13: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* now compare each of the size/cnt depedant values */
|
2005-03-14 20:57:21 +00:00
|
|
|
for (k=0; k<src[j]->num_tokens; k++) {
|
|
|
|
if (0 != strcmp(src[j]->tokens[k], dst[j]->tokens[k])) {
|
|
|
|
test_comment ("test13: invalid results (tokens) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (k=0; k< src[j]->num_keys; k++) {
|
|
|
|
if (0 != strcmp(src[j]->keys[k], dst[j]->keys[k])) {
|
|
|
|
test_comment ("test13: invalid results (keys) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
2005-05-01 00:47:35 +00:00
|
|
|
OBJ_RELEASE(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
OBJ_RELEASE(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ORTE_GPR_NOTIFY_DATA */
|
|
|
|
static bool test14(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
2005-05-01 00:47:35 +00:00
|
|
|
int32_t i;
|
|
|
|
size_t j, k, l;
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_gpr_notify_data_t *src[NUM_ELEMS];
|
|
|
|
orte_gpr_notify_data_t *dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
src[i] = OBJ_NEW(orte_gpr_notify_data_t);
|
2005-05-01 00:47:35 +00:00
|
|
|
src[i]->cb_num = (uint32_t) i;
|
|
|
|
src[i]->addr_mode = (uint16_t) i;
|
2005-03-14 20:57:21 +00:00
|
|
|
src[i]->segment = strdup("test-segment-name");
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* test value counts of 0 to NUM_ELEMS-1 */
|
|
|
|
src[i]->cnt = (uint32_t) i; /* value count */
|
|
|
|
|
|
|
|
if (src[i]->cnt) { /* if to allow testing of GPR value count of zero */
|
|
|
|
|
|
|
|
src[i]->values = (orte_gpr_value_t**)malloc(src[i]->cnt * sizeof(orte_gpr_value_t*));
|
|
|
|
|
|
|
|
for (j=0; j < src[i]->cnt; j++) {
|
|
|
|
src[i]->values[j] = OBJ_NEW(orte_gpr_value_t);
|
|
|
|
src[i]->values[j]->addr_mode = (uint16_t) i+j+1;
|
|
|
|
src[i]->values[j]->segment = strdup("test-gpr-notify-value-segment-name"); /* ek segment name again! */
|
|
|
|
|
|
|
|
/* tokens */
|
|
|
|
src[i]->values[j]->num_tokens = j; /* test tokens within gpr values within notify message between 0-NUM_ELEMS-1 */
|
|
|
|
if (src[i]->values[j]->num_tokens) { /* if to allow testing of num_tokens count of zero */
|
|
|
|
src[i]->values[j]->tokens = (char**)malloc(src[i]->values[j]->num_tokens * sizeof(char*));
|
|
|
|
for (k=0; k < src[i]->values[j]->num_tokens; k++) {
|
|
|
|
src[i]->values[j]->tokens[k] = strdup("test-grp-notify-value-token");
|
|
|
|
} /* for each token */
|
|
|
|
} /* if tokens */
|
|
|
|
|
|
|
|
/* keyval pairs (field name is 'cnt' same as used for value count so be carefull) */
|
|
|
|
src[i]->values[j]->cnt = j; /* test keyval pairs within gpr values within notify message between 0-NUM_ELEMS-1 */
|
|
|
|
if (src[i]->values[j]->cnt) { /* if to allow testing of keyval pair count of zero */
|
|
|
|
src[i]->values[j]->keyvals = (orte_gpr_keyval_t**)malloc(src[i]->values[j]->cnt * sizeof(orte_gpr_keyval_t*));
|
|
|
|
for (k=0; k < src[i]->values[j]->cnt; k++) {
|
|
|
|
src[i]->values[j]->keyvals[k] = OBJ_NEW (orte_gpr_keyval_t);
|
|
|
|
src[i]->values[j]->keyvals[k]->key = strdup("test-grp-notify-value-key");
|
|
|
|
src[i]->values[j]->keyvals[k]->type = (uint8_t) (ORTE_INT32); /* make it simplier */
|
|
|
|
src[i]->values[j]->keyvals[k]->value.i32 = (uint32_t) (i*100)+(j*10)+k; /* something variable */
|
|
|
|
} /* for each keyval pair */
|
|
|
|
} /* if keyvals */
|
|
|
|
|
|
|
|
} /* for each value */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* source data set, now create buffer and pack source data */
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_GPR_NOTIFY_DATA);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value (ORTE_GPR_NOTIFY_DATA) failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
memset(dst,-1,sizeof(dst));
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_GPR_NOTIFY_DATA);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_unpack_value (ORTE_GPR_NOTIFY_DATA) failed with return code %d (count=%d)\n", rc, count);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
|
|
|
|
if (
|
|
|
|
src[j]->cb_num != dst[j]->cb_num ||
|
2005-05-01 00:47:35 +00:00
|
|
|
src[j]->addr_mode != dst[j]->addr_mode ||
|
|
|
|
0 != strcmp(src[j]->segment, dst[j]->segment) ||
|
2005-03-14 20:57:21 +00:00
|
|
|
src[j]->cnt != dst[j]->cnt
|
2005-05-01 00:47:35 +00:00
|
|
|
) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test14: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/* now compare each value of the cnt depedant values */
|
2005-03-14 20:57:21 +00:00
|
|
|
for (k=0; k<src[j]->cnt; k++) {
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
if (src[j]->values[k]->addr_mode != dst[j]->values[k]->addr_mode) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test14: invalid results (values-addr-mode) from unpack");
|
|
|
|
return(false);
|
2005-05-01 00:47:35 +00:00
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
|
|
|
|
if (0 != strcmp(src[j]->values[k]->segment, dst[j]->values[k]->segment)) {
|
|
|
|
test_comment ("test14: invalid results (values-segment) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
if (src[j]->values[k]->num_tokens != dst[j]->values[k]->num_tokens) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test14: invalid results (values-num_tokens) from unpack");
|
|
|
|
return(false);
|
2005-05-01 00:47:35 +00:00
|
|
|
}
|
|
|
|
for (l=0; l<src[j]->values[k]->num_tokens; l++) {
|
|
|
|
if (0 != strcmp(src[j]->values[k]->tokens[l], dst[j]->values[k]->tokens[l])) {
|
|
|
|
test_comment ("test14: invalid results (values-tokens) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
} /* for each token inside each grp value */
|
|
|
|
|
|
|
|
if (src[j]->values[k]->cnt != dst[j]->values[k]->cnt) {
|
2005-03-14 20:57:21 +00:00
|
|
|
test_comment ("test14: invalid results (values-cnt (of keyval pairs)) from unpack");
|
|
|
|
return(false);
|
2005-05-01 00:47:35 +00:00
|
|
|
}
|
|
|
|
for (l=0; l< src[j]->values[k]->cnt; l++) {
|
|
|
|
if (0 != strcmp(src[j]->values[k]->keyvals[l]->key, dst[j]->values[k]->keyvals[l]->key)) {
|
|
|
|
test_comment ("test14: invalid results (values-keyvals-key) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if (src[j]->values[k]->keyvals[l]->type != dst[j]->values[k]->keyvals[l]->type) {
|
|
|
|
test_comment ("test14: invalid results (values-keyvals-type) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
if (src[j]->values[k]->keyvals[l]->value.i32 != dst[j]->values[k]->keyvals[l]->value.i32) {
|
|
|
|
test_comment ("test14: invalid results (values-keyvals-value.i32) from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}/* for each keyvalpair inside each grp value */
|
2005-03-14 20:57:21 +00:00
|
|
|
} /* for each grp value */
|
2005-05-01 00:47:35 +00:00
|
|
|
OBJ_RELEASE(dst[j]);
|
2005-03-14 20:57:21 +00:00
|
|
|
} /* for each ELEMENT */
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
for(i=0; i<NUM_ELEMS; i++) {
|
|
|
|
OBJ_RELEASE(src[i]);
|
|
|
|
}
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
2005-05-01 00:47:35 +00:00
|
|
|
/*
|
|
|
|
* OMPI_INT pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test15(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
int src[NUM_ELEMS];
|
|
|
|
int dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_INT);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = -1;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_INT);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test15: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_UINT pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test16(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
unsigned int src[NUM_ELEMS];
|
|
|
|
unsigned int dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_UINT);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = 0;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_UINT);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test16: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_SIZE pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test17(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
size_t src[NUM_ELEMS];
|
|
|
|
size_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_SIZE);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = 0;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_SIZE);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test15: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* OMPI_PID pack/unpack
|
|
|
|
*/
|
|
|
|
static bool test18(void)
|
|
|
|
{
|
|
|
|
orte_buffer_t *bufA;
|
|
|
|
int rc;
|
|
|
|
int32_t i;
|
|
|
|
pid_t src[NUM_ELEMS];
|
|
|
|
pid_t dst[NUM_ELEMS];
|
|
|
|
|
|
|
|
for(i=0; i<NUM_ELEMS; i++)
|
|
|
|
src[i] = i;
|
|
|
|
|
|
|
|
bufA = OBJ_NEW(orte_buffer_t);
|
|
|
|
if (NULL == bufA) {
|
|
|
|
test_comment("orte_buffer failed init in OBJ_NEW");
|
|
|
|
fprintf(test_out, "OBJ_NEW failed\n");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0;i<NUM_ITERS;i++) {
|
|
|
|
rc = orte_dps.pack(bufA, src, NUM_ELEMS, ORTE_PID);
|
|
|
|
if (ORTE_SUCCESS != rc) {
|
|
|
|
test_comment ("orte_dps.pack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<NUM_ITERS; i++) {
|
|
|
|
int j;
|
|
|
|
size_t count = NUM_ELEMS;
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++)
|
|
|
|
dst[j] = -1;
|
|
|
|
|
|
|
|
rc = orte_dps.unpack(bufA, dst, &count, ORTE_PID);
|
|
|
|
if (ORTE_SUCCESS != rc || count != NUM_ELEMS) {
|
|
|
|
test_comment ("orte_dps.unpack failed");
|
|
|
|
fprintf(test_out, "orte_pack_value failed with return code %d\n", rc);
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
|
|
|
|
for(j=0; j<NUM_ELEMS; j++) {
|
|
|
|
if(src[j] != dst[j]) {
|
|
|
|
test_comment ("test18: invalid results from unpack");
|
|
|
|
return(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
OBJ_RELEASE(bufA);
|
|
|
|
if (NULL != bufA) {
|
|
|
|
test_comment("OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
fprintf(test_out, "OBJ_RELEASE did not NULL the buffer pointer");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (true);
|
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
|