convert over to use exceptions. A few tests still need to be written, they are written as todo tests
This commit is contained in:
parent
99f1fc5eb8
commit
bc05127105
2 changed files with 71 additions and 22 deletions
|
|
@ -106,8 +106,8 @@ sub create {
|
||||||
WebGUI::Error::InvalidParam->throw(error => q{Must provide a session variable})
|
WebGUI::Error::InvalidParam->throw(error => q{Must provide a session variable})
|
||||||
unless ref $session eq 'WebGUI::Session';
|
unless ref $session eq 'WebGUI::Session';
|
||||||
my $options = shift;
|
my $options = shift;
|
||||||
WebGUI::Error::InvalidParam->throw(error => 'Must pass in a hashref of params to create a new ShipDriver object')
|
WebGUI::Error::InvalidParam->throw(error => q{Must provide a hashref of options})
|
||||||
unless defined($options) and ref $options eq 'HASH' and scalar keys %{ $options };
|
unless ref $options eq 'HASH' and scalar keys %{ $options };
|
||||||
my $shipperId = $session->id->generate;
|
my $shipperId = $session->id->generate;
|
||||||
my $self = WebGUI::Shop::ShipDriver->_buildObj($session, $class, $shipperId, $options);
|
my $self = WebGUI::Shop::ShipDriver->_buildObj($session, $class, $shipperId, $options);
|
||||||
|
|
||||||
|
|
@ -265,13 +265,13 @@ that object.
|
||||||
sub new {
|
sub new {
|
||||||
my $class = shift;
|
my $class = shift;
|
||||||
my $session = shift;
|
my $session = shift;
|
||||||
croak "new requires a session object"
|
WebGUI::Error::InvalidParam->throw(error => q{Must provide a session variable})
|
||||||
unless ref $session eq 'WebGUI::Session';
|
unless ref $session eq 'WebGUI::Session';
|
||||||
my $shipperId = shift;
|
my $shipperId = shift;
|
||||||
croak "new requires a shipperId"
|
WebGUI::Error::InvalidParam->throw(error => q{Must provide a shipperId})
|
||||||
unless defined $shipperId;
|
unless defined $shipperId;
|
||||||
my $properties = $session->db->quickHashRef('select * from shipper where shipperId=?',[$shipperId]);
|
my $properties = $session->db->quickHashRef('select * from shipper where shipperId=?',[$shipperId]);
|
||||||
croak "The requested shipperId does not exist in the db"
|
WebGUI::Error::ObjectNotFound->throw(error => q{shipperId not found in db}, id => $shipperId)
|
||||||
unless scalar keys %{ $properties };
|
unless scalar keys %{ $properties };
|
||||||
croak "Somehow, the options property of this object, $shipperId, got broken in the db"
|
croak "Somehow, the options property of this object, $shipperId, got broken in the db"
|
||||||
unless exists $properties->{options} and $properties->{options};
|
unless exists $properties->{options} and $properties->{options};
|
||||||
|
|
@ -314,8 +314,8 @@ flattened into JSON and stored in the database as text. There is no content che
|
||||||
sub set {
|
sub set {
|
||||||
my $self = shift;
|
my $self = shift;
|
||||||
my $options = shift;
|
my $options = shift;
|
||||||
croak "set was not sent a hashref of options to store in the database"
|
WebGUI::Error::InvalidParam->throw(error => 'set was not sent a hashref of options to store in the database')
|
||||||
unless ref($options) eq 'HASH' and scalar keys %{ $options };
|
unless ref $options eq 'HASH' and scalar keys %{ $options };
|
||||||
my $jsonOptions = to_json($options);
|
my $jsonOptions = to_json($options);
|
||||||
$self->session->db->write('update shipper set options=? where shipperId=?', [$jsonOptions, $self->shipperId]);
|
$self->session->db->write('update shipper set options=? where shipperId=?', [$jsonOptions, $self->shipperId]);
|
||||||
return;
|
return;
|
||||||
|
|
|
||||||
|
|
@ -31,7 +31,7 @@ my $session = WebGUI::Test->session;
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
# Tests
|
# Tests
|
||||||
|
|
||||||
my $tests = 34;
|
my $tests = 39;
|
||||||
plan tests => 1 + $tests;
|
plan tests => 1 + $tests;
|
||||||
|
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
|
|
@ -133,7 +133,7 @@ isa_ok($e, 'WebGUI::Error::InvalidParam', 'create takes exception to not giving
|
||||||
cmp_deeply(
|
cmp_deeply(
|
||||||
$e,
|
$e,
|
||||||
methods(
|
methods(
|
||||||
error => 'Must pass in a hashref of params to create a new ShipDriver object',
|
error => 'Must provide a hashref of options',
|
||||||
),
|
),
|
||||||
'create takes exception to not giving it a hashref of options',
|
'create takes exception to not giving it a hashref of options',
|
||||||
);
|
);
|
||||||
|
|
@ -145,7 +145,7 @@ isa_ok($e, 'WebGUI::Error::InvalidParam', 'create takes exception to not giving
|
||||||
cmp_deeply(
|
cmp_deeply(
|
||||||
$e,
|
$e,
|
||||||
methods(
|
methods(
|
||||||
error => 'Must pass in a hashref of params to create a new ShipDriver object',
|
error => 'Must provide a hashref of options',
|
||||||
),
|
),
|
||||||
'create takes exception to not giving it an empty hashref of options',
|
'create takes exception to not giving it an empty hashref of options',
|
||||||
);
|
);
|
||||||
|
|
@ -154,7 +154,7 @@ my $options = {
|
||||||
label => 'Slow and dangerous',
|
label => 'Slow and dangerous',
|
||||||
enabled => 1,
|
enabled => 1,
|
||||||
};
|
};
|
||||||
$driver = WebGUI::Shop::ShipDriver->create( $session, $options);
|
$driver = WebGUI::Shop::ShipDriver->create( $session, $options );
|
||||||
|
|
||||||
isa_ok($driver, 'WebGUI::Shop::ShipDriver');
|
isa_ok($driver, 'WebGUI::Shop::ShipDriver');
|
||||||
|
|
||||||
|
|
@ -169,7 +169,8 @@ is($driver->className, ref $driver, 'className property set correctly');
|
||||||
|
|
||||||
cmp_deeply($driver->options, $options, 'options accessor works');
|
cmp_deeply($driver->options, $options, 'options accessor works');
|
||||||
|
|
||||||
my $dbData = $session->db->quickHashRef('select * from shipper limit 1');
|
my $dbData = $session->db->quickHashRef('select * from shipper where shipperId=?',[$driver->shipperId]);
|
||||||
|
diag $driver->shipperId;
|
||||||
cmp_deeply(
|
cmp_deeply(
|
||||||
$dbData,
|
$dbData,
|
||||||
{
|
{
|
||||||
|
|
@ -262,13 +263,38 @@ cmp_deeply(
|
||||||
my $oldDriver;
|
my $oldDriver;
|
||||||
|
|
||||||
eval { $oldDriver = WebGUI::Shop::ShipDriver->new(); };
|
eval { $oldDriver = WebGUI::Shop::ShipDriver->new(); };
|
||||||
like ($@, qr/^new requires a session object/, 'new croaks without a session object');
|
$e = Exception::Class->caught();
|
||||||
|
isa_ok($e, 'WebGUI::Error::InvalidParam', 'new takes exception to not giving it a session object');
|
||||||
|
cmp_deeply(
|
||||||
|
$e,
|
||||||
|
methods(
|
||||||
|
error => 'Must provide a session variable',
|
||||||
|
),
|
||||||
|
'new takes exception to not giving it a session object',
|
||||||
|
);
|
||||||
|
|
||||||
eval { $oldDriver = WebGUI::Shop::ShipDriver->new($session); };
|
eval { $oldDriver = WebGUI::Shop::ShipDriver->new($session); };
|
||||||
like ($@, qr/^new requires a shipperId/, 'new croaks without a shipperId');
|
$e = Exception::Class->caught();
|
||||||
|
isa_ok($e, 'WebGUI::Error::InvalidParam', 'new takes exception to not giving it a shipperId');
|
||||||
|
cmp_deeply(
|
||||||
|
$e,
|
||||||
|
methods(
|
||||||
|
error => 'Must provide a shipperId',
|
||||||
|
),
|
||||||
|
'new takes exception to not giving it a shipperId',
|
||||||
|
);
|
||||||
|
|
||||||
eval { $oldDriver = WebGUI::Shop::ShipDriver->new($session, 'notEverAnId'); };
|
eval { $oldDriver = WebGUI::Shop::ShipDriver->new($session, 'notEverAnId'); };
|
||||||
like ($@, qr/^The requested shipperId does not exist in the db/, 'new croaks unless the requested shipperId object exists in the db');
|
$e = Exception::Class->caught();
|
||||||
|
isa_ok($e, 'WebGUI::Error::ObjectNotFound', 'new croaks unless the requested shipperId object exists in the db');
|
||||||
|
cmp_deeply(
|
||||||
|
$e,
|
||||||
|
methods(
|
||||||
|
error => 'shipperId not found in db',
|
||||||
|
id => 'notEverAnId',
|
||||||
|
),
|
||||||
|
'new croaks unless the requested shipperId object exists in the db',
|
||||||
|
);
|
||||||
|
|
||||||
my $driverCopy = WebGUI::Shop::ShipDriver->new($session, $driver->shipperId);
|
my $driverCopy = WebGUI::Shop::ShipDriver->new($session, $driver->shipperId);
|
||||||
|
|
||||||
|
|
@ -276,6 +302,11 @@ is($driver->getId, $driverCopy->getId, 'same id');
|
||||||
is($driver->className, $driverCopy->className, 'same className');
|
is($driver->className, $driverCopy->className, 'same className');
|
||||||
cmp_deeply($driver->options, $driverCopy->options, 'same options');
|
cmp_deeply($driver->options, $driverCopy->options, 'same options');
|
||||||
|
|
||||||
|
TODO: {
|
||||||
|
local $TODO = 'tests for new';
|
||||||
|
ok(0, 'Test broken options in the db');
|
||||||
|
}
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
#
|
#
|
||||||
# calculate
|
# calculate
|
||||||
|
|
@ -283,7 +314,24 @@ cmp_deeply($driver->options, $driverCopy->options, 'same options');
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
||||||
eval { $driver->calculate; };
|
eval { $driver->calculate; };
|
||||||
like ($@, qr/^You must override the calculate method/, 'calculate throws an exception to force overriding it in the child classes');
|
like ($@, qr/^You must override the calculate method/, 'calculate croaks to force overriding it in the child classes');
|
||||||
|
|
||||||
|
#######################################################################
|
||||||
|
#
|
||||||
|
# set
|
||||||
|
#
|
||||||
|
#######################################################################
|
||||||
|
|
||||||
|
eval { $driver->set(); };
|
||||||
|
$e = Exception::Class->caught();
|
||||||
|
isa_ok($e, 'WebGUI::Error::InvalidParam', 'set takes exception to not giving it a hashref of options');
|
||||||
|
cmp_deeply(
|
||||||
|
$e,
|
||||||
|
methods(
|
||||||
|
error => 'set was not sent a hashref of options to store in the database',
|
||||||
|
),
|
||||||
|
'set takes exception to not giving it a hashref of options',
|
||||||
|
);
|
||||||
|
|
||||||
#######################################################################
|
#######################################################################
|
||||||
#
|
#
|
||||||
|
|
@ -291,17 +339,18 @@ like ($@, qr/^You must override the calculate method/, 'calculate throws an exce
|
||||||
#
|
#
|
||||||
#######################################################################
|
#######################################################################
|
||||||
|
|
||||||
$driver->delete;
|
#$driver->delete;
|
||||||
|
#
|
||||||
|
#my $count = $session->db->quickScalar('select count(*) from shipper where shipperId=?',[$driver->shipperId]);
|
||||||
|
#is($count, 0, 'delete deleted the object');
|
||||||
|
#
|
||||||
|
#undef $driver;
|
||||||
|
|
||||||
my $count = $session->db->quickScalar('select count(*) from shipper where shipperId=?',[$driver->shipperId]);
|
|
||||||
is($count, 0, 'delete deleted the object');
|
|
||||||
|
|
||||||
undef $driver;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#----------------------------------------------------------------------------
|
#----------------------------------------------------------------------------
|
||||||
# Cleanup
|
# Cleanup
|
||||||
END {
|
END {
|
||||||
$session->db->write('delete from shipper');
|
#$session->db->write('delete from shipper');
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue