Blame test/mpi/cxx/info/infodupx.cxx

Packit 0848f5
/* -*- Mode: C++; c-basic-offset:4 ; -*- */
Packit 0848f5
/*
Packit 0848f5
 *
Packit 0848f5
 *  (C) 2003 by Argonne National Laboratory.
Packit 0848f5
 *      See COPYRIGHT in top-level directory.
Packit 0848f5
 */
Packit 0848f5
#include "mpi.h"
Packit 0848f5
#include "mpitestconf.h"
Packit 0848f5
#ifdef HAVE_IOSTREAM
Packit 0848f5
// Not all C++ compilers have iostream instead of iostream.h
Packit 0848f5
#include <iostream>
Packit 0848f5
#ifdef HAVE_NAMESPACE_STD
Packit 0848f5
// Those that do often need the std namespace; otherwise, a bare "cout"
Packit 0848f5
// is likely to fail to compile
Packit 0848f5
using namespace std;
Packit 0848f5
#endif
Packit 0848f5
#else
Packit 0848f5
#include <iostream.h>
Packit 0848f5
#endif
Packit 0848f5
#include "mpitestcxx.h"
Packit 0848f5
#ifdef HAVE_STRING_H
Packit 0848f5
#include <string.h>
Packit 0848f5
#endif
Packit 0848f5
Packit 0848f5
int main( int argc, char *argv[] )
Packit 0848f5
{
Packit 0848f5
    int errs = 0;
Packit 0848f5
    MPI::Info info1, infodup;
Packit 0848f5
    int nkeys, nkeysdup, i, vallen, flag, flagdup;
Packit 0848f5
    char *key, *keydup;
Packit 0848f5
    char *value, *valdup;
Packit 0848f5
Packit 0848f5
    MTest_Init( );
Packit 0848f5
Packit 0848f5
    key = new char [MPI::MAX_INFO_KEY];
Packit 0848f5
    keydup = new char [MPI::MAX_INFO_KEY];
Packit 0848f5
    value = new char [MPI::MAX_INFO_VAL];
Packit 0848f5
    valdup = new char [MPI::MAX_INFO_VAL];
Packit 0848f5
Packit 0848f5
    info1 = MPI::Info::Create( );
Packit 0848f5
    /* Use only named keys incase the info implementation only supports
Packit 0848f5
       the predefined keys (e.g., IBM) */
Packit 0848f5
    info1.Set( "host", "myhost.myorg.org" );
Packit 0848f5
    info1.Set( "file", "runfile.txt" );
Packit 0848f5
    info1.Set( "soft", "2:1000:4,3:1000:7" );
Packit 0848f5
Packit 0848f5
    infodup = info1.Dup();
Packit 0848f5
Packit 0848f5
    nkeysdup = infodup.Get_nkeys();
Packit 0848f5
    nkeys    = info1.Get_nkeys();
Packit 0848f5
    if (nkeys != nkeysdup) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "Dup'ed info has a different number of keys; is " <<
Packit 0848f5
	    nkeysdup << " should be " << nkeys << "\n";
Packit 0848f5
    }
Packit 0848f5
    vallen = MPI::MAX_INFO_VAL;
Packit 0848f5
    for (i=0; i
Packit 0848f5
	/* MPI requires that the keys are in the same order after the dup */
Packit 0848f5
	info1.Get_nthkey( i, key );
Packit 0848f5
	infodup.Get_nthkey( i, keydup );
Packit 0848f5
	if (strcmp(key, keydup)) {
Packit 0848f5
	    errs++;
Packit 0848f5
	    cout << "keys do not match: " << keydup << " should be " <<
Packit 0848f5
		key << "\n";
Packit 0848f5
	}
Packit 0848f5
Packit 0848f5
	vallen = MPI::MAX_INFO_VAL;
Packit 0848f5
	flag = info1.Get( key, vallen, value );
Packit 0848f5
	flagdup = infodup.Get( keydup, vallen, valdup );
Packit 0848f5
	if (!flag || !flagdup) {
Packit 0848f5
	    errs++;
Packit 0848f5
	    cout << "Info get failed for key " << key << "\n";
Packit 0848f5
	}
Packit 0848f5
	else if (strcmp( value, valdup )) {
Packit 0848f5
	    errs++;
Packit 0848f5
	    cout << "Info values for key " << key << 
Packit 0848f5
		" not the same after dup\n";
Packit 0848f5
	}
Packit 0848f5
    }
Packit 0848f5
Packit 0848f5
    /* Change info and check that infodup does NOT have the new value 
Packit 0848f5
       (ensure that lazy dups are still duped) */
Packit 0848f5
    info1.Set( "path", "/a:/b:/c/d" );
Packit 0848f5
Packit 0848f5
    flag = infodup.Get( "path", vallen, value );
Packit 0848f5
    if (flag) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "inserting path into info changed infodup\n";
Packit 0848f5
    }
Packit 0848f5
    
Packit 0848f5
    info1.Free();
Packit 0848f5
    infodup.Free();
Packit 0848f5
    
Packit 0848f5
    MTest_Finalize( errs );
Packit 0848f5
    delete [] key;
Packit 0848f5
    delete [] keydup;
Packit 0848f5
    delete [] value;
Packit 0848f5
    delete [] valdup;
Packit 0848f5
Packit 0848f5
    MPI::Finalize();
Packit 0848f5
Packit 0848f5
    return 0;  
Packit 0848f5
}