42ec26e640
This commit was SVN r7999.
1088 строки
35 KiB
C
1088 строки
35 KiB
C
/*
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
* of Tennessee Research Foundation. All rights
|
|
* reserved.
|
|
* 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 "support.h"
|
|
|
|
#include "class/orte_pointer_array.h"
|
|
#include "dps/dps.h"
|
|
#include "runtime/runtime.h"
|
|
#include "opal/util/output.h"
|
|
#include "util/proc_info.h"
|
|
#include "util/sys_info.h"
|
|
#include "opal/util/malloc.h"
|
|
#include "opal/util/output.h"
|
|
|
|
#include "mca/errmgr/errmgr.h"
|
|
#include "mca/errmgr/base/base.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 "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";
|
|
|
|
static void test_cbfunc1(orte_gpr_notify_data_t *data, void *user_tag);
|
|
static void test_cbfunc2(orte_gpr_notify_data_t *data, void *user_tag);
|
|
static void test_cbfunc3(orte_gpr_notify_data_t *data, void *user_tag);
|
|
static void test_cbfunc4(orte_gpr_notify_data_t *data, void *user_tag);
|
|
static void test_cbfunc5(orte_gpr_notify_data_t *data, void *user_tag);
|
|
static void test_cbfunc6(orte_gpr_notify_data_t *data, void *user_tag);
|
|
|
|
static int test1(void);
|
|
static int test2(void);
|
|
static int test3(void);
|
|
static int test4(void);
|
|
|
|
|
|
int main(int argc, char **argv)
|
|
{
|
|
int rc=0;
|
|
|
|
test_init("test_gpr_replica_trigs");
|
|
|
|
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 (!opal_output_init()) {
|
|
exit(1);
|
|
}
|
|
|
|
/*
|
|
* If threads are supported - assume that we are using threads -
|
|
* and reset otherwise.
|
|
*/
|
|
opal_set_using_threads(OMPI_HAVE_THREAD_SUPPORT);
|
|
|
|
/* For malloc debugging */
|
|
opal_malloc_init();
|
|
|
|
/* Ensure the system_info structure is instantiated and initialized */
|
|
if (ORTE_SUCCESS != orte_sys_info()) {
|
|
exit(1);
|
|
}
|
|
|
|
/* Ensure the process info structure is instantiated and initialized */
|
|
if (ORTE_SUCCESS != orte_proc_info()) {
|
|
exit(1);
|
|
}
|
|
|
|
orte_process_info.seed = true;
|
|
|
|
/* 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);
|
|
}
|
|
|
|
/* startup the registry */
|
|
if (OMPI_SUCCESS == orte_gpr_base_open()) {
|
|
fprintf(test_out, "GPR started\n");
|
|
} else {
|
|
fprintf(test_out, "GPR could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* do a select on the registry components */
|
|
if (OMPI_SUCCESS == orte_gpr_base_select()) {
|
|
fprintf(test_out, "GPR selected\n");
|
|
} else {
|
|
fprintf(test_out, "GPR could not select\n");
|
|
exit (1);
|
|
}
|
|
|
|
|
|
if (ORTE_SUCCESS == orte_errmgr_base_open()) {
|
|
fprintf(test_out, "error mgr started\n");
|
|
} else {
|
|
fprintf(test_out, "error mgr could not start\n");
|
|
exit (1);
|
|
}
|
|
|
|
/* test triggers that compare two counters to each other */
|
|
if (ORTE_SUCCESS == test1()) {
|
|
fprintf(test_out, "triggers: compare two counters successful\n");
|
|
} else {
|
|
fprintf(test_out, "triggers: compare two counters failed\n");
|
|
rc = 1;
|
|
}
|
|
|
|
/* test triggers that fire at a level */
|
|
if (ORTE_SUCCESS == test2()) {
|
|
fprintf(test_out, "triggers: trigger at level successful\n");
|
|
} else {
|
|
fprintf(test_out, "triggers: trigger at level failed\n");
|
|
rc = 1;
|
|
}
|
|
|
|
/* test notification on value added */
|
|
if (ORTE_SUCCESS == test3()) {
|
|
fprintf(test_out, "triggers: notify upon value added successful\n");
|
|
} else {
|
|
fprintf(test_out, "triggers: notify upon value added failed\n");
|
|
rc = 1;
|
|
}
|
|
|
|
/* test notification on value changed */
|
|
if (ORTE_SUCCESS == test4()) {
|
|
fprintf(test_out, "triggers: notify upon value changed successful\n");
|
|
} else {
|
|
fprintf(test_out, "triggers: notify upon value changed failed\n");
|
|
rc = 1;
|
|
}
|
|
|
|
/* cleanup and finalize */
|
|
orte_dps_close();
|
|
orte_gpr_base_close();
|
|
orte_sys_info_finalize();
|
|
orte_proc_info_finalize();
|
|
mca_base_close();
|
|
opal_malloc_finalize();
|
|
opal_output_finalize();
|
|
opal_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 rc;
|
|
}
|
|
|
|
static int test1(void)
|
|
{
|
|
int rc, i, k;
|
|
orte_gpr_value_t *values, value, *val;
|
|
orte_gpr_trigger_t trig, *trigs;
|
|
orte_gpr_subscription_t *subscriptions[5];
|
|
char* keys[] = {
|
|
/* changes to this ordering need to be reflected in code below */
|
|
"setpoint",
|
|
"counter",
|
|
};
|
|
|
|
/* setup a pair of counters on the registry - one is the actual
|
|
* counter, and the other will hold the end condition when the
|
|
* trigger(s) should fire
|
|
*/
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_TOKENS_XAND | ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == value.tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.tokens[0] = strdup("test-container");
|
|
value.num_tokens = 1;
|
|
value.cnt = 2;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(2 * sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == value.keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
for (i=0; i < 2; i++) {
|
|
value.keyvals[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == value.keyvals[i]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.keyvals[i]->key = strdup(keys[i]);
|
|
value.keyvals[i]->type = ORTE_UINT32;
|
|
value.keyvals[i]->value.ui32 = 0;
|
|
}
|
|
/* set value in keys[0] to 3 */
|
|
value.keyvals[0]->value.ui32 = 3;
|
|
|
|
values = &value;
|
|
|
|
fprintf(test_out, "putting counters on registry\n");
|
|
|
|
/* put the counters on the registry */
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &values))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
OBJ_DESTRUCT(&value); /* clean up */
|
|
|
|
/* put some data on the registry that the subscriptions can return
|
|
* we'll first put several keyvals in one container that have different
|
|
* keys, plus a few that have the same key.
|
|
*/
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_NO_OVERWRITE |
|
|
ORTE_GPR_TOKENS_XAND |
|
|
ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.num_tokens = 2;
|
|
value.tokens = (char**)malloc(value.num_tokens * sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(value.tokens[i]), "dummy%d", i);
|
|
}
|
|
value.cnt = 5;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(5*sizeof(orte_gpr_keyval_t*));
|
|
for (i=0; i < 5; i++) value.keyvals[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
(value.keyvals[0])->key = strdup("stupid-value-one");
|
|
(value.keyvals[0])->type = ORTE_INT32;
|
|
(value.keyvals[0])->value.i32 = 654321;
|
|
(value.keyvals[1])->key = strdup("stupid-value-two");
|
|
(value.keyvals[1])->type = ORTE_INT16;
|
|
(value.keyvals[1])->value.i16 = 128;
|
|
for (i=2; i < 5; i++) {
|
|
(value.keyvals[i])->key = strdup("stupid-value-multi");
|
|
(value.keyvals[i])->type = ORTE_INT32;
|
|
(value.keyvals[i])->value.i32 = i * 10;
|
|
}
|
|
values = &value;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &values))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
OBJ_DESTRUCT(&value); /* clean up */
|
|
|
|
/* now put some data in a second container, some of it with
|
|
* matching keys
|
|
*/
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_NO_OVERWRITE |
|
|
ORTE_GPR_TOKENS_XAND |
|
|
ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.num_tokens = 2;
|
|
value.tokens = (char**)malloc(value.num_tokens * sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(value.tokens[i]), "dummy%d", i+5);
|
|
}
|
|
value.cnt = 3;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(5*sizeof(orte_gpr_keyval_t*));
|
|
for (i=0; i < 3; i++) value.keyvals[i] = OBJ_NEW(orte_gpr_keyval_t);
|
|
(value.keyvals[0])->key = strdup("stupid-value-one");
|
|
(value.keyvals[0])->type = ORTE_INT32;
|
|
(value.keyvals[0])->value.i32 = 123456;
|
|
(value.keyvals[1])->key = strdup("stupid-value-three");
|
|
(value.keyvals[1])->type = ORTE_INT16;
|
|
(value.keyvals[1])->value.i16 = 821;
|
|
(value.keyvals[2])->key = strdup("stupid-value-multi");
|
|
(value.keyvals[2])->type = ORTE_INT32;
|
|
(value.keyvals[2])->value.i32 = 2348;
|
|
values = &value;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &values))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
OBJ_DESTRUCT(&value); /* clean up */
|
|
|
|
for (k=0; k < 10; k++) {
|
|
/* setup the subscriptions, each defining a set of data that is to be
|
|
* returned to the corresponding callback function
|
|
*/
|
|
for (i=0; i < 5; i++) {
|
|
subscriptions[i] = OBJ_NEW(orte_gpr_subscription_t);
|
|
subscriptions[i]->action = ORTE_GPR_NOTIFY_DELETE_AFTER_TRIG;
|
|
subscriptions[i]->cnt = 1;
|
|
subscriptions[i]->values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
subscriptions[i]->values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
val = subscriptions[i]->values[0];
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR;
|
|
val->segment = strdup("test-segment");
|
|
subscriptions[i]->user_tag = NULL;
|
|
}
|
|
/* sub-0 asks for the stupid-value-one data from the first
|
|
* container ONLY
|
|
*/
|
|
val = subscriptions[0]->values[0];
|
|
val->num_tokens = 2;
|
|
val->tokens = (char**)malloc(2*sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy%d", i);
|
|
}
|
|
val->cnt = 1;
|
|
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-one");
|
|
subscriptions[0]->cbfunc = test_cbfunc1;
|
|
|
|
/* sub-1 asks for the stupid-value-one data from ALL containers
|
|
*/
|
|
val = subscriptions[1]->values[0];
|
|
val->num_tokens = 0;
|
|
val->tokens = NULL;
|
|
val->cnt = 1;
|
|
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-one");
|
|
subscriptions[1]->cbfunc = test_cbfunc2;
|
|
|
|
/* sub-2 asks for the stupid-value-multi data from the first
|
|
* container ONLY
|
|
*/
|
|
val = subscriptions[2]->values[0];
|
|
val->num_tokens = 2;
|
|
val->tokens = (char**)malloc(2*sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy%d", i);
|
|
}
|
|
val->cnt = 1;
|
|
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-multi");
|
|
subscriptions[2]->cbfunc = test_cbfunc3;
|
|
|
|
/* sub-3 asks for the stupid-value-three data from ALL containers */
|
|
val = subscriptions[3]->values[0];
|
|
val->num_tokens = 0;
|
|
val->tokens = NULL;
|
|
val->cnt = 1;
|
|
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-three");
|
|
subscriptions[3]->cbfunc = test_cbfunc4;
|
|
|
|
/* sub-4 asks for ALL data from ALL containers */
|
|
val = subscriptions[4]->values[0];
|
|
val->num_tokens = 0;
|
|
val->tokens = NULL;
|
|
val->cnt = 0;
|
|
val->keyvals = NULL;
|
|
subscriptions[4]->cbfunc = test_cbfunc5;
|
|
|
|
/* setup the trigger information - initialize the common elements */
|
|
OBJ_CONSTRUCT(&trig, orte_gpr_trigger_t);
|
|
trig.action = ORTE_GPR_TRIG_ALL_CMP;
|
|
trig.cnt = 1;
|
|
trig.values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
trig.values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
val = trig.values[0];
|
|
val->addr_mode = ORTE_GPR_TOKENS_XAND;
|
|
val->segment = strdup("test-segment");
|
|
val->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == val->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
for (i=0; i < 5; i++) OBJ_RELEASE(subscriptions[i]);
|
|
OBJ_DESTRUCT(&trig);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->tokens[0] = strdup("test-container");
|
|
val->num_tokens = 1;
|
|
val->cnt = 2;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(2*sizeof(orte_gpr_keyval_t*));
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
val->keyvals[0]->key = strdup(keys[0]);
|
|
val->keyvals[0]->type = ORTE_NULL;
|
|
|
|
val->keyvals[1] = OBJ_NEW(orte_gpr_keyval_t);
|
|
val->keyvals[1]->key = strdup(keys[1]);
|
|
val->keyvals[1]->type = ORTE_NULL;
|
|
|
|
fprintf(test_out, "setting trigger\n");
|
|
|
|
trigs = &trig;
|
|
|
|
/* enter things as three different subscriptions */
|
|
rc = orte_gpr.subscribe(
|
|
2, subscriptions,
|
|
1, &trigs);
|
|
|
|
|
|
rc = orte_gpr.subscribe(
|
|
2, &(subscriptions[2]),
|
|
1, &trigs);
|
|
|
|
rc = orte_gpr.subscribe(
|
|
1, &(subscriptions[4]),
|
|
1, &trigs);
|
|
|
|
for (i=0; i < 5; i++) OBJ_RELEASE(subscriptions[i]);
|
|
OBJ_DESTRUCT(&trig);
|
|
|
|
if(ORTE_SUCCESS != rc) {
|
|
ORTE_ERROR_LOG(rc);
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
orte_gpr.dump_triggers(0);
|
|
return ORTE_SUCCESS;
|
|
|
|
fprintf(test_out, "incrementing until trigger\n");
|
|
/* increment the value in keys[1] until the trig fires */
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_TOKENS_XAND | ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == value.tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.tokens[0] = strdup("test-container");
|
|
value.num_tokens = 1;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == value.keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.cnt = 1;
|
|
value.keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == value.keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.keyvals[0]->key = strdup(keys[1]);
|
|
value.keyvals[0]->type = ORTE_NULL;
|
|
|
|
for (i=0; i < 10; i++) {
|
|
fprintf(test_out, "\tincrement %s\n", keys[1]);
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.increment_value(&value))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_DESTRUCT(&value);
|
|
|
|
return ORTE_SUCCESS;
|
|
}
|
|
|
|
int test2(void)
|
|
{
|
|
int rc, i;
|
|
orte_gpr_value_t *values, value;
|
|
orte_gpr_trigger_t trig, *trigs;
|
|
orte_gpr_subscription_t *subscription;
|
|
|
|
/* setup a counter on the registry that the trigger will later refer
|
|
* to when defining the level at which to fire
|
|
*/
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_TOKENS_XAND | ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == value.tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.tokens[0] = strdup("test-level-trigger");
|
|
value.num_tokens = 1;
|
|
value.cnt = 1;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == value.keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == value.keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.keyvals[0]->key = strdup("level-counter");
|
|
value.keyvals[0]->type = ORTE_UINT32;
|
|
value.keyvals[0]->value.ui32 = 0;
|
|
|
|
values = &value;
|
|
|
|
fprintf(test_out, "putting level test counter on registry\n");
|
|
|
|
/* put the counters on the registry */
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &values))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
OBJ_DESTRUCT(&value); /* clean up */
|
|
|
|
/* setup a subscription that defines a set of data that is to be
|
|
* returned to the corresponding callback function
|
|
*/
|
|
subscription = OBJ_NEW(orte_gpr_subscription_t);
|
|
subscription->action = ORTE_GPR_NOTIFY_DELETE_AFTER_TRIG;
|
|
subscription->cnt = 1;
|
|
subscription->values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
subscription->values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
values = subscription->values[0];
|
|
values->addr_mode = ORTE_GPR_TOKENS_OR;
|
|
values->segment = strdup("test-segment");
|
|
subscription->user_tag = NULL;
|
|
/* ask for the stupid-value-one data from the first
|
|
* container ONLY
|
|
*/
|
|
values->num_tokens = 2;
|
|
values->tokens = (char**)malloc(2*sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(values->tokens[i]), "dummy%d", i);
|
|
}
|
|
values->cnt = 1;
|
|
values->keyvals =(orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
values->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
values->keyvals[0]->key = strdup("stupid-value-one");
|
|
subscription->cbfunc = test_cbfunc6;
|
|
|
|
/* setup the trigger information - want trigger to fire when
|
|
* a specific counter reaches a specified value
|
|
*/
|
|
OBJ_CONSTRUCT(&trig, orte_gpr_trigger_t);
|
|
trig.action = ORTE_GPR_TRIG_ALL_AT;
|
|
trig.cnt = 1;
|
|
trig.values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
trig.values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
values = trig.values[0];
|
|
values->addr_mode = ORTE_GPR_TOKENS_XAND;
|
|
values->segment = strdup("test-segment");
|
|
values->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == values->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_RELEASE(subscription);
|
|
OBJ_DESTRUCT(&trig);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
values->tokens[0] = strdup("test-level-trigger");
|
|
values->num_tokens = 1;
|
|
values->cnt = 1;
|
|
values->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
values->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
values->keyvals[0]->key = strdup("level-counter");
|
|
values->keyvals[0]->type = ORTE_UINT32;
|
|
values->keyvals[0]->value.i32 = 2;
|
|
|
|
fprintf(test_out, "setting level trigger\n");
|
|
|
|
trigs = &trig;
|
|
|
|
/* enter subscription */
|
|
rc = orte_gpr.subscribe(
|
|
1, &subscription,
|
|
1, &trigs);
|
|
|
|
orte_gpr.dump_triggers(0);
|
|
|
|
/* cleanup */
|
|
OBJ_RELEASE(subscription);
|
|
OBJ_DESTRUCT(&trig);
|
|
|
|
fprintf(test_out, "incrementing until level trigger\n");
|
|
/* increment the value in the counter until the trig fires */
|
|
OBJ_CONSTRUCT(&value, orte_gpr_value_t);
|
|
value.addr_mode = ORTE_GPR_TOKENS_XAND | ORTE_GPR_KEYS_OR;
|
|
value.segment = strdup("test-segment");
|
|
value.tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == value.tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.tokens[0] = strdup("test-level-trigger");
|
|
value.num_tokens = 1;
|
|
value.keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == value.keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.cnt = 1;
|
|
value.keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == value.keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
value.keyvals[0]->key = strdup("level-counter");
|
|
value.keyvals[0]->type = ORTE_NULL;
|
|
|
|
for (i=0; i < 10; i++) {
|
|
fprintf(test_out, "\tincrement level-counter\n");
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.increment_value(&value))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_DESTRUCT(&value);
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_DESTRUCT(&value);
|
|
|
|
return ORTE_SUCCESS;
|
|
}
|
|
|
|
|
|
int test3(void)
|
|
{
|
|
int rc;
|
|
size_t i;
|
|
orte_gpr_value_t value, *val;
|
|
orte_gpr_subscription_t *subscription;
|
|
|
|
/* put something on the registry to start */
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->segment = strdup("test-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-sub-%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 = orte_gpr.put(1, &val))) {
|
|
fprintf(test_out, "put failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("put failed");
|
|
test_finalize();
|
|
return rc;
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
/* setup a subscription on one of the containers
|
|
* that notifies callback 1 if something is added
|
|
*/
|
|
subscription = OBJ_NEW(orte_gpr_subscription_t);
|
|
subscription->action = ORTE_GPR_NOTIFY_ADD_ENTRY;
|
|
subscription->cnt = 1;
|
|
subscription->values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
subscription->values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
val = subscription->values[0];
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR;
|
|
val->segment = strdup("test-segment");
|
|
subscription->user_tag = NULL;
|
|
/* monitor the dummy-sub-xx container only
|
|
*/
|
|
val->num_tokens = 2;
|
|
val->tokens = (char**)malloc(2*sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy-sub-%lu", (unsigned long) i);
|
|
}
|
|
/* get notified when anything is added */
|
|
val->cnt = 0;
|
|
val->keyvals = NULL;
|
|
|
|
/* send notification to callback 1 */
|
|
subscription->cbfunc = test_cbfunc1;
|
|
|
|
/* enter subscription */
|
|
rc = orte_gpr.subscribe(
|
|
1, &subscription,
|
|
0, NULL);
|
|
|
|
orte_gpr.dump_triggers(0);
|
|
|
|
/* cleanup */
|
|
OBJ_RELEASE(subscription);
|
|
|
|
|
|
/* add something with two keyvals to the container */
|
|
|
|
fprintf(test_out, "adding something - should trigger\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR | ORTE_GPR_KEYS_OR;
|
|
val->segment = strdup("test-segment");
|
|
val->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == val->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->tokens[0] = strdup("dummy-sub-0");
|
|
val->num_tokens = 1;
|
|
val->cnt = 2;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(val->cnt * sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == val->keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[0]->key = strdup("test-notify-add");
|
|
val->keyvals[0]->type = ORTE_NULL;
|
|
val->keyvals[1] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[1]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[1]->key = strdup("test-notify-add-2");
|
|
val->keyvals[1]->type = ORTE_INT32;
|
|
val->keyvals[1]->value.i32 = 12345;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &val))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_RELEASE(val);
|
|
return rc;
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_RELEASE(val);
|
|
|
|
fprintf(test_out, "adding something - should NOT trigger\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR | ORTE_GPR_KEYS_OR;
|
|
val->segment = strdup("test-segment");
|
|
val->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == val->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->tokens[0] = strdup("dummy-sub-10");
|
|
val->num_tokens = 1;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == val->keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->cnt = 1;
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[0]->key = strdup("test-notify-add-no-fire");
|
|
val->keyvals[0]->type = ORTE_NULL;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &val))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_RELEASE(val);
|
|
return rc;
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_RELEASE(val);
|
|
|
|
return ORTE_SUCCESS;
|
|
}
|
|
|
|
|
|
int test4(void)
|
|
{
|
|
int rc;
|
|
size_t i;
|
|
orte_gpr_value_t value, *val;
|
|
orte_gpr_subscription_t *subscription;
|
|
|
|
/* put something on the registry to start */
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_NO_OVERWRITE | ORTE_GPR_TOKENS_XAND;
|
|
val->segment = strdup("test-segment-2");
|
|
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-sub-%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 = orte_gpr.put(1, &val))) {
|
|
fprintf(test_out, "put failed with error code %s\n",
|
|
ORTE_ERROR_NAME(rc));
|
|
test_failure("put failed");
|
|
test_finalize();
|
|
return rc;
|
|
}
|
|
OBJ_RELEASE(val);
|
|
|
|
/* setup a subscription on one of the containers
|
|
* that notifies callback 1 if something is changed
|
|
*/
|
|
subscription = OBJ_NEW(orte_gpr_subscription_t);
|
|
subscription->action = ORTE_GPR_NOTIFY_VALUE_CHG;
|
|
subscription->cnt = 1;
|
|
subscription->values = (orte_gpr_value_t**)malloc(sizeof(orte_gpr_value_t*));
|
|
subscription->values[0] = OBJ_NEW(orte_gpr_value_t);
|
|
val = subscription->values[0];
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR;
|
|
val->segment = strdup("test-segment-2");
|
|
subscription->user_tag = NULL;
|
|
/* monitor the dummy-sub-xx container only
|
|
*/
|
|
val->num_tokens = 2;
|
|
val->tokens = (char**)malloc(2*sizeof(char*));
|
|
for (i=0; i < 2; i++) {
|
|
asprintf(&(val->tokens[i]), "dummy-sub-%lu", (unsigned long) i);
|
|
}
|
|
/* get notified when any value is changed */
|
|
val->cnt = 0;
|
|
val->keyvals = NULL;
|
|
|
|
/* send notification to callback 1 */
|
|
subscription->cbfunc = test_cbfunc1;
|
|
|
|
/* enter subscription */
|
|
rc = orte_gpr.subscribe(
|
|
1, &subscription,
|
|
0, NULL);
|
|
|
|
orte_gpr.dump_triggers(0);
|
|
|
|
/* cleanup */
|
|
OBJ_RELEASE(subscription);
|
|
|
|
|
|
/* change something on the container */
|
|
|
|
fprintf(test_out, "changing something - should trigger\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_TOKENS_OR | ORTE_GPR_KEYS_OR;
|
|
val->segment = strdup("test-segment-2");
|
|
val->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == val->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->tokens[0] = strdup("dummy-sub-0");
|
|
val->num_tokens = 1;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == val->keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->cnt = 2;
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[0]->key = strdup("stupid-test-0");
|
|
val->keyvals[0]->type = ORTE_UINT32;
|
|
val->keyvals[0]->value.ui32 = 12345;
|
|
val->keyvals[1] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[1]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[1]->key = strdup("stupid-test-5");
|
|
val->keyvals[1]->type = ORTE_UINT32;
|
|
val->keyvals[1]->value.ui32 = 6789;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &val))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_RELEASE(val);
|
|
return rc;
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_RELEASE(val);
|
|
|
|
fprintf(test_out, "changing something else - should NOT trigger\n");
|
|
val = OBJ_NEW(orte_gpr_value_t);
|
|
val->addr_mode = ORTE_GPR_OVERWRITE | ORTE_GPR_TOKENS_OR | ORTE_GPR_KEYS_OR;
|
|
val->segment = strdup("test-segment-2");
|
|
val->tokens = (char**)malloc(sizeof(char*));
|
|
if (NULL == val->tokens) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->tokens[0] = strdup("dummy-sub-1");
|
|
val->num_tokens = 1;
|
|
val->keyvals = (orte_gpr_keyval_t**)malloc(sizeof(orte_gpr_keyval_t*));
|
|
if (NULL == val->keyvals) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->cnt = 1;
|
|
val->keyvals[0] = OBJ_NEW(orte_gpr_keyval_t);
|
|
if (NULL == val->keyvals[0]) {
|
|
ORTE_ERROR_LOG(ORTE_ERR_OUT_OF_RESOURCE);
|
|
OBJ_DESTRUCT(&value);
|
|
return ORTE_ERR_OUT_OF_RESOURCE;
|
|
}
|
|
val->keyvals[0]->key = strdup("stupid-test-1");
|
|
val->keyvals[0]->type = ORTE_UINT32;
|
|
val->keyvals[0]->value.ui32 = 6789;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_gpr.put(1, &val))) {
|
|
ORTE_ERROR_LOG(rc);
|
|
OBJ_RELEASE(val);
|
|
return rc;
|
|
}
|
|
|
|
orte_gpr.dump_all(0);
|
|
OBJ_RELEASE(val);
|
|
|
|
return ORTE_SUCCESS;
|
|
}
|
|
|
|
|
|
void test_cbfunc1(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 1\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|
|
|
|
void test_cbfunc2(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 2\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|
|
|
|
void test_cbfunc3(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 3\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|
|
|
|
void test_cbfunc4(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 4\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|
|
|
|
void test_cbfunc5(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 5\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|
|
|
|
void test_cbfunc6(orte_gpr_notify_data_t *data, void *tag)
|
|
{
|
|
fprintf(test_out, "\n\n\nTRIGGER FIRED AND RECEIVED AT CALLBACK 6\n");
|
|
|
|
orte_gpr.dump_notify_data(data, 0);
|
|
}
|