X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Finflate%2Fserialize.t;h=87fb7ce7828663b1a2dbe15b05d000be8d3f0d59;hb=68de943862f06cabd397d2e74d12cd9cdc999779;hp=15647985bdb67f25e84a042024fcbb34241a42a2;hpb=c9372242657c1b20e0558ff00891a4717ecab6de;p=dbsrgits%2FDBIx-Class.git diff --git a/t/inflate/serialize.t b/t/inflate/serialize.t index 1564798..87fb7ce 100644 --- a/t/inflate/serialize.t +++ b/t/inflate/serialize.t @@ -1,5 +1,5 @@ use strict; -use warnings; +use warnings; use Test::More; use lib qw(t/lib); @@ -7,8 +7,6 @@ use DBICTest; my $schema = DBICTest->init_schema(); -use Data::Dumper; - my @serializers = ( { module => 'YAML.pm', inflater => sub { YAML::Load (shift) }, @@ -71,10 +69,17 @@ is_deeply($inflated, $struct_hash, 'inflated hash matches original'); $object = $rs->create( { serialized => '', } ); -eval { $object->set_inflated_column('serialized', $struct_hash) }; -ok(!$@, 'set_inflated_column to a hashref'); +$object->set_inflated_column('serialized', $struct_hash); is_deeply($object->serialized, $struct_hash, 'inflated hash matches original'); +$object = $rs->new({}); +$object->serialized ($struct_hash); +$object->insert; +is_deeply ( + $rs->find ({id => $object->id})->serialized, + $struct_hash, + 'new/insert works', +); #====== testing arrayref serialization @@ -82,8 +87,16 @@ ok($object->update( { serialized => $struct_array } ), 'arrayref deflation'); ok($inflated = $object->serialized, 'arrayref inflation'); is_deeply($inflated, $struct_array, 'inflated array matches original'); +$object = $rs->new({}); +$object->serialized ($struct_array); +$object->insert; +is_deeply ( + $rs->find ({id => $object->id})->serialized, + $struct_array, + 'new/insert works', +); -#===== make sure make_column_dirty ineracts reasonably with inflation +#===== make sure make_column_dirty interacts reasonably with inflation $object = $rs->first; $object->update ({serialized => { x => 'y'}});