Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add mpich3 tests for MPI_Info calls.
[simgrid.git] / teshsuite / smpi / mpich3-test / info / infoorder.c
diff --git a/teshsuite/smpi/mpich3-test/info/infoorder.c b/teshsuite/smpi/mpich3-test/info/infoorder.c
new file mode 100644 (file)
index 0000000..aa1db8c
--- /dev/null
@@ -0,0 +1,166 @@
+/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil ; -*- */
+/*
+ *
+ *  (C) 2003 by Argonne National Laboratory.
+ *      See COPYRIGHT in top-level directory.
+ */
+#include "mpi.h"
+#include <stdio.h>
+#include <stdlib.h>
+#include "mpitest.h"
+#include "mpitestconf.h"
+#ifdef HAVE_STRING_H
+#include <string.h>
+#endif
+
+#define NKEYS 3
+int main( int argc, char *argv[] )
+{
+    int errs = 0;
+    MPI_Info info;
+    char *keys1[NKEYS] = { (char*)"file", (char*)"soft", (char*)"host" };
+    char *values1[NKEYS] = { (char*)"runfile.txt", (char*)"2:1000:4,3:1000:7", 
+                            (char*)"myhost.myorg.org" };
+
+    char value[MPI_MAX_INFO_VAL];
+    int i, flag;
+
+    MTest_Init( &argc, &argv );
+
+    /* 1,2,3 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_set( info, keys1[i], values1[i] );
+    }
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+
+    /* 3,2,1 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    for (i=NKEYS-1; i>=0; i--) {
+       MPI_Info_set( info, keys1[i], values1[i] );
+    }
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+
+    /* 1,3,2 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    MPI_Info_set( info, keys1[0], values1[0] );
+    MPI_Info_set( info, keys1[2], values1[2] );
+    MPI_Info_set( info, keys1[1], values1[1] );
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+
+    /* 2,1,3 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    MPI_Info_set( info, keys1[1], values1[1] );
+    MPI_Info_set( info, keys1[0], values1[0] );
+    MPI_Info_set( info, keys1[2], values1[2] );
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+
+    /* 2,3,1 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    MPI_Info_set( info, keys1[1], values1[1] );
+    MPI_Info_set( info, keys1[2], values1[2] );
+    MPI_Info_set( info, keys1[0], values1[0] );
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+    
+    /* 3,1,2 */
+    MPI_Info_create( &info );
+    /* Use only named keys incase the info implementation only supports
+       the predefined keys (e.g., IBM) */
+    MPI_Info_set( info, keys1[2], values1[2] );
+    MPI_Info_set( info, keys1[0], values1[0] );
+    MPI_Info_set( info, keys1[1], values1[1] );
+
+    /* Check that all values are present */
+    for (i=0; i<NKEYS; i++) {
+       MPI_Info_get( info, keys1[i], MPI_MAX_INFO_VAL, value, &flag );
+       if (!flag) {
+           errs++;
+           printf( "No value for key %s\n", keys1[i] );
+       }
+       if (strcmp( value, values1[i] )) {
+           errs++;
+           printf( "Incorrect value for key %s\n", keys1[i] );
+       }
+    }
+    MPI_Info_free( &info );
+    
+    MTest_Finalize( errs );
+    MPI_Finalize();
+    return 0;
+  
+}