src/test/graph_wrapper_test.cc
author marci
Mon, 22 Nov 2004 09:09:18 +0000
changeset 1016 18d009b23e42
parent 997 665ffade9aca
child 1160 d9c32f713cad
permissions -rw-r--r--
bug fix in SubBidirGraphWrapper, roadmap to MergeGraphWrapper
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@906
     4
 * Copyright (C) 2004 Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
alpar@906
     5
 * (Egervary Combinatorial Optimization Research Group, 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>
klao@946
    22
alpar@921
    23
#include<lemon/list_graph.h>
alpar@921
    24
#include<lemon/full_graph.h>
alpar@921
    25
#include<lemon/graph_wrapper.h>
marci@849
    26
marci@870
    27
#include"test/test_tools.h"
marci@870
    28
#include"test/graph_test.h"
marci@849
    29
marci@849
    30
/**
marci@849
    31
\file
alpar@878
    32
This test makes consistency checks of graph wrappers.
marci@849
    33
alpar@878
    34
\todo More extensive tests are needed 
marci@849
    35
*/
marci@849
    36
alpar@921
    37
using namespace lemon;
klao@959
    38
using namespace lemon::concept;
marci@849
    39
marci@849
    40
marci@849
    41
marci@849
    42
int main() 
marci@849
    43
{
klao@946
    44
  {
marci@998
    45
    typedef StaticGraph Graph;
marci@998
    46
    checkConcept<StaticGraph, GraphWrapper<Graph> >();
klao@946
    47
marci@998
    48
    checkConcept<StaticGraph, RevGraphWrapper<Graph> >();
klao@946
    49
marci@998
    50
    checkConcept<StaticGraph, SubGraphWrapper<Graph, 
marci@998
    51
      Graph::NodeMap<bool> , Graph::EdgeMap<bool> > >();
marci@998
    52
    checkConcept<StaticGraph, NodeSubGraphWrapper<Graph, 
marci@998
    53
      Graph::NodeMap<bool> > >();
marci@998
    54
    checkConcept<StaticGraph, EdgeSubGraphWrapper<Graph, 
marci@998
    55
      Graph::EdgeMap<bool> > >();
marci@992
    56
    
marci@998
    57
    checkConcept<StaticGraph, SubBidirGraphWrapper<Graph, 
marci@998
    58
      Graph::EdgeMap<bool>, Graph::EdgeMap<bool> > >();
marci@998
    59
    checkConcept<StaticGraph, BidirGraph<Graph> >();
marci@998
    60
    checkConcept<StaticGraph, ResGraphWrapper<Graph, int, 
marci@998
    61
      Graph::EdgeMap<int>, Graph::EdgeMap<int> > >();
klao@946
    62
marci@998
    63
    checkConcept<StaticGraph, ErasingFirstGraphWrapper<Graph, 
marci@998
    64
      Graph::NodeMap<Graph::Edge> > >(); 
klao@946
    65
  }
marci@849
    66
  std::cout << __FILE__ ": All tests passed.\n";
marci@849
    67
marci@849
    68
  return 0;
marci@849
    69
}