App-Dochazka-CLI

 view release on metacpan or  search on metacpan

t/001-init.t  view on Meta::CPAN

    my ( $cmd, $rv, $status );

    $cmd = "EMPLOYEE=$nick PROFILE";
    $rv = process_command( $cmd );
    is( ref( $rv ), 'App::CELL::Status' );
    unless ( $rv->level eq 'OK' and $rv->code eq 'DOCHAZKA_CLI_NORMAL_COMPLETION' ) {

        # create employee $nick and assign privlevel $privlevel
        $cmd = "PUT employee nick $nick { \"fullname\" : \"$fullname\", \"password\" : \"$nick\" }";
        $rv = process_command( $cmd );
        is( ref( $rv ), 'App::CELL::Status' );
        is( $rv->{'http_status'}, '200 OK' );
        is( $rv->code, 'DOCHAZKA_CUD_OK' );

        $cmd = "POST priv history nick $nick { \"priv\" : \"$privlevel\", \"effective\" : \"2000-01-01 00:00\" }";
        $rv = process_command( $cmd );
        is( ref( $rv ), 'App::CELL::Status' );
        is( $rv->{'http_status'}, '201 Created' );
        is( $rv->code, 'DOCHAZKA_CUD_OK' );

    }

}

sub create_testing_schedule {
    my ( $cmd, $rv );

    note( "Create a testing schedule" );

    $cmd = "SCHEDULE ALL 8:00-12:00";
    $rv = process_command( $cmd );
    is( ref( $rv ), 'App::CELL::Status' );
    is( $rv->level, 'OK', "process_command( $cmd ) returned OK status" );
    is( $rv->{'http_status'}, undef );

    $cmd = "SCHEDULE ALL 12:30-16:30";
    $rv = process_command( $cmd );
    is( ref( $rv ), 'App::CELL::Status' );
    is( $rv->level, 'OK', "process_command( $cmd ) returned OK status" );
    is( $rv->{'http_status'}, undef );

    $cmd = "SCHEDULE SCODE KOBOLD";
    $rv = process_command( $cmd );
    is( ref( $rv ), 'App::CELL::Status' );
    is( $rv->level, 'OK', "process_command( $cmd ) returned OK status" );
    is( $rv->{'http_status'}, undef );

    $cmd = "SCHEDULE NEW";
    $rv = process_command( $cmd );
    is( ref( $rv ), 'App::CELL::Status' );
    is( $rv->level, 'OK', "process_command( $cmd ) returned OK status" );
    is( $rv->{'http_status'}, '200 OK' );

}


my ( $cmd, $rv, $rv_type, $status );

$rv = init_unit();
$rv_type = ref( $rv );
if ( $rv_type ne 'App::CELL::Status' or $rv->not_ok ) {
    diag "init_unit returned unexpected status:";
    diag( Dumper $rv );
    BAIL_OUT(0);
}

$rv = authenticate_to_server( user => 'root', password => 'immutable', quiet => 1 );
$rv_type = ref( $rv );
if ( $rv_type ne 'App::CELL::Status' or $rv->not_ok ) {
    if ( $rv->{'http_status'} =~ m/500 Can\'t connect/ ) {
        plan skip_all => "Can't connect to server";
    } else {
        diag "authenticate_to_server returned unexpected status:";
        diag( Dumper $rv );
        BAIL_OUT(0);
    }
}

create_employees_carefully( 'worker', 'active', 'Joe Working Stiff' );

create_employees_carefully( 'absent', 'inactive', 'On Leave Dude' );

create_testing_schedule();

$cmd = "EMPLOYEE=worker SCODE=KOBOLD 2015-01-01";
$rv = process_command( $cmd );
is( ref( $rv ), 'App::CELL::Status' );
if ( $rv->level eq 'OK' ) {
    # schedule history record did not exist and was just now created
    is( $rv->code, 'DOCHAZKA_CLI_SCHEDULE_HISTORY_ADD' );
} else {
    # schedule history record already existed
    is( $rv->code, 'DOCHAZKA_DBI_ERR' );
    like( $rv->text, qr/duplicate key value violates unique constraint "schedhistory_eid_effective_key"/ );
}

done_testing;



( run in 0.728 second using v1.01-cache-2.11-cpan-98e64b0badf )