1
1
openmpi/test/dss/dss_set_get.c
Rainer Keller 583bb42739 - Adapt for changed opal_init() arguments -- takes argc&argv
It's orte/constants.h not orte/orte_constants.h

This commit was SVN r22594.
2010-02-10 18:29:01 +00:00

504 строки
13 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$
*/
#include "opal_config.h"
#include "opal/constants.h"
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include "opal/runtime/opal.h"
#include "opal/dss/dss.h"
#define NUM_ITERS 3
#define NUM_ELEMS 10
static bool test1(void); /* verify different buffer inits */
static bool test2(void); /* verify int16 */
static bool test3(void); /* verify int */
static bool test4(void); /* verify int32 */
static bool test5(void); /* verify int64 */
static bool test6(void); /* verify string */
static bool test7(void); /* verify BOOL */
static bool test8(void); /* verify OBJECT */
static bool test9(void); /* verify composite (multiple types and element counts) */
static bool test11(void); /* verify size_t */
static bool test12(void); /* verify pid_t */
FILE *test_out;
int main (int argc, char* argv[])
{
opal_init(&argc, &argv);
test_out = stderr;
/* run the tests */
fprintf(test_out, "executing test1\n");
if (test1()) {
fprintf(test_out, "Test1 succeeded\n");
}
else {
fprintf(test_out, "Test1 failed\n");
}
fprintf(test_out, "executing test2\n");
if (test2()) {
fprintf(test_out, "Test2 succeeded\n");
}
else {
fprintf(test_out, "Test2 failed\n");
}
fprintf(test_out, "executing test3\n");
if (test3()) {
fprintf(test_out, "Test3 succeeded\n");
}
else {
fprintf(test_out, "Test3 failed\n");
}
fprintf(test_out, "executing test4\n");
if (test4()) {
fprintf(test_out, "Test4 succeeded\n");
}
else {
fprintf(test_out, "Test4 failed\n");
}
fprintf(test_out, "executing test5\n");
if (test5()) {
fprintf(test_out, "Test5 succeeded\n");
}
else {
fprintf(test_out, "Test5 failed\n");
}
fprintf(test_out, "executing test6\n");
if (test6()) {
fprintf(test_out, "Test6 succeeded\n");
}
else {
fprintf(test_out, "Test6 failed\n");
}
fprintf(test_out, "executing test7\n");
if (test7()) {
fprintf(test_out, "Test7 succeeded\n");
}
else {
fprintf(test_out, "Test7 failed\n");
}
fprintf(test_out, "executing test8\n");
if (test8()) {
fprintf(test_out, "Test8 succeeded\n");
}
else {
fprintf(test_out, "Test8 failed\n");
}
fprintf(test_out, "executing test9\n");
if (test9()) {
fprintf(test_out, "Test9 succeeded\n");
}
else {
fprintf(test_out, "opal_dss test9 failed\n");
}
fprintf(test_out, "executing test11\n");
if (test11()) {
fprintf(test_out, "Test11 succeeded\n");
}
else {
fprintf(test_out, "opal_dss test11 failed\n");
}
fprintf(test_out, "executing test12\n");
if (test12()) {
fprintf(test_out, "Test12 succeeded\n");
}
else {
fprintf(test_out, "opal_dss test12 failed\n");
}
fclose(test_out);
opal_finalize();
return(0);
}
/*
* INT8
*/
static bool test1(void)
{
int8_t *v1, v2=100;
uint8_t *u1, u2=150;
opal_data_type_t type=OPAL_INT8, utype=OPAL_UINT8;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
opal_dss_value_t udv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for signed value\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.set(&udv, &u2, utype)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&u1, &udv, utype)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for unsigned value\n");
return(false);
}
return (true);
}
/*
* INT16
*/
static bool test2(void)
{
int16_t *v1, v2=100;
uint16_t *u1, u2=150;
opal_data_type_t type=OPAL_INT16, utype=OPAL_UINT16;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
opal_dss_value_t udv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for signed value\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.set(&udv, &u2, utype)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&u1, &udv, utype)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for unsigned value\n");
return(false);
}
return (true);
}
/*
* INT32
*/
static bool test3(void)
{
int32_t *v1, v2=100;
uint32_t *u1, u2=150;
opal_data_type_t type=OPAL_INT32, utype=OPAL_UINT32;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
opal_dss_value_t udv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for signed value\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.set(&udv, &u2, utype)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&u1, &udv, utype)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for unsigned value\n");
return(false);
}
return (true);
}
/*
* INT64
*/
static bool test4(void)
{
int64_t *v1, v2=100;
uint64_t *u1, u2=150;
opal_data_type_t type=OPAL_INT64, utype=OPAL_UINT64;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
opal_dss_value_t udv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for signed value\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.set(&udv, &u2, utype)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&u1, &udv, utype)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for unsigned value\n");
return(false);
}
return (true);
}
/*
* INT
*/
static bool test5(void)
{
int *v1, v2=100;
uint *u1, u2=150;
opal_data_type_t type=OPAL_INT, utype=OPAL_UINT;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
opal_dss_value_t udv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for signed value\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.set(&udv, &u2, utype)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&u1, &udv, utype)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for unsigned value\n");
return(false);
}
return (true);
}
/*
* STRING
*/
static bool test6(void)
{
char *string1="This is a short string", *string2;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, string1, OPAL_STRING)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&string2, &dv, OPAL_STRING)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (0 != strcmp(string1, string2)) {
fprintf(test_out, "opal_dss.get/set failed for string value\n");
return(false);
}
return (true);
}
/*
* BOOL
*/
static bool test7(void)
{
bool *v1, v2=true;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, OPAL_BOOL)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, OPAL_BOOL)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for bool value\n");
return(false);
}
return (true);
}
/*
* SIZE
*/
static bool test8(void)
{
size_t *v1, v2=100;
opal_data_type_t type=OPAL_SIZE;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for size value\n");
return(false);
}
return (true);
}
/*
* PID
*/
static bool test9(void)
{
pid_t *v1, v2=100;
opal_data_type_t type=OPAL_PID;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for pid value\n");
return(false);
}
return (true);
}
/*
* DATA TYPE
*/
static bool test11(void)
{
opal_data_type_t *v1, v2=100;
opal_data_type_t type=OPAL_DATA_TYPE;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, type)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, type)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (v2 != *v1) {
fprintf(test_out, "opal_dss.get/set failed for data type value\n");
return(false);
}
return (true);
}
/**
* OPAL_BYTE_OBJECT
*/
static bool test12(void)
{
size_t i;
opal_byte_object_t v2, *v1;
opal_dss_value_t dv = {{OBJ_CLASS(opal_dss_value_t),0},OPAL_UNDEF, NULL};
v2.size = 20;
v2.bytes = (uint8_t*)malloc(v2.size);
for (i=0; i<v2.size; i++) v2.bytes[i] = i;
if (OPAL_SUCCESS != opal_dss.set(&dv, &v2, OPAL_BYTE_OBJECT)) {
fprintf(test_out, "opal_dss.set returned error\n");
return(false);
}
if (OPAL_SUCCESS != opal_dss.get((void**)&v1, &dv, OPAL_BYTE_OBJECT)) {
fprintf(test_out, "opal_dss.get returned error\n");
return(false);
}
if (0 != opal_dss.compare(v1, &v2, OPAL_BYTE_OBJECT)) {
fprintf(test_out, "opal_dss.get/set failed for byte object value\n");
return(false);
}
return (true);
}