The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use warnings;
use autodie;

use Statistics::RserveClient::Connection;
use Statistics::RserveClient::REXP::Logical;
use Statistics::RserveClient::REXP::Symbol;
use Statistics::RserveClient::REXP::String;
use Statistics::RserveClient::REXP::Integer;
use Statistics::RserveClient::REXP::Double;

use Test::More;    # tests => 12;

SKIP: {
    eval {
        my $object = Statistics::RserveClient::Connection->new('localhost');
        if ( !ref($object) || !UNIVERSAL::can( $object, 'can' ) ) {
            die "Can't create a connection\n";
        }
    };
    skip "Looks like Rserve is not reachable.  Skipping test.", 12 if $@;

    my $cnx
        = new_ok( 'Statistics::RserveClient::Connection' => ['localhost'] );

    my @expected_true_scalar = (1);
    my $x                    = new Statistics::RserveClient::REXP::Logical;
    $x->setValues( \@expected_true_scalar );
    $cnx->assign( 'x', $x );
    my @true_scalar = $cnx->evalString('x');
    # print join(':', @true_scalar) . "\n";
    # print join(':', @expected_true_scalar) . "\n";
    is_deeply( \@true_scalar, \@expected_true_scalar, 'scalar TRUE value' )
        or diag explain @true_scalar;

    my @expected_false_scalar = (0);
    $x->setValues( \@expected_false_scalar );
    $cnx->assign( 'x', $x );
    my @false_scalar = $cnx->evalString('x');
    is_deeply( \@false_scalar, \@expected_false_scalar, 'scalar FALSE value' )
        or diag explain @false_scalar;

    my @expected_bool_vector = ( 1, 0, 1 );
    $x->setValues( \@expected_bool_vector );
    $cnx->assign( 'x', $x );
    my @bool_vector = $cnx->evalString('x');
    is_deeply( \@bool_vector, \@expected_bool_vector, 'boolean array' )
        or diag explain @bool_vector;

    my @expected_char_scalar = 'z';
    $x = new Statistics::RserveClient::REXP::String;
    $x->setValues( \@expected_char_scalar );
    $cnx->assign( 'x', $x );
    my @char_scalar = $cnx->evalString('x');
    is_deeply( \@char_scalar, \@expected_char_scalar,
        'single-char string scalar' )
        or diag explain @char_scalar;

    my @expected_char_vector = ( 'a', 'b', 'c', 'd' );
    $x->setValues( \@expected_char_vector );
    $cnx->assign( 'x', $x );
    my @char_vector = $cnx->evalString('x');
    is_deeply( \@char_vector, \@expected_char_vector,
        'vector of single-char strings' )
        or diag explain @char_vector;

    my @expected_string_scalar = 'Dec';
    $x->setValues( \@expected_string_scalar );
    $cnx->assign( 'x', $x );
    my @string_scalar = $cnx->evalString('x');
    is_deeply( \@string_scalar, \@expected_string_scalar, 'string scalar' )
        or diag explain @string_scalar;

    my @expected_string_vector = ( 'Jan', 'Feb', 'Mar' );
    $x->setValues( \@expected_string_vector );
    $cnx->assign( 'x', $x );

    my @string_vector = $cnx->evalString('x');
    is_deeply( \@string_vector, \@expected_string_vector,
        'vector of strings' )
        or diag explain @string_vector;

    my @expected_int_scalar = 123;
    $x = new Statistics::RserveClient::REXP::Integer;
    $x->setValues( \@expected_int_scalar );
    $cnx->assign( 'x', $x );
    my @int_scalar = $cnx->evalString('x');
    is_deeply( \@int_scalar, \@expected_int_scalar, 'single-int scalar' )
        or diag explain @int_scalar;

    my @expected_int_vector = ( 101 .. 110 );
    $x->setValues( \@expected_int_vector );
    $cnx->assign( 'x', $x );
    my @int_vector = $cnx->evalString('x');
    is_deeply( \@int_vector, \@expected_int_vector, 'vector of ints' )
        or diag explain @int_vector;

    my @expected_double_scalar = 1.5;
    $x = new Statistics::RserveClient::REXP::Double;
    $x->setValues( \@expected_double_scalar );
    $cnx->assign( 'x', $x );
    my @double_scalar = $cnx->evalString('x');
    is_deeply( \@double_scalar, \@expected_double_scalar, 'double scalar' )
        or diag explain @double_scalar;

    my @expected_double_vector = ( 0.5, 1, 1.5, 2 );
    $x->setValues( \@expected_double_vector );
    $cnx->assign( 'x', $x );
    my @double_vector = $cnx->evalString('x');
    is_deeply( \@double_vector, \@expected_double_vector,
        'vector of doubles' )
        or diag explain @double_vector;

}

done_testing();