X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Finflate%2Fserialize.t;h=30d63ec37f00a2bc5096d6cbc8d63fc91069852f;hb=704a0f8ec36f8bd8e273f5ddb553b2f67ea83f06;hp=15647985bdb67f25e84a042024fcbb34241a42a2;hpb=c9372242657c1b20e0558ff00891a4717ecab6de;p=dbsrgits%2FDBIx-Class.git diff --git a/t/inflate/serialize.t b/t/inflate/serialize.t index 1564798..30d63ec 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) }, @@ -61,20 +59,27 @@ my $inflated; #======= testing hashref serialization -my $object = $rs->create( { +my $object = $rs->create( { serialized => '', } ); ok($object->update( { serialized => $struct_hash } ), 'hashref deflation'); ok($inflated = $object->serialized, 'hashref inflation'); is_deeply($inflated, $struct_hash, 'inflated hash matches original'); -$object = $rs->create( { +$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'}});