89b6a97f0f
Need to do some refining of the component, but it meets basic requirements right now. Nobody else should notice any change - system basically ignores it unless you tell it to do something. This commit was SVN r5723.
512 строки
18 KiB
C
512 строки
18 KiB
C
/*
|
|
* 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.
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
/** @file:
|
|
*
|
|
* The Open MPI general purpose registry - unit test
|
|
*
|
|
*/
|
|
|
|
/*
|
|
* includes
|
|
*/
|
|
|
|
#include "orte_config.h"
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#ifdef HAVE_UNISTD_H
|
|
#include <unistd.h>
|
|
#endif
|
|
|
|
#include "include/orte_constants.h"
|
|
#include "mca/schema/schema.h"
|
|
#include "mca/schema/base/base.h"
|
|
#include "mca/ns/base/base.h"
|
|
#include "mca/soh/base/base.h"
|
|
#include "mca/rmgr/base/base.h"
|
|
|
|
#include "support.h"
|
|
#include "components.h"
|
|
|
|
#include "class/orte_pointer_array.h"
|
|
#include "dps/dps.h"
|
|
#include "runtime/runtime.h"
|
|
#include "util/proc_info.h"
|
|
#include "util/sys_info.h"
|
|
#include "util/malloc.h"
|
|
#include "util/output.h"
|
|
|
|
#include "mca/gpr/base/base.h"
|
|
#include "mca/gpr/replica/api_layer/gpr_replica_api.h"
|
|
#include "mca/gpr/replica/functional_layer/gpr_replica_fn.h"
|
|
#include "mca/gpr/replica/communications/gpr_replica_comm.h"
|
|
#include "mca/gpr/replica/transition_layer/gpr_replica_tl.h"
|
|
|
|
/* output files needed by the test */
|
|
static FILE *test_out=NULL;
|
|
|
|
static char *cmd_str="diff ./test_gpr_replica_out ./test_gpr_replica_out_std";
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
int rc;
|
|
size_t i, j, cnt;
|
|
char *names[15], *keys[5];
|
|
orte_gpr_keyval_t **kvals;
|
|
orte_gpr_value_t **values, *val;
|
|
test_component_handle_t handle;
|
|
mca_gpr_base_component_t *gpr_component = NULL;
|
|
orte_gpr_base_module_t *gpr_module = NULL;
|
|
bool allow, have;
|
|
int priority;
|
|
|
|
test_init("test_gpr_replica");
|
|
|
|
if (getenv("TEST_WRITE_TO_FILE") != NULL) {
|
|
test_out = fopen( "test_gpr_replica_out", "w+" );
|
|
} else {
|
|
test_out = stderr;
|
|
}
|
|
if( test_out == NULL ) {
|
|
test_failure("gpr_test couldn't open test file failed");
|
|
test_finalize();
|
|
exit(1);
|
|
}
|
|
|
|
/* ENSURE THE REPLICA IS ISOLATED */
|
|
setenv("OMPI_MCA_gpr_replica_isolate", "1", 1);
|
|
|
|
/* 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();
|
|
|
|
/* Ensure the system_info structure is instantiated and initialized */
|
|
if (ORTE_SUCCESS != (rc = orte_sys_info())) {
|
|
return rc;
|
|
}
|
|
|
|
/* Ensure the process info structure is instantiated and initialized */
|
|
if (ORTE_SUCCESS != (rc = orte_proc_info())) {
|
|
return rc;
|
|
}
|
|
|
|
orte_process_info.seed = true;
|
|
orte_process_info.my_name = (orte_process_name_t*)malloc(sizeof(orte_process_name_t));
|
|
orte_process_info.my_name->cellid = 0;
|
|
orte_process_info.my_name->jobid = 0;
|
|
orte_process_info.my_name->vpid = 0;
|
|
|
|
/* startup the MCA */
|
|
if (OMPI_SUCCESS == mca_base_open()) {
|
|
fprintf(test_out, "MCA started\n");
|
|
} else {
|
|
fprintf(test_out, "MCA could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* startup the dps */
|
|
if (OMPI_SUCCESS == orte_dps_open()) {
|
|
fprintf(test_out, "DPS started\n");
|
|
} else {
|
|
fprintf(test_out, "DPS could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* startup the name services */
|
|
if (OMPI_SUCCESS == orte_ns_base_open()) {
|
|
fprintf(test_out, "NS started\n");
|
|
} else {
|
|
fprintf(test_out, "NS could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* startup the soh */
|
|
if (OMPI_SUCCESS == orte_soh_base_open()) {
|
|
fprintf(test_out, "SOH started\n");
|
|
} else {
|
|
fprintf(test_out, "SOH could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* startup the rmgr */
|
|
if (OMPI_SUCCESS == orte_rmgr_base_open()) {
|
|
fprintf(test_out, "RMGR started\n");
|
|
} else {
|
|
fprintf(test_out, "RMGR could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* startup the schema */
|
|
if (OMPI_SUCCESS == orte_schema_base_open()) {
|
|
fprintf(test_out, "SCHEMA started\n");
|
|
} else {
|
|
fprintf(test_out, "SCHEMA could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* Open the gpr replica component and initialize a module */
|
|
if (OMPI_SUCCESS !=
|
|
test_component_open("gpr", "replica", &handle,
|
|
(mca_base_component_t**) &gpr_component) ||
|
|
NULL == gpr_component) {
|
|
fprintf(test_out, "Could not open replica\n");
|
|
exit(1);
|
|
}
|
|
gpr_module = gpr_component->gpr_init(&allow, &have, &priority);
|
|
if (NULL == gpr_module) {
|
|
fprintf(test_out, "replica component did not return a module\n");
|
|
exit(1);
|
|
}
|
|
|
|
if (ORTE_SUCCESS == orte_dps_open()) {
|
|
fprintf(test_out, "DPS started\n");
|
|
} else {
|
|
fprintf(test_out, "DPS could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
fprintf(stderr, "put one value with single keyval\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->cnt = 1;
|
|
val->segment = strdup("test-put-segment");
|
|
val->num_tokens = 14;
|
|
val->tokens = (char**)malloc(val->num_tokens * sizeof(char*));
|
|
for (i=0; i < 14; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy%lu", (unsigned long) i);
|
|
}
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
(val->keyvals[0])->key = strdup("stupid-value-next-one");
|
|
(val->keyvals[0])->type = ORTE_INT32;
|
|
(val->keyvals[0])->value.i32 = 654321;
|
|
if (ORTE_SUCCESS != (rc = gpr_module->put(1, &val))) {
|
|
fprintf(test_out, "gpr_test: put of 1 value/1 keyval failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: put of 1 value/1 keyval failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: put of 1 value/1 keyval passed\n");
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
fprintf(stderr, "put one value with multiple keyvals\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->cnt = 20;
|
|
val->segment = strdup("test-put-segment");
|
|
val->num_tokens = 14;
|
|
val->tokens = (char**)malloc(val->num_tokens * sizeof(char*));
|
|
for (i=0; i < 14; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy%lu", (unsigned long) i);
|
|
}
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(20*sizeof(orte_gpr_keyval_t*));
|
|
for (i=0; i<20; i++) {
|
|
val->keyvals[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
asprintf(&((val->keyvals[i])->key), "stupid-test-%lu",
|
|
(unsigned long) i);
|
|
(val->keyvals[i])->type = ORTE_UINT32;
|
|
(val->keyvals[i])->value.ui32 = (uint32_t)i;
|
|
}
|
|
if (ORTE_SUCCESS != (rc = gpr_module->put(1, &val))) {
|
|
fprintf(test_out, "gpr_test: put 1 value/multiple keyval failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: put 1 value/multiple keyval failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: put 1 value/multiple keyval passed\n");
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
fprintf(stderr, "put 1 value/multiple keyvals - second container\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->segment = strdup("test-put-segment");
|
|
val->num_tokens = 10;
|
|
val->tokens = (char**)malloc(val->num_tokens * sizeof(char*));
|
|
for (i=0; i < val->num_tokens; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy%lu", (unsigned long) i);
|
|
}
|
|
val->cnt = 20;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(val->cnt * sizeof(orte_gpr_keyval_t*));
|
|
for (i=0; i<val->cnt; i++) {
|
|
val->keyvals[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
asprintf(&((val->keyvals[i])->key), "stupid-test-%lu",
|
|
(unsigned long) i);
|
|
(val->keyvals[i])->type = ORTE_UINT32;
|
|
(val->keyvals[i])->value.ui32 = (uint32_t)i;
|
|
}
|
|
if (ORTE_SUCCESS != (rc = gpr_module->put(1, &val))) {
|
|
fprintf(test_out, "gpr_test: put 1 value/multiple keyval in second container failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: put 1 value/multiple keyval in second container failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: put 1 value/multiple keyval in second container passed\n");
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
fprintf(stderr, "dump\n");
|
|
if (ORTE_SUCCESS != (rc = gpr_module->dump_all(0))) {
|
|
fprintf(test_out, "gpr_test: dump failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: dump failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: dump passed\n");
|
|
}
|
|
|
|
fprintf(stderr, "get\n");
|
|
names[0] = strdup("dummy0");
|
|
names[1] = NULL;
|
|
keys[0] = strdup("stupid-test-1");
|
|
keys[1] = NULL;
|
|
if (ORTE_SUCCESS != (rc = gpr_module->get(ORTE_GPR_KEYS_OR | ORTE_GPR_TOKENS_OR,
|
|
"test-put-segment",
|
|
names, keys,
|
|
&cnt, &values))) {
|
|
fprintf(test_out, "gpr_test: get failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: get failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: get passed\n");
|
|
}
|
|
free(keys[0]);
|
|
|
|
fprintf(stderr, "get results:\n");
|
|
for (j=0; j < cnt; j++) {
|
|
fprintf(stderr, "value %lu: cnt %lu\t segment %s num_tokens %lu\n",
|
|
(unsigned long) j, (unsigned long) values[j]->cnt,
|
|
values[j]->segment, (unsigned long) values[j]->num_tokens);
|
|
for (i=0; i < values[j]->num_tokens; i++) {
|
|
fprintf(stderr, "token: %lu %s\n", (unsigned long) i,
|
|
values[j]->tokens[i]);
|
|
}
|
|
kvals = values[j]->keyvals;
|
|
for (i=0; i < values[j]->cnt; i++) {
|
|
fprintf(stderr, "\tkey %s type %d\n", kvals[i]->key, kvals[i]->type);
|
|
}
|
|
OBJ_RELEASE(values[j]);
|
|
}
|
|
free(values);
|
|
|
|
fprintf(stderr, "get multiple in one segment, multiple containers\n");
|
|
keys[0] = strdup("stupid-test-1");
|
|
keys[1] = strdup("stupid-test-3");
|
|
keys[2] = strdup("stupid-test-5");
|
|
keys[3] = strdup("stupid-test-8");
|
|
keys[4] = NULL;
|
|
if (ORTE_SUCCESS != (rc = gpr_module->get(ORTE_GPR_KEYS_OR | ORTE_GPR_TOKENS_OR,
|
|
"test-put-segment",
|
|
names, keys,
|
|
&cnt, &values))) {
|
|
fprintf(test_out, "gpr_test: get failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: get failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: get passed\n");
|
|
}
|
|
for (i=0; i < 4; i++) free(keys[i]);
|
|
free(names[0]);
|
|
|
|
fprintf(stderr, "get results:\n");
|
|
for (j=0; j < cnt; j++) {
|
|
fprintf(stderr, "value %lu: cnt %lu\t segment %s num_tokens %lu\n",
|
|
(unsigned long) j, (unsigned long) values[j]->cnt,
|
|
values[j]->segment, (unsigned long) values[j]->num_tokens);
|
|
for (i=0; i < values[j]->num_tokens; i++) {
|
|
fprintf(stderr, "token: %lu %s\n", (unsigned long) i,
|
|
values[j]->tokens[i]);
|
|
}
|
|
kvals = values[j]->keyvals;
|
|
for (i=0; i < values[j]->cnt; i++) {
|
|
fprintf(stderr, "\tkey %s type %d\n", kvals[i]->key, kvals[i]->type);
|
|
}
|
|
OBJ_RELEASE(values[j]);
|
|
}
|
|
free(values);
|
|
|
|
fprintf(stderr, "put multiple copies of same entry in single container\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->cnt = 1;
|
|
val->segment = strdup("test-put-segment");
|
|
val->num_tokens = 5;
|
|
val->tokens = (char**)malloc(val->num_tokens * sizeof(char*));
|
|
for (i=0; i < 5; i++) {
|
|
asprintf(&(val->tokens[i]), "multi-dum-dum-%lu", (unsigned long) i);
|
|
}
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
(val->keyvals[0])->key = strdup("stupid-value-next-one");
|
|
(val->keyvals[0])->type = ORTE_STRING;
|
|
(val->keyvals[0])->value.strptr = strdup("try-string-value");
|
|
for (i = 0; i < 10; i++) {
|
|
fprintf(stderr, "\tputting copy %lu\n", (unsigned long) i);
|
|
if (ORTE_SUCCESS != (rc = gpr_module->put(1, &val))) {
|
|
fprintf(test_out, "gpr_test: put multiple copies of one keyval in a container failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: put multiple copies of one keyval in a container failed");
|
|
test_finalize();
|
|
return rc;
|
|
}
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
gpr_module->dump_all(0);
|
|
|
|
fprintf(stderr, "put with no tokens puts in every container\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE;
|
|
val->cnt = 1;
|
|
val->segment = strdup("test-put-segment");
|
|
val->num_tokens = 0;
|
|
val->tokens = NULL;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
(val->keyvals[0])->key = strdup("stupid-value-next-one");
|
|
(val->keyvals[0])->type = ORTE_STRING;
|
|
(val->keyvals[0])->value.strptr = strdup("try-string-value");
|
|
if (ORTE_SUCCESS != (rc = gpr_module->put(1, &val))) {
|
|
fprintf(test_out, "gpr_test: put with no tokens failed - returned %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: put with no tokens failed");
|
|
test_finalize();
|
|
} else {
|
|
fprintf(test_out, "gpr_test: put with no tokens passed\n");
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
gpr_module->dump_all(0);
|
|
|
|
fprintf(stderr, "get with no tokens, KEYS_OR\n");
|
|
keys[0] = strdup("stupid-test-1");
|
|
keys[1] = strdup("stupid-test-3");
|
|
keys[2] = strdup("stupid-test-5");
|
|
keys[3] = strdup("stupid-test-8");
|
|
keys[4] = NULL;
|
|
if (ORTE_SUCCESS != (rc = gpr_module->get(ORTE_GPR_KEYS_OR | ORTE_GPR_TOKENS_OR,
|
|
"test-put-segment",
|
|
NULL, keys,
|
|
&cnt, &values))) {
|
|
fprintf(test_out, "gpr_test: get failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: get failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: get with no tokens, KEYS_OR passed\n");
|
|
}
|
|
for (i=0; i < 4; i++) free(keys[i]);
|
|
free(names[0]);
|
|
|
|
fprintf(stderr, "get results:\n");
|
|
for (j=0; j < cnt; j++) {
|
|
fprintf(stderr, "value %lu: cnt %lu\t segment %s num_tokens %lu\n",
|
|
(unsigned long) j, (unsigned long) values[j]->cnt,
|
|
values[j]->segment, (unsigned long) values[j]->num_tokens);
|
|
for (i=0; i < values[j]->num_tokens; i++) {
|
|
fprintf(stderr, "token: %lu %s\n", (unsigned long) i,
|
|
values[j]->tokens[i]);
|
|
}
|
|
kvals = values[j]->keyvals;
|
|
for (i=0; i < values[j]->cnt; i++) {
|
|
fprintf(stderr, "\tkey %s type %d\n", kvals[i]->key, kvals[i]->type);
|
|
}
|
|
OBJ_RELEASE(values[j]);
|
|
}
|
|
free(values);
|
|
|
|
fprintf(stderr, "get with no tokens, KEYS_AND\n");
|
|
keys[0] = strdup("stupid-test-1");
|
|
keys[1] = strdup("stupid-test-3");
|
|
keys[2] = strdup("stupid-test-5");
|
|
keys[3] = strdup("stupid-test-8");
|
|
keys[4] = NULL;
|
|
if (ORTE_SUCCESS != (rc = gpr_module->get(ORTE_GPR_KEYS_AND | ORTE_GPR_TOKENS_OR,
|
|
"test-put-segment",
|
|
NULL, keys,
|
|
&cnt, &values))) {
|
|
fprintf(test_out, "gpr_test: get failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("gpr_test: get failed");
|
|
test_finalize();
|
|
return rc;
|
|
} else {
|
|
fprintf(test_out, "gpr_test: get with no tokens, KEYS_AND passed\n");
|
|
}
|
|
for (i=0; i < 4; i++) free(keys[i]);
|
|
free(names[0]);
|
|
|
|
fprintf(stderr, "get results:\n");
|
|
for (j=0; j < cnt; j++) {
|
|
fprintf(stderr, "value %lu: cnt %lu\t segment %s num_tokens %lu\n",
|
|
(unsigned long) j, (unsigned long) values[j]->cnt,
|
|
values[j]->segment, (unsigned long) values[j]->num_tokens);
|
|
for (i=0; i < values[j]->num_tokens; i++) {
|
|
fprintf(stderr, "token: %lu %s\n", (unsigned long) i,
|
|
values[j]->tokens[i]);
|
|
}
|
|
kvals = values[j]->keyvals;
|
|
for (i=0; i < values[j]->cnt; i++) {
|
|
fprintf(stderr, "\tkey %s type %d\n", kvals[i]->key, kvals[i]->type);
|
|
}
|
|
OBJ_RELEASE(values[j]);
|
|
}
|
|
free(values);
|
|
|
|
fprintf(stderr, "now finalize and see if all memory cleared\n");
|
|
test_component_close(&handle);
|
|
orte_dps_close();
|
|
orte_sys_info_finalize();
|
|
orte_proc_info_finalize();
|
|
mca_base_close();
|
|
ompi_malloc_finalize();
|
|
ompi_output_finalize();
|
|
ompi_class_finalize();
|
|
|
|
fclose( test_out );
|
|
/* result = system( cmd_str );
|
|
if( result == 0 ) {
|
|
test_success();
|
|
}
|
|
else {
|
|
test_failure( "test_gpr_replica failed");
|
|
}
|
|
*/
|
|
test_finalize();
|
|
unlink("test_gpr_replica_out");
|
|
|
|
return(0);
|
|
}
|