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");
}