The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#   $Id: 206-parse-classes-uindxc.t,v 1.2 2009/02/26 13:49:07 aff Exp $

use warnings;
use strict;

use Data::Dumper;
use Test::More;
use File::Spec::Functions;
use lib catdir qw ( blib lib );

plan tests => 47;

use_ok ('Parse::Dia::SQL');

my $diasql =  Parse::Dia::SQL->new( file => catfile(qw(t data TestERD.dia)), db => 'db2' );
isa_ok($diasql, q{Parse::Dia::SQL}, q{Expect a Parse::Dia::SQL object});

# TODO: Add test on return value - call wrapper
$diasql->convert();

my $classes = $diasql->get_classes_ref();

# Expect an array ref with 14 elements
isa_ok($classes, 'ARRAY');
cmp_ok(scalar(@$classes), q{==}, 14, q{Expect 14 classes});

# Hash with class/view names as keys and unique index (if any) as
# (hashref) elements
my %uindxc = (
    attributeCategory => {},
    categoryNames     => {},
    extremes          => {},
    imageAttribute    => {},
    imageCategoryList => {},
    imageInfo         => { '' => [ [ 'md5sum', 'char (32)' ] ] },
    ratings_view      => {},
    subImageInfo      => {},
    userAttribute     => {},
    userImageRating   => {},
    userInfo =>
      { '' => [ [ 'name', 'varchar (32)' ], [ 'md5sum', 'char (32)' ] ] },
    userSession   => {},
    users_view    => {},
    whorated_view => {},
);




# Check that each class has of the expected uindxc attributes
foreach my $class (@$classes) {
  isa_ok($class, 'HASH');
  ok(exists($uindxc{$class->{name}})) or
	diag($class->{name} . ' uindxc :' . Dumper($class->{uindxc}));

  # check contents
  is_deeply(
 			$class->{uindxc},
 			$uindxc{ $class->{name} },
 			q{uindxc for } . $class->{name}
 		   );

  # remove class from hash
  delete $uindxc{$class->{name}};
} 

# Expect no classes left now
cmp_ok(scalar(keys %uindxc), q{==}, 0, q{Expect 0 classes left});

__END__