File: 30_mixedged.t

package info (click to toggle)
libgraph-perl 1%3A0.96-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 1,316 kB
  • ctags: 938
  • sloc: perl: 6,094; sh: 8; makefile: 2
file content (36 lines) | stat: -rw-r--r-- 813 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use Test::More tests => 96;
	
use Graph;

for my $m (0, 1) {
    for my $r (0, 1) {
	for my $h (0, 1) {
	    my $g = Graph->new(countedged => $m,
			       hyperedged => $h);
	    print "# m = $m, c = $r, h = $h\n";
	    $g->omnidirected($r);
	    $g->add_edge("a", "b");
	    $g->add_edge("a", "b");
	    if ($g->hyperedged) {
		$g->add_edge("c", "d", "e");
		$g->add_edge("c", "d", "e");
	    }
	    for (1, 2) {
		ok(  $g->has_vertices( ) );
		ok(  $g->has_edge("a", "b") );
		if ($g->hyperedged) {
		    ok(  $g->has_edge("c", "d", "e") );
		}
		ok( !$g->has_edge("e", "f") );
	    }
	    for (1, 2) {
		is( $g->get_edge_count("a", "b"),      $m ? 2 : 1 );
		if ($g->hyperedged) {
		    is( $g->get_edge_count("c", "d", "e"), $m ? 2 : 1 );
		}
		is( $g->get_edge_count("e", "f"),      0 );
	    }
	}
    }
}