52_edge_attributes.t [plain text]
use Test::More tests => 101;
use Graph;
my $g = Graph->new;
$g->add_edge("a", "b");
ok( !$g->has_edge_attributes("a", "b") );
ok( !$g->has_edge_attributes("a", "b") );
ok( $g->set_edge_attribute("a", "b", "color", "red") );
ok( $g->has_edge_attribute("a", "b", "color") );
ok( $g->has_edge_attribute("a", "b", "color") );
ok( $g->has_edge_attributes("a", "b") );
ok( $g->has_edge_attributes("a", "b") );
is( $g->get_edge_attribute("a", "b", "color"), "red" );
is( $g->get_edge_attribute("a", "b", "color"), "red" );
is( $g->get_edge_attribute("a", "b", "colour"), undef );
is( $g->get_edge_attribute("a", "b", "colour"), undef );
ok( $g->set_edge_attribute("a", "b", "color", "green") );
ok( $g->has_edge_attributes("a", "b") );
ok( $g->has_edge_attributes("a", "b") );
is( $g->get_edge_attribute("a", "b", "color"), "green" );
is( $g->get_edge_attribute("a", "b", "color"), "green" );
my $attr = $g->get_edge_attributes("a", "b");
my @name = $g->get_edge_attribute_names("a", "b");
my @val = $g->get_edge_attribute_values("a", "b");
is( scalar keys %$attr, 1 );
is( scalar @name, 1 );
is( scalar @val, 1 );
is( $attr->{color}, "green" );
is( $name[0], "color" );
is( $val[0], "green" );
ok( $g->set_edge_attribute("a", "b", "taste", "rhubarb") );
ok( $g->has_edge_attributes("a", "b") );
ok( $g->has_edge_attributes("a", "b") );
is( $g->get_edge_attribute("a", "b", "taste"), "rhubarb" );
is( $g->get_edge_attribute("a", "b", "taste"), "rhubarb" );
is( $g->get_edge_attribute("a", "b", "color"), "green" );
is( $g->get_edge_attribute("a", "b", "taste"), "rhubarb" );
$attr = $g->get_edge_attributes("a", "b");
@name = sort $g->get_edge_attribute_names("a", "b");
@val = sort $g->get_edge_attribute_values("a", "b");
is( scalar keys %$attr, 2 );
is( scalar @name, 2 );
is( scalar @val, 2 );
is( $attr->{color}, "green" );
is( $attr->{taste}, "rhubarb" );
is( $name[0], "color" );
is( $val[0], "green" );
is( $name[1], "taste" );
is( $val[1], "rhubarb" );
ok( $g->delete_edge_attribute("a", "b", "color" ) );
ok( !$g->has_edge_attribute("a", "b", "color" ) );
ok( $g->has_edge_attributes("a", "b") );
is( $g->get_edge_attribute("a", "b", "taste"), "rhubarb" );
ok( $g->delete_edge_attributes("a", "b") );
ok( !$g->has_edge_attributes("a", "b") );
is( $g->get_edge_attribute("a", "b", "taste"), undef );
ok( !$g->delete_edge_attribute("a", "b", "taste" ) );
ok( !$g->delete_edge_attributes("a", "b") );
$attr = $g->get_edge_attributes("a", "b");
@name = $g->get_edge_attribute_names("a", "b");
@val = $g->get_edge_attribute_values("a", "b");
is( scalar keys %$attr, 0 );
is( scalar @name, 0 );
is( scalar @val, 0 );
ok( $g->delete_edge("c", "d") );
ok(!$g->has_edge("c", "d"));
$g->add_weighted_edge("c", "d", 42);
ok( $g->has_edge("c", "d") );
is( $g->get_edge_attribute("c", "d", "weight"), 42 );
is( $g->edges, 2 );
ok( $g->delete_edge("c", "d") );
ok( $g->delete_edge("e", "f") );
ok(!$g->has_edge("c", "d"));
ok(!$g->has_edge("e", "f"));
$g->add_weighted_edges("c", "d", 43, "e", "f", 44);
ok( $g->has_edge("c", "d") );
ok( $g->has_edge("e", "f") );
is( $g->get_edge_weight("c", "d"), 43 );
is( $g->get_edge_weight("e", "f"), 44 );
is( $g->edges, 3 );
ok( $g->delete_edge("c", "d") );
ok( $g->delete_edge("d", "e") );
$g->add_weighted_path("c", 45, "d", 46, "e");
ok( $g->has_edge("c", "d") );
ok( $g->has_edge("d", "e") );
is( $g->get_edge_weight("c", "d"), 45 );
is( $g->get_edge_weight("d", "e"), 46 );
is( $g->edges, 4 );
use Graph::Undirected;
my $u = Graph::Undirected->new;
$u->add_weighted_edge('a', 'b', 123);
is($u->get_edge_weight('a', 'b'), 123);
is($u->get_edge_weight('b', 'a'), 123);
ok($u->set_edge_attributes('a', 'b',
{ 'color' => 'pearl', 'weight' => 'heavy' }));
$attr = $u->get_edge_attributes('a', 'b');
is(scalar keys %$attr, 2);
is($attr->{color}, 'pearl');
is($attr->{weight}, 'heavy');
ok( $g->set_edge_weight("a", "b", 42));
is( $g->get_edge_weight("a", "b"), 42);
ok( $g->has_edge_weight("a", "b"));
ok(!$g->has_edge_weight("a", "c"));
ok( $g->delete_edge_weight("a", "b"));
ok(!$g->has_edge_weight("a", "b"));
is( $g->get_edge_weight("a", "b"), undef);
my $v = Graph::Undirected->new;
$v->add_weighted_path("b", 1, "f",
2, "c",
3, "d",
3, "f",
2, "g",
2, "e");
ok( $v, "b=f,c=d,c=f,d=f,e=g,f=g" );
{
use Graph::Directed;
use Graph::Undirected;
my $g1a = Graph::Directed->new;
my $g1b = Graph::Undirected->new;
$g1a->add_edge(qw(a b));
$g1a->add_edge(qw(b c));
$g1a->add_edge(qw(b d));
$g1b->add_edge(qw(a b));
$g1b->add_edge(qw(b c));
$g1b->add_edge(qw(b d));
$g1a->set_edge_attribute('b', 'c', 'color', 'electric blue');
$g1b->set_edge_attribute('b', 'c', 'color', 'firetruck red');
is("@{[sort $g1a->successors('a')]}", "b");
is("@{[sort $g1a->successors('b')]}", "c d");
is("@{[sort $g1a->successors('c')]}", "");
is("@{[sort $g1a->successors('d')]}", "");
is("@{[sort $g1a->predecessors('a')]}", "");
is("@{[sort $g1a->predecessors('b')]}", "a");
is("@{[sort $g1a->predecessors('c')]}", "b");
is("@{[sort $g1a->predecessors('d')]}", "b");
is("@{[sort $g1b->successors('a')]}", "b");
is("@{[sort $g1b->successors('b')]}", "a c d");
is("@{[sort $g1b->successors('c')]}", "b");
is("@{[sort $g1b->successors('d')]}", "b");
is("@{[sort $g1b->predecessors('a')]}", "b");
is("@{[sort $g1b->predecessors('b')]}", "a c d");
is("@{[sort $g1b->predecessors('c')]}", "b");
is("@{[sort $g1b->predecessors('d')]}", "b");
}