########################################
# retrieve objects for testing updates
# this set (40, 41, ...) test updates that change all list fields without
# changing their sizes
########################################
use t::lib;
use strict;
use Carp;
use Test::More;
use Test::Deep;
use autodbTestObject;
use Class::AutoDB;
use putgetUtil; use Mechanics;
my($num_objects,$get_type)=@ARGV;
defined $num_objects or $num_objects=3;
defined $get_type or $get_type='get';
my $autodb=new Class::AutoDB(database=>'test'); # open database
isa_ok($autodb,'Class::AutoDB','class is Class::AutoDB - sanity check');
# %test_args, exported by putgetUtil, sets class2colls, coll2keys, label
my $test=new autodbTestObject(%test_args,labelprefix=>"$get_type:",get_type=>$get_type);
# make the objects
my @objects=
map {new Mechanics (name=>"same_size $num_objects object $_",id=>id_next(),
num_objects=>$num_objects,list_count=>2*$num_objects)} (0..$num_objects-1);
for my $i (0..$num_objects-1) {
my $object=$objects[$i];
# repeat '40' update
$object->string_list
([map {"string same_size 40 object $i element $_"} (0..(2*$num_objects)-1)]);
$object->integer_list([(40)x(2*$num_objects)]);
$object->float_list([map {40.40+(($i/100)+($_/1000))} (0..(2*$num_objects)-1)]);
$object->object_list([map {$objects[($i+$_)%$num_objects]} (0..(2*$num_objects)-1)]);
# repeat '41' update
splice(@{$object->string_list},2,2,map {"string same_size 41 object $i change $_"} (0,1));
splice(@{$object->integer_list},2,2,(41,41));
splice(@{$object->float_list},2,2,map {41.40+($_/100)} (0,1));
splice(@{$object->object_list},2,2,$object,$object);
}
# test them the usual way
my @actual_objects=$autodb->get(collection=>'Mechanics');
$test->test_get(labelprefix=>"$get_type:",
actual_objects=>\@actual_objects,correct_objects=>\@objects);
# test collection
map {ok_collection($_,'collection Mechanics: '.$_->name,'Mechanics',@{$coll2keys->{Mechanics}})}
@actual_objects;
done_testing();