Config-OpenSSH-Authkey

 view release on metacpan or  search on metacpan

t/040-authkey.t  view on Meta::CPAN

#!perl
#
# Tests for Config::OpenSSH::Authkey and the utility
# Config::OpenSSH::Authkey::MetaEntry class.

use strict;
use warnings;

use Test::More tests => 39;

BEGIN { use_ok('Config::OpenSSH::Authkey') }
ok( defined $Config::OpenSSH::Authkey::VERSION, '$VERSION defined' );

# Utility class tests
{
    can_ok( 'Config::OpenSSH::Authkey::MetaEntry', qw{new as_string} );

    my $test_line  = '# some comment';
    my $meta_entry = Config::OpenSSH::Authkey::MetaEntry->new($test_line);
    isa_ok( $meta_entry, 'Config::OpenSSH::Authkey::MetaEntry' );

    is( $meta_entry->as_string, $test_line, 'check MetaEntry as_string' );
}

eval {
    can_ok(
        'Config::OpenSSH::Authkey',
        qw/new fh file iterate consume parse
          get_stored_keys reset_store reset_dups
          auto_store tag_dups nostore_nonkey_data/
    );

    my $ak = Config::OpenSSH::Authkey->new();
    isa_ok( $ak, 'Config::OpenSSH::Authkey' );
    ok( !@{ $ak->get_stored_keys }, 'check that no keys exist' );

    my @prefs = qw/auto_store tag_dups nostore_nonkey_data/;
    for my $pref (@prefs) {
        is( $ak->$pref, 0, "check default for $pref setting" );
    }

    # Confirm options can be passed to new()
    my $ak_opts = Config::OpenSSH::Authkey->new(
        { auto_store => 1, tag_dups => 1, nostore_nonkey_data => 1 } );
    for my $pref (@prefs) {
        is( $ak_opts->$pref, 1, "check non-default for $pref setting" );
    }

    $ak->auto_store(1);
    $ak->nostore_nonkey_data(1);
    is( $ak->auto_store, 1, 'check that auto_store setting updated' );

    $ak->file('t/authorized_keys')->consume;
    is( scalar @{ $ak->get_stored_keys }, 6, 'check that all keys loaded' );

    $ak->reset_store();
    ok( !@{ $ak->get_stored_keys }, 'check that no keys exist' );

    $ak->tag_dups(1);

    open( my $input_fh, '<', 't/authorized_keys' )
      or diag("error: cannot open: file=t/authorized_keys, errstr=$!\n");
    $ak->fh($input_fh);
    while ( my $entry = $ak->iterate ) {
        ok( $entry->can('as_string'), 'check that object has as_string method' );
    }

    is( scalar @{ $ak->get_stored_keys }, 6, 'check that keys loaded again' );

    is( scalar grep( $_->duplicate_of, @{ $ak->get_stored_keys } ),
        1, 'check for duplicate' );

    # The dup record should be a reference to the key that is duplicated
    my $dup_ref = $ak->get_stored_keys->[2]->duplicate_of;
    isa_ok( $dup_ref, 'Config::OpenSSH::Authkey::Entry' );

    ok( $dup_ref->key eq $ak->get_stored_keys->[2]->key,
        'check that duplicate keys identical'
    );
};
if ($@) {
    diag("Unexpected exception: $@");
}

eval {
    my $ak = Config::OpenSSH::Authkey->new();
    $ak->parse('not a pubkey');
};
like( $@, qr/unable to parse public key/, "invalid pubkey error" );

exit 0;



( run in 2.046 seconds using v1.01-cache-2.11-cpan-0bb4e1dffa6 )