src/test/graph_wrapper_test.cc
author alpar
Mon, 25 Apr 2005 16:22:04 +0000
changeset 1390 9c8e464ed940
parent 1359 1581f961cfaa
permissions -rw-r--r--
LpSkeleton updated
alpar@906
     1
/* -*- C++ -*-
alpar@921
     2
 * src/test/graph_wrapper_test.cc - Part of LEMON, a generic C++ optimization library
alpar@906
     3
 *
alpar@1164
     4
 * Copyright (C) 2005 Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
alpar@1359
     5
 * (Egervary Research Group on Combinatorial Optimization, EGRES).
alpar@906
     6
 *
alpar@906
     7
 * Permission to use, modify and distribute this software is granted
alpar@906
     8
 * provided that this copyright notice appears in all copies. For
alpar@906
     9
 * precise terms see the accompanying LICENSE file.
alpar@906
    10
 *
alpar@906
    11
 * This software is provided "AS IS" with no warranty of any kind,
alpar@906
    12
 * express or implied, and with no claim as to its suitability for any
alpar@906
    13
 * purpose.
alpar@906
    14
 *
alpar@906
    15
 */
alpar@906
    16
marci@849
    17
#include<iostream>
klao@946
    18
#include<lemon/concept_check.h>
klao@946
    19
alpar@921
    20
#include<lemon/smart_graph.h>
klao@959
    21
#include<lemon/concept/graph.h>
marci@1383
    22
#include<lemon/concept/undir_graph.h>
klao@946
    23
alpar@921
    24
#include<lemon/list_graph.h>
alpar@921
    25
#include<lemon/full_graph.h>
alpar@921
    26
#include<lemon/graph_wrapper.h>
marci@849
    27
marci@870
    28
#include"test/test_tools.h"
marci@870
    29
#include"test/graph_test.h"
marci@849
    30
marci@849
    31
/**
marci@849
    32
\file
alpar@878
    33
This test makes consistency checks of graph wrappers.
marci@849
    34
alpar@878
    35
\todo More extensive tests are needed 
marci@849
    36
*/
marci@849
    37
alpar@921
    38
using namespace lemon;
klao@959
    39
using namespace lemon::concept;
marci@849
    40
marci@849
    41
marci@849
    42
marci@849
    43
int main() 
marci@849
    44
{
klao@946
    45
  {
marci@998
    46
    typedef StaticGraph Graph;
marci@998
    47
    checkConcept<StaticGraph, GraphWrapper<Graph> >();
klao@946
    48
marci@998
    49
    checkConcept<StaticGraph, RevGraphWrapper<Graph> >();
klao@946
    50
marci@998
    51
    checkConcept<StaticGraph, SubGraphWrapper<Graph, 
marci@998
    52
      Graph::NodeMap<bool> , Graph::EdgeMap<bool> > >();
marci@998
    53
    checkConcept<StaticGraph, NodeSubGraphWrapper<Graph, 
marci@998
    54
      Graph::NodeMap<bool> > >();
marci@998
    55
    checkConcept<StaticGraph, EdgeSubGraphWrapper<Graph, 
marci@998
    56
      Graph::EdgeMap<bool> > >();
marci@992
    57
    
marci@998
    58
    checkConcept<StaticGraph, SubBidirGraphWrapper<Graph, 
marci@998
    59
      Graph::EdgeMap<bool>, Graph::EdgeMap<bool> > >();
alpar@1160
    60
    //    checkConcept<StaticGraph, BidirGraph<Graph> >();
marci@998
    61
    checkConcept<StaticGraph, ResGraphWrapper<Graph, int, 
marci@998
    62
      Graph::EdgeMap<int>, Graph::EdgeMap<int> > >();
klao@946
    63
marci@998
    64
    checkConcept<StaticGraph, ErasingFirstGraphWrapper<Graph, 
marci@998
    65
      Graph::NodeMap<Graph::Edge> > >(); 
marci@1383
    66
marci@1383
    67
    /// \bug why does not compile with StaticGraph
marci@1383
    68
    checkConcept<BaseIterableUndirGraphConcept, UndirGraphWrapper<ListGraph> >();
marci@1383
    69
    checkConcept<IterableUndirGraphConcept, UndirGraphWrapper<ListGraph> >();
marci@1383
    70
    checkConcept<MappableUndirGraphConcept, UndirGraphWrapper<ListGraph> >();
klao@946
    71
  }
marci@849
    72
  std::cout << __FILE__ ": All tests passed.\n";
marci@849
    73
marci@849
    74
  return 0;
marci@849
    75
}