|
Teuchos Package Browser (Single Doxygen Collection) Version of the Day
|
00001 // @HEADER 00002 // *********************************************************************** 00003 // 00004 // Teuchos: Common Tools Package 00005 // Copyright (2004) Sandia Corporation 00006 // 00007 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive 00008 // license for use of this work by or on behalf of the U.S. Government. 00009 // 00010 // This library is free software; you can redistribute it and/or modify 00011 // it under the terms of the GNU Lesser General Public License as 00012 // published by the Free Software Foundation; either version 2.1 of the 00013 // License, or (at your option) any later version. 00014 // 00015 // This library is distributed in the hope that it will be useful, but 00016 // WITHOUT ANY WARRANTY; without even the implied warranty of 00017 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 // Lesser General Public License for more details. 00019 // 00020 // You should have received a copy of the GNU Lesser General Public 00021 // License along with this library; if not, write to the Free Software 00022 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 // USA 00024 // Questions? Contact Michael A. Heroux (maherou@sandia.gov) 00025 // 00026 // *********************************************************************** 00027 // @HEADER 00028 00029 #include "Teuchos_ParameterList.hpp" 00030 #include "Teuchos_XMLParameterListHelpers.hpp" 00031 #include "Teuchos_DefaultComm.hpp" 00032 #include "Teuchos_CommHelpers.hpp" 00033 00034 #include "Teuchos_UnitTestHarness.hpp" 00035 00036 00037 namespace Teuchos { 00038 00039 00040 TEUCHOS_UNIT_TEST( Teuchos_ParameterList, xmlUpdateAndBroadcast ) { 00041 const RCP<const Comm<int> > comm = DefaultComm<int>::getComm(); 00042 // Test the broadcast functionality to avoid unscalable I/O collisions 00043 std::string inputFile="input.xml"; 00044 ParameterList A; 00045 ParameterList B; 00046 updateParametersFromXmlFile(inputFile, &A); 00047 updateParametersFromXmlFileAndBroadcast(inputFile, &B, *comm); 00048 out << "B = " << B; 00049 TEST_ASSERT( B.begin() != B.end() ); // Avoid false positive from empty lists 00050 00051 // See if any process returned a failed (i.e. a non-zero local_failed) 00052 int local_failed = !(A == B); 00053 int global_failed = -1; 00054 reduceAll( *comm, Teuchos::REDUCE_SUM, local_failed, outArg(global_failed) ); 00055 TEST_EQUALITY_CONST( global_failed, 0 ); 00056 } 00057 00058 00059 } // namespace Teuchos 00060 00061 00062
1.7.4