2004-07-09 01:58:08 +00:00
|
|
|
/*
|
2005-04-08 11:21:43 +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.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
2004-07-09 01:58:08 +00:00
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
#include "orte_config.h"
|
2004-07-09 01:58:08 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2004-08-10 19:03:42 +00:00
|
|
|
#include "support.h"
|
2005-04-08 11:21:43 +00:00
|
|
|
#include "components.h"
|
2004-07-09 01:58:08 +00:00
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
#include "include/orte_constants.h"
|
2005-05-01 00:58:06 +00:00
|
|
|
#include "mca/schema/schema.h"
|
2004-07-11 01:18:59 +00:00
|
|
|
#include "util/proc_info.h"
|
2005-04-09 14:29:29 +00:00
|
|
|
#include "util/malloc.h"
|
2005-07-03 23:31:27 +00:00
|
|
|
#include "opal/util/output.h"
|
2004-07-09 01:58:08 +00:00
|
|
|
#include "mca/mca.h"
|
|
|
|
#include "mca/base/base.h"
|
|
|
|
#include "mca/ns/base/base.h"
|
|
|
|
|
2004-08-10 19:03:42 +00:00
|
|
|
/* output files needed by the test */
|
|
|
|
static FILE *test_out=NULL;
|
|
|
|
|
|
|
|
static char *cmd_str="diff ./test_ns_replica_out ./test_ns_replica_out_std";
|
|
|
|
|
2004-07-09 01:58:08 +00:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
2005-03-14 20:57:21 +00:00
|
|
|
orte_process_name_t *test_name;
|
|
|
|
orte_cellid_t cell;
|
|
|
|
orte_jobid_t job;
|
|
|
|
orte_vpid_t vpid;
|
2005-03-22 19:56:45 +00:00
|
|
|
int i, j, rc;
|
2005-05-16 21:01:09 +00:00
|
|
|
char *tmp, *site, *resource;
|
2005-04-08 11:21:43 +00:00
|
|
|
test_component_handle_t ns_handle;
|
|
|
|
mca_ns_base_component_t *ns_component = NULL;
|
|
|
|
mca_ns_base_module_t *ns_module = NULL;
|
|
|
|
int priority;
|
2004-08-10 19:03:42 +00:00
|
|
|
|
|
|
|
test_init("test_ns_replica");
|
|
|
|
|
|
|
|
test_out = fopen( "test_ns_replica_out", "w+" );
|
|
|
|
if( test_out == NULL ) {
|
|
|
|
test_failure("test_ns_replica couldn't open test file failed");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
2004-07-09 01:58:08 +00:00
|
|
|
|
2005-03-22 20:48:55 +00:00
|
|
|
/* Open up the output streams */
|
2005-07-03 23:31:27 +00:00
|
|
|
if (!opal_output_init()) {
|
2005-03-22 20:48:55 +00:00
|
|
|
return OMPI_ERROR;
|
|
|
|
}
|
2005-04-08 11:21:43 +00:00
|
|
|
|
2005-03-22 20:48:55 +00:00
|
|
|
/*
|
2005-04-08 11:21:43 +00:00
|
|
|
* If threads are supported - assume that we are using threads -
|
|
|
|
* and reset otherwise.
|
2005-03-22 20:48:55 +00:00
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_set_using_threads(OMPI_HAVE_THREAD_SUPPORT);
|
2005-04-08 11:21:43 +00:00
|
|
|
|
2005-03-22 20:48:55 +00:00
|
|
|
/* For malloc debugging */
|
|
|
|
ompi_malloc_init();
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
/* set seed to true to force replica selection */
|
|
|
|
orte_process_info.seed = true;
|
2004-07-11 01:18:59 +00:00
|
|
|
|
2005-03-22 19:56:45 +00:00
|
|
|
/* ensure the replica is isolated */
|
2005-04-04 22:55:26 +00:00
|
|
|
setenv("OMPI_MCA_ns_replica_isolate", "1", 1);
|
2005-03-22 19:56:45 +00:00
|
|
|
|
|
|
|
/* init the proc info structure */
|
|
|
|
orte_proc_info();
|
|
|
|
|
2004-07-09 01:58:08 +00:00
|
|
|
/* startup the MCA */
|
|
|
|
if (OMPI_SUCCESS == mca_base_open()) {
|
2004-08-10 19:03:42 +00:00
|
|
|
fprintf(test_out, "MCA started\n");
|
2004-07-09 01:58:08 +00:00
|
|
|
} else {
|
2004-08-10 19:03:42 +00:00
|
|
|
fprintf(test_out, "MCA could not start - please report error to bugs@open-mpi.org\n");
|
2004-07-09 01:58:08 +00:00
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
2005-04-08 11:21:43 +00:00
|
|
|
/* Open the ns replica component and initialize a module */
|
|
|
|
if (OMPI_SUCCESS !=
|
|
|
|
test_component_open("ns", "replica", &ns_handle,
|
|
|
|
(mca_base_component_t**) &ns_component) ||
|
|
|
|
NULL == ns_component) {
|
|
|
|
test_fail_stop("Could not open ns replica\n", 1);
|
2004-07-09 01:58:08 +00:00
|
|
|
}
|
2005-04-08 11:21:43 +00:00
|
|
|
ns_module = ns_component->ns_init(&priority);
|
|
|
|
if (NULL == ns_module) {
|
|
|
|
test_fail_stop("NS replica component did not return a module\n", 1);
|
2004-07-09 01:58:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* create a name */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->create_process_name(&test_name, 0, 1, 1))) { /* got error */
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "create process name failed with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica orte_ns create_process_name failed");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
2004-07-09 01:58:08 +00:00
|
|
|
} else {
|
2005-05-08 13:22:55 +00:00
|
|
|
fprintf(test_out, "got process name: %lu %lu %lu\n", ORTE_NAME_ARGS(test_name));
|
2005-03-22 19:56:45 +00:00
|
|
|
test_success();
|
2004-08-03 15:58:08 +00:00
|
|
|
}
|
2005-03-22 20:48:55 +00:00
|
|
|
free(test_name);
|
|
|
|
|
2004-08-03 15:58:08 +00:00
|
|
|
/* convert a string to a name */
|
|
|
|
tmp = strdup("1234.5678.9AEF");
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->convert_string_to_process_name(&test_name, tmp))) { /* got error */
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "convert string to process name failed with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica orte_ns convert_string_to_process_name failed");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
2004-08-03 15:58:08 +00:00
|
|
|
} else {
|
2005-05-08 13:22:55 +00:00
|
|
|
fprintf(test_out, "got process name: %lu %lu %lu\n",
|
2005-03-22 19:56:45 +00:00
|
|
|
ORTE_NAME_ARGS(test_name));
|
2004-08-10 19:03:42 +00:00
|
|
|
test_success();
|
2004-07-09 01:58:08 +00:00
|
|
|
}
|
2005-03-22 20:48:55 +00:00
|
|
|
free(tmp);
|
|
|
|
free(test_name);
|
|
|
|
|
2004-07-12 03:21:18 +00:00
|
|
|
/* create a cellid */
|
2005-05-16 21:01:09 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->create_cellid(&cell, "dummy-site", "dummy-resource"))) { /* got error */
|
2005-03-22 19:56:45 +00:00
|
|
|
test_failure("test_ns_replica orte_ns test create_cellid failed");
|
|
|
|
fprintf(test_out, "create cellid: error with error %s\n", ORTE_ERROR_NAME(rc));
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
2004-07-12 03:21:18 +00:00
|
|
|
} else {
|
2005-05-10 23:28:31 +00:00
|
|
|
fprintf(test_out, "cellid created: %lu\n", (unsigned long) cell);
|
2005-03-22 19:56:45 +00:00
|
|
|
test_success();
|
2004-07-12 03:21:18 +00:00
|
|
|
}
|
|
|
|
|
2005-05-16 21:01:09 +00:00
|
|
|
/* get cellid info */
|
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_cell_info(cell, &site, &resource))) { /* got error */
|
|
|
|
test_failure("test_ns_replica orte_ns test get_cell_info failed");
|
|
|
|
fprintf(test_out, "get_cell_info: error with error %s\n", ORTE_ERROR_NAME(rc));
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
|
|
|
fprintf(test_out, "get_cell_info: %lu %s %s\n", (unsigned long) cell, site, resource);
|
|
|
|
test_success();
|
|
|
|
}
|
|
|
|
|
2004-07-12 03:21:18 +00:00
|
|
|
for (i=0; i<10; i++) { /* loop through */
|
2005-03-22 19:56:45 +00:00
|
|
|
/* create jobid */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->create_jobid(&job))) { /* got error */
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "create jobid: error with error %s\n", ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica orte_ns create_jobid failed");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
2005-05-10 23:28:31 +00:00
|
|
|
fprintf(test_out, "jobid created: %lu\n", (unsigned long) job);
|
2005-03-22 19:56:45 +00:00
|
|
|
test_success();
|
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
|
2005-03-22 19:56:45 +00:00
|
|
|
for (j=0; j<5; j++) { /* loop through several vpid ranges */
|
|
|
|
/* get range of vpids */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->reserve_range(job, 250, &vpid))) { /* got error */
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "get range: error with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica orte_ns reserve_range failed");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
2005-05-10 23:28:31 +00:00
|
|
|
fprintf(test_out, "range reserved: %lu\n",
|
|
|
|
(unsigned long) vpid);
|
2005-03-22 19:56:45 +00:00
|
|
|
test_success();
|
|
|
|
}
|
2005-03-14 20:57:21 +00:00
|
|
|
|
2005-03-22 19:56:45 +00:00
|
|
|
/* create a name */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->create_process_name(&test_name, (orte_cellid_t)i,
|
2005-03-22 19:56:45 +00:00
|
|
|
job, vpid))) {
|
|
|
|
fprintf(test_out, "test_ns_replica: failed to create proc name after vpid range with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to create proc name after vpid range");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* get and print its string values */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_proc_name_string(&tmp, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get proc_name_string with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get proc_name_string");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
|
|
|
fprintf(test_out, "(%d) strings: name - %s\n", i, tmp);
|
|
|
|
}
|
|
|
|
free(tmp);
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_vpid_string(&tmp, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get vpid_string with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get vpid_string");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
|
|
|
fprintf(test_out, "(%d) strings: vpid - %s\n", i, tmp);
|
|
|
|
}
|
|
|
|
free(tmp);
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_jobid_string(&tmp, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get jobid_string with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get jobid_string");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
|
|
|
fprintf(test_out, "(%d) strings: jobid - %s\n", i, tmp);
|
|
|
|
}
|
|
|
|
free(tmp);
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_cellid_string(&tmp, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get cellid_string with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get cellid_string");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
} else {
|
|
|
|
fprintf(test_out, "(%d) strings: cellid - %s\n", i, tmp);
|
|
|
|
}
|
|
|
|
free(tmp);
|
|
|
|
|
|
|
|
/* get and print its numeric values */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_vpid(&vpid, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get vpid with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get vpid");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_jobid(&job, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get jobid with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get jobid");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
2005-04-08 11:21:43 +00:00
|
|
|
if (ORTE_SUCCESS != (rc = ns_module->get_cellid(&cell, test_name))) {
|
2005-03-22 19:56:45 +00:00
|
|
|
fprintf(test_out, "test_ns_replica: failed to get cellid with error %s\n",
|
|
|
|
ORTE_ERROR_NAME(rc));
|
|
|
|
test_failure("test_ns_replica: failed to get cellid");
|
|
|
|
test_finalize();
|
|
|
|
exit(1);
|
|
|
|
}
|
2005-05-10 23:28:31 +00:00
|
|
|
fprintf(test_out, "(%d) ints cell %lu job %lu vpid %lu\n\n",
|
|
|
|
i, (unsigned long) cell, (unsigned long) job,
|
|
|
|
(unsigned long) vpid);
|
2005-03-22 20:48:55 +00:00
|
|
|
free(test_name);
|
2005-03-22 19:56:45 +00:00
|
|
|
}
|
2004-07-12 03:21:18 +00:00
|
|
|
}
|
|
|
|
|
2005-03-22 19:56:45 +00:00
|
|
|
/* finalize and see if memory cleared */
|
2005-04-08 11:21:43 +00:00
|
|
|
if (NULL != ns_component->ns_finalize) {
|
|
|
|
ns_component->ns_finalize();
|
|
|
|
}
|
|
|
|
test_component_close(&ns_handle);
|
|
|
|
|
2005-03-22 19:56:45 +00:00
|
|
|
orte_proc_info_finalize();
|
|
|
|
mca_base_close();
|
2005-03-22 20:48:55 +00:00
|
|
|
ompi_malloc_finalize();
|
2005-07-03 23:31:27 +00:00
|
|
|
opal_output_finalize();
|
2005-03-22 19:56:45 +00:00
|
|
|
|
2005-03-22 20:48:55 +00:00
|
|
|
fclose( test_out );
|
2004-08-10 19:03:42 +00:00
|
|
|
test_finalize();
|
2004-07-12 03:21:18 +00:00
|
|
|
|
2004-07-09 01:58:08 +00:00
|
|
|
return(0);
|
|
|
|
}
|