Koha/t/db_dependent/lib/KohaTest/Members/DebarMember.pm
Paul Poulain d019b4c63a Bug 6328 Fixes for comment 35
* correctly indenting with tab the debarrcomment field
* setdebar.pl is called without status parameter, thus it is not working anymore. It's fixed & some dead code has been removed. To test : debar someone, then go to patron detail page and click "lift debarment"
* the test function had not been updated. The fix define a debarment date of 2099-12-31 (no limit)
2011-11-25 14:00:47 +01:00

44 lines
1.4 KiB
Perl

package KohaTest::Members::DebarMember;
use base qw( KohaTest::Members );
use strict;
use warnings;
use Test::More;
use C4::Members;
sub testing_class { 'C4::Members' };
sub simple_usage : Test( 6 ) {
my $self = shift;
ok( $self->{'memberid'}, 'we have a valid memberid to test with' );
my $details = C4::Members::GetMemberDetails( $self->{'memberid'} );
ok( exists $details->{'flags'}, 'member details has a "flags" attribute');
isa_ok( $details->{'flags'}, 'HASH', 'the "flags" attribute is a hashref');
ok( ! $details->{'flags'}->{'DBARRED'}, 'this member is NOT debarred' );
# Now, let's debar this member and see what happens
my $success = C4::Members::DebarMember( $self->{'memberid'}, '2099-12-31' );
ok( $success, 'we were able to debar the member' );
$details = C4::Members::GetMemberDetails( $self->{'memberid'} );
ok( $details->{'flags'}->{'DBARRED'}, 'this member is debarred now' )
or diag( Data::Dumper->Dump( [ $details->{'flags'} ], [ 'flags' ] ) );
}
sub incorrect_usage : Test( 2 ) {
my $self = shift;
my $result = C4::Members::DebarMember();
ok( ! defined $result, 'DebarMember returns undef when passed no parameters' );
$result = C4::Members::DebarMember( 'this is not a borrowernumber' );
ok( ! defined $result, 'DebarMember returns undef when not passed a numeric argument' );
}
1;