use Test::More tests => 25; use Graph; my $g = Graph->new; $g->add_edge(qw(a b)); $g->add_edge(qw(b c)); $g->add_edge(qw(b d)); $g->add_edge(qw(d d)); my $m = Graph::BitMatrix->new($g); ok(!$m->get(qw(a a)) ); ok( $m->get(qw(a b)) ); ok(!$m->get(qw(a c)) ); ok(!$m->get(qw(a d)) ); ok(!$m->get(qw(b a)) ); ok(!$m->get(qw(b b)) ); ok( $m->get(qw(b c)) ); ok( $m->get(qw(b d)) ); ok(!$m->get(qw(c a)) ); ok(!$m->get(qw(c b)) ); ok(!$m->get(qw(c c)) ); ok(!$m->get(qw(c d)) ); ok(!$m->get(qw(d a)) ); ok(!$m->get(qw(d b)) ); ok(!$m->get(qw(d c)) ); ok( $m->get(qw(d d)) ); $m->set(qw(c c)); ok( $m->get(qw(c c)) ); $m->unset(qw(c c)); ok(!$m->get(qw(c c)) ); is("@{[$m->get_row(qw(a a b c d))]}", "0 1 0 0"); is("@{[$m->get_row(qw(b a b c d))]}", "0 0 1 1"); is("@{[$m->get_row(qw(c a b c d))]}", "0 0 0 0"); is("@{[$m->get_row(qw(d a b c d))]}", "0 0 0 1"); is( $m->get(qw(x x)), undef ); is("@{[sort $m->vertices]}", "a b c d"); eval 'Graph::BitMatrix->new($g, nonesuch => 1)'; like($@, qr/Graph::BitMatrix::new: Unknown option: 'nonesuch' /);