#!/usr/bin/env perl
use strict;
use warnings;
use File::Basename;
use lib File::Basename::dirname(__FILE__)."/../../../lib";
use lib File::Basename::dirname(__FILE__)."/../..";
use URT;
use Test::More tests => 18;
class Game::Card {
has => [
suit => { is => 'Text', valid_values => [qw/heart diamond club spade/], },
color => { is => 'Text', valid_values => [qw/red blue green/], is_mutable => 0 },
owner => { is => 'Text', is_optional => 1 },
pips => { is => 'Number', is_optional => 0 },
],
};
for my $class (qw/Game::Card/) {
my $c1 = $class->create(suit => 'spade', color => 'red', pips => 4);
ok($c1, "created an object with a valid property");
my @i1 = $c1->__errors__;
is(scalar(@i1), 0, "no cases of invalididy")
or diag(Data::Dumper::Dumper(\@i1));
my $c2 = $class->create(suit => 'badsuit', color => 'blue', pips => 9);
ok($c2, "created an object with an invalid property");
my @i2 = $c2->__errors__;
is(scalar(@i2), 1, "one expected cases of invalididy")
or diag(Data::Dumper::Dumper(\@i2));
is($i2[0]->__display_name__,
qq(INVALID: property 'suit': The value badsuit is not in the list of valid values for suit. Valid values are: heart, diamond, club, spade),
'Error text is corect');
$c2->suit('heart');
@i2 = $c2->__errors__;
is(scalar(@i2), 0, "zero cases of invalididy after fix")
or diag(Data::Dumper::Dumper(\@i2));
my $c3 = $class->create(suit => 'spade', color => 'red');
ok($c3, 'Created color with missing required param');
my @i3 = $c3->__errors__;
is(scalar(@i3), 1, 'one expected cases of invalididy')
or diag(Data::Dumper::Dumper(\@i3));
is($i3[0]->__display_name__,
qq(INVALID: property 'pips': No value specified for required property),
'Error text is corect');
my $c4 = $class->create(suit => 'badsuit', color => 'blue');
ok($c4, 'Created object with invalid property value and missing required param');
my @i4 = sort { $a->__display_name__ cmp $b->__display_name__ }
$c4->__errors__;
is(scalar(@i4), 2, 'two expected cases of invalididy')
or diag(Data::Dumper::Dumper(\@i4));
is($i4[0]->__display_name__,
qq(INVALID: property 'pips': No value specified for required property),
'First error text is corect');
is($i4[1]->__display_name__,
qq(INVALID: property 'suit': The value badsuit is not in the list of valid values for suit. Valid values are: heart, diamond, club, spade),
'second error text is corect');
my $context = UR::Context->current;
$context->dump_error_messages(0);
$context->queue_error_messages(1);
ok(!UR::Context->commit, 'Commit fails as expected');
my @error_messages = sort {$a cmp $b } UR::Context->current->error_messages();
is(scalar(@error_messages), 3, 'commit generated 3 error messages');
is($error_messages[2], # This one prints first, but sorts 3rd
'Invalid data for save!',
'First error message is correct');
my $c3_id = $c3->id;
like($error_messages[0],
qr/Game::Card identified by $c3_id has problems on\s+INVALID: property 'pips': No value specified for required property\s+Current state:\s+\$VAR1 = bless\( {/s,
'Second error message is correct');
my $c4_id = $c4->id;
like($error_messages[1],
qr/Game::Card identified by $c4_id has problems on\s+INVALID: property 'pips': No value specified for required property\s+INVALID: property 'suit': The value badsuit is not in the list of valid values for suit. Valid values are: heart, diamond, club, spade\s+Current state:\s+\$VAR1 = bless\( {/s,
'Third error message is correct');
#my $c5 = eval { $class->create(suit => 'spade', color => 'badcolor') };
#ok(!defined($c5), "correctly refused to create an object with an invalid immutable property")
# or diag(Data::Dumper::Dumper($c5));
}