2004-07-09 05:58:08 +04:00
|
|
|
/*
|
|
|
|
* unit test for name server replica.
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
Authors: Ralph H. Castain <rhc@lanl.gov>
|
|
|
|
|
|
|
|
--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
#include "orte_config.h"
|
2004-07-09 05:58:08 +04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
2004-08-10 23:03:42 +04:00
|
|
|
#include "support.h"
|
2004-07-09 05:58:08 +04:00
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
#include "include/orte_constants.h"
|
2005-03-22 22:56:45 +03:00
|
|
|
#include "include/orte_schema.h"
|
2004-07-11 05:18:59 +04:00
|
|
|
#include "util/proc_info.h"
|
2004-07-09 05:58:08 +04:00
|
|
|
#include "mca/mca.h"
|
|
|
|
#include "mca/base/base.h"
|
|
|
|
#include "mca/ns/base/base.h"
|
|
|
|
|
2004-08-10 23:03:42 +04: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 05:58:08 +04:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_process_name_t *test_name;
|
|
|
|
orte_cellid_t cell;
|
|
|
|
orte_jobid_t job;
|
|
|
|
orte_vpid_t vpid;
|
2005-03-22 22:56:45 +03:00
|
|
|
int i, j, rc;
|
2004-07-12 07:21:18 +04:00
|
|
|
char *tmp;
|
2004-08-10 23:03:42 +04: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 05:58:08 +04:00
|
|
|
|
2005-03-22 23:48:55 +03: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 23:57:21 +03:00
|
|
|
/* set seed to true to force replica selection */
|
|
|
|
orte_process_info.seed = true;
|
2004-07-11 05:18:59 +04:00
|
|
|
|
2005-03-22 22:56:45 +03:00
|
|
|
/* ensure the replica is isolated */
|
|
|
|
setenv("OMPI_MCA_ns_replica_isolate", "1", 1);
|
|
|
|
|
|
|
|
/* init the proc info structure */
|
|
|
|
orte_proc_info();
|
|
|
|
|
2004-07-09 05:58:08 +04:00
|
|
|
/* startup the MCA */
|
|
|
|
if (OMPI_SUCCESS == mca_base_open()) {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "MCA started\n");
|
2004-07-09 05:58:08 +04:00
|
|
|
} else {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "MCA could not start - please report error to bugs@open-mpi.org\n");
|
2004-07-09 05:58:08 +04:00
|
|
|
exit (1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* open the name server */
|
2005-03-14 23:57:21 +03:00
|
|
|
if (OMPI_SUCCESS == orte_ns_base_open()) {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "NS opened\n");
|
|
|
|
test_success();
|
2004-07-09 05:58:08 +04:00
|
|
|
} else {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "NS could not open\n");
|
|
|
|
test_failure("test_ns_replica mca_ns_base_open failed");
|
|
|
|
test_finalize();
|
2004-07-09 05:58:08 +04:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* startup the name server */
|
2005-03-22 22:56:45 +03:00
|
|
|
if (OMPI_SUCCESS != orte_ns_base_select()) {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "NS could not start\n");
|
|
|
|
test_failure("test_ns_replica mca_ns_base_select failed");
|
|
|
|
test_finalize();
|
2004-07-09 05:58:08 +04:00
|
|
|
exit(1);
|
|
|
|
} else {
|
2004-08-10 23:03:42 +04:00
|
|
|
fprintf(test_out, "NS started\n");
|
|
|
|
test_success();
|
2004-07-09 05:58:08 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* create a name */
|
2005-03-22 22:56:45 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.create_process_name(&test_name, 0, 1, 1))) { /* got error */
|
|
|
|
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 05:58:08 +04:00
|
|
|
} else {
|
2005-03-22 22:56:45 +03:00
|
|
|
fprintf(test_out, "got process name: %0X %0X %0X\n", ORTE_NAME_ARGS(test_name));
|
|
|
|
test_success();
|
2004-08-03 19:58:08 +04:00
|
|
|
}
|
2005-03-22 23:48:55 +03:00
|
|
|
free(test_name);
|
|
|
|
|
2004-08-03 19:58:08 +04:00
|
|
|
/* convert a string to a name */
|
|
|
|
tmp = strdup("1234.5678.9AEF");
|
2005-03-22 22:56:45 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.convert_string_to_process_name(&test_name, tmp))) { /* got error */
|
|
|
|
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 19:58:08 +04:00
|
|
|
} else {
|
2005-03-22 22:56:45 +03:00
|
|
|
fprintf(test_out, "got process name: %0X %0X %0X\n",
|
|
|
|
ORTE_NAME_ARGS(test_name));
|
2004-08-10 23:03:42 +04:00
|
|
|
test_success();
|
2004-07-09 05:58:08 +04:00
|
|
|
}
|
2005-03-22 23:48:55 +03:00
|
|
|
free(tmp);
|
|
|
|
free(test_name);
|
|
|
|
|
2004-07-12 07:21:18 +04:00
|
|
|
/* create a cellid */
|
2005-03-22 22:56:45 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.create_cellid(&cell))) { /* got error */
|
|
|
|
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 07:21:18 +04:00
|
|
|
} else {
|
2005-03-22 22:56:45 +03:00
|
|
|
fprintf(test_out, "cellid created: %d\n", cell);
|
|
|
|
test_success();
|
2004-07-12 07:21:18 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i<10; i++) { /* loop through */
|
2005-03-22 22:56:45 +03:00
|
|
|
/* create jobid */
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.create_jobid(&job))) { /* got error */
|
|
|
|
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 {
|
|
|
|
fprintf(test_out, "jobid created: %d\n", job);
|
|
|
|
test_success();
|
|
|
|
}
|
2005-03-14 23:57:21 +03:00
|
|
|
|
2005-03-22 22:56:45 +03:00
|
|
|
for (j=0; j<5; j++) { /* loop through several vpid ranges */
|
|
|
|
/* get range of vpids */
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.reserve_range(job, 250, &vpid))) { /* got error */
|
|
|
|
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 {
|
|
|
|
fprintf(test_out, "range reserved: %d\n", vpid);
|
|
|
|
test_success();
|
|
|
|
}
|
2005-03-14 23:57:21 +03:00
|
|
|
|
2005-03-22 22:56:45 +03:00
|
|
|
/* create a name */
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.create_process_name(&test_name, (orte_cellid_t)i,
|
|
|
|
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 */
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_proc_name_string(&tmp, test_name))) {
|
|
|
|
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);
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_vpid_string(&tmp, test_name))) {
|
|
|
|
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);
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_jobid_string(&tmp, test_name))) {
|
|
|
|
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);
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_cellid_string(&tmp, test_name))) {
|
|
|
|
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 */
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_vpid(&vpid, test_name))) {
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_jobid(&job, test_name))) {
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_ns.get_cellid(&cell, test_name))) {
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
fprintf(test_out, "(%d) ints cell %0X(%ld) job %0X(%ld) vpid %0x(%ld)\n\n",
|
|
|
|
i, cell, (long int)cell, job, (long int)job, vpid, (long int)vpid);
|
2005-03-22 23:48:55 +03:00
|
|
|
free(test_name);
|
2005-03-22 22:56:45 +03:00
|
|
|
}
|
2004-07-12 07:21:18 +04:00
|
|
|
}
|
|
|
|
|
2005-03-22 22:56:45 +03:00
|
|
|
/* finalize and see if memory cleared */
|
|
|
|
orte_ns_base_close();
|
|
|
|
orte_proc_info_finalize();
|
|
|
|
mca_base_close();
|
2005-03-22 23:48:55 +03:00
|
|
|
ompi_malloc_finalize();
|
|
|
|
ompi_output_finalize();
|
2005-03-22 22:56:45 +03:00
|
|
|
|
2005-03-22 23:48:55 +03:00
|
|
|
fclose( test_out );
|
2004-08-10 23:03:42 +04:00
|
|
|
test_finalize();
|
2004-07-12 07:21:18 +04:00
|
|
|
|
2004-07-09 05:58:08 +04:00
|
|
|
return(0);
|
|
|
|
}
|