The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!perl -T
use warnings; use strict;
use Test::More tests => 24;
use Test::Fatal;
use Scalar::Util;

use lib '.';
use t::Elive;

use Elive;
use Elive::Entity::User;

my $class = 'Elive::Entity::User' ;

is($class->quote('') => '', 'quote - empty string');
is($class->quote(' ') => "' '", 'quote - space');
is($class->quote('abc123') => 'abc123', 'quote - single word');
is($class->quote('abc 123') => "'abc 123'", 'quote - words');
is($class->quote("O'Reilly") => "'O''Reilly'", 'quote - embedded quote');

SKIP: {

    my %result = t::Elive->test_connection();
    my $auth = $result{auth};

    skip ($result{reason} || 'skipping live tests', 19)
	unless $auth && @$auth;

    my $connection_class = $result{class};
    my $connection = $connection_class->connect(@$auth);
    Elive->connection($connection);

    my $login = Elive->login;
    ok(Scalar::Util::blessed($login), 'Elive->login returns an object');

    #
    # just retest some of our entity management with active live or mock
    # connections.
    #

    ok(!$login->is_changed, 'login not yet changed');

    my $loginName_old = $login->loginName;
	
    my $loginName_new = $loginName_old.'x';
    $login->loginName($loginName_new);

    is($login->loginName, $loginName_new, 'login name changed enacted');
    ok($login->is_changed, 'login object showing as changed');

    my $login_refetch;

    #
    # check the retrieve -reuse option
    #

    is(
	exception {$login_refetch = Elive::Entity::User->retrieve($login->userId, reuse => 1)} => undef,
	're-retrieve of updated object with reuse - lives');

    is(Scalar::Util::refaddr($login), Scalar::Util::refaddr($login_refetch),
       "login objects unified to cache");

    ok($login->is_changed, 'login object still showing as changed');

    isnt(
	     exception {$login_refetch = Elive::Entity::User->retrieve($login->userId, reuse => 0)} => undef,
	     're-retrieve of updated object without reuse - dies');

    my $login_raw_data;

    is(
	exception {$login_raw_data = Elive::Entity::User->retrieve($login->userId, raw => 1)} => undef,
	     'retrieval of raw data - lives');

    ok(!Scalar::Util::blessed($login_raw_data), 'raw retrieval returns unblessed data');
    
    is($login_raw_data->{loginName}, $loginName_old,
       'raw retrieval bypasses cache');

    is($login->loginName, $loginName_new, 'changes held in cache');

    $login->revert;

    is($login->loginName, $loginName_old, 'revert of login user');

    #
    # check refetch, both on object and primary key
    #
    my $user_id = $login->userId;
    my $user_refetched;

    is( exception {$user_refetched = Elive::Entity::User->retrieve($login)} => undef, 'refetch by object - lives');
    isa_ok($user_refetched,'Elive::Entity::User', 'user refetched by object');
    is($user_refetched->userId, $user_id, "user refetch by object, as expected");

    is( exception {$user_refetched = Elive::Entity::User->retrieve($user_id)} => undef, 'refetch by id - lives');
    isa_ok($user_refetched,'Elive::Entity::User', 'user refetched by primary key');
    is($user_refetched->userId, $user_id, "user refetch by id, as expected");
}

Elive->disconnect;