/* -*- C++ -*- * src/test/test_tools.h - Part of HUGOlib, a generic C++ optimization library * * Copyright (C) 2004 Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport * (Egervary Combinatorial Optimization Research Group, EGRES). * * Permission to use, modify and distribute this software is granted * provided that this copyright notice appears in all copies. For * precise terms see the accompanying LICENSE file. * * This software is provided "AS IS" with no warranty of any kind, * express or implied, and with no claim as to its suitability for any * purpose. * */ #ifndef HUGO_TEST_TEST_TOOLS_H #define HUGO_TEST_TEST_TOOLS_H //! \ingroup misc //! \file //! \brief Some utility to write test programs. #include #include ///If \c rc is fail, writes an error message end exit. ///If \c rc is fail, writes an error message end exit. ///The error message contains the file name and the line number of the ///source code in a standard from, which makes it possible to go there ///using good source browsers like e.g. \c emacs. /// ///For example ///\code check(0==1,"This is obviously false.");\endcode will ///print this (and then exits). ///\verbatim graph_test.cc:123: error: This is obviously false. \endverbatim /// ///\todo It should be in \c error.h #define check(rc, msg) \ if(!(rc)) { \ std::cerr << __FILE__ ":" << __LINE__ << ": error: " << msg << std::endl; \ exit(1); \ } else { } \ ///Structure returned by \ref addPetersen(). ///Structure returned by \ref addPetersen(). /// template struct PetStruct { ///Vector containing the outer nodes. std::vector outer; ///Vector containing the inner nodes. std::vector inner; ///Vector containing the edges of the inner circle. std::vector incir; ///Vector containing the edges of the outer circle. std::vector outcir; ///Vector containing the chord edges. std::vector chords; }; ///Adds a Petersen graph to \c G. ///Adds a Petersen graph to \c G. ///\return The nodes and edges of the generated graph. template PetStruct addPetersen(Graph &G,int num=5) { PetStruct n; for(int i=0;i struct SymPetStruct { ///Vector containing the outer nodes. std::vector outer; ///Vector containing the inner nodes. std::vector inner; ///Vector containing the edges of the inner circle. std::vector incir; ///Vector containing the edges of the outer circle. std::vector outcir; ///Vector containing the chord edges. std::vector chords; }; ///Adds a Petersen graph to the symmetric \c G. ///Adds a Petersen graph to the symmetric \c G. ///\return The nodes and edges of the generated graph. template SymPetStruct addSymPetersen(Graph &G,int num=5) { SymPetStruct n; for(int i=0;i