use Graph::Directed;
use strict;
local $^W = 1;
print "1..30\n";
my $g = Graph::Directed->new(compat02 => 1);
$g->add_edge('a', 'b');
$g->add_edge('b', 'c');
$g->add_edge('a', 'd');
$g->add_vertex('e');
print "not " unless $g->in_degree('a') == 0;
print "ok 1\n";
print "not " unless $g->out_degree('a') == 2;
print "ok 2\n";
print "not " unless $g->degree('a') == -2;
print "ok 3\n";
print "not " unless $g->in_degree('b') == 1;
print "ok 4\n";
print "not " unless $g->out_degree('b') == 1;
print "ok 5\n";
print "not " unless $g->degree('b') == 0;
print "ok 6\n";
print "not " unless $g->in_degree('c') == 1;
print "ok 7\n";
print "not " unless $g->out_degree('c') == 0;
print "ok 8\n";
print "not " unless $g->degree('c') == 1;
print "ok 9\n";
print "not " unless $g->in_degree('d') == 1;
print "ok 10\n";
print "not " unless $g->out_degree('d') == 0;
print "ok 11\n";
print "not " unless $g->degree('d') == 1;
print "ok 12\n";
print "not " unless $g->in_degree('e') == 0;
print "ok 13\n";
print "not " unless $g->out_degree('e') == 0;
print "ok 14\n";
print "not " unless $g->degree('e') == 0;
print "ok 15\n";
print "not " if defined $g->in_degree('x');
print "ok 16\n";
print "not " if defined $g->out_degree('x');
print "ok 17\n";
print "not " if defined $g->degree('x');
print "ok 18\n";
print "not " unless join(" ", $g->in_edges('b')) eq "a b";
print "ok 19\n";
print "not " unless join(" ", $g->out_edges('b')) eq "b c";
print "ok 20\n";
print "not " unless join(" ", $g->edges('b')) eq "a b b c" ||
join(" ", $g->edges('b')) eq "b c a b";
print "ok 21\n";
print "not " if defined $g->in_edges('x');
print "ok 22\n";
print "not " if defined $g->out_edges('x');
print "ok 23\n";
print "not " unless $g->edges == 3;
print "ok 24\n";
print "not " unless join(" ", sort $g->sink_vertices) eq "c d";
print "ok 25\n";
print "not " unless join(" ", sort $g->source_vertices) eq "a";
print "ok 26\n";
print "not " unless join(" ", sort $g->exterior_vertices) eq "a c d e";
print "ok 27\n";
print "not " unless join(" ", sort $g->interior_vertices) eq "b";
print "ok 28\n";
$g->add_cycle('f');
print "not " unless join(" ", sort $g->self_loop_vertices) eq "f";
print "ok 29\n";
print "not " unless join(" ", sort $g->interior_vertices) eq "b";
print "ok 30\n";