# -*- cperl -*-
use ExtUtils::testlib;
use Test::More tests => 8;
use Test::Memory::Cycle;
use Config::Model;
use Log::Log4perl qw(:easy);
use File::Path;
use warnings;
no warnings qw(once);
use strict;
# pseudo root where config files are written by config-model
my $wr_root = 'wr_root';
# cleanup before tests
rmtree($wr_root);
mkpath( $wr_root, { mode => 0755 } );
my $model = Config::Model->new( legacy => 'ignore', );
my $arg = shift || '';
my $trace = $arg =~ /t/ ? 1 : 0;
my $log = $arg =~ /l/ ? 1 : 0;
Config::Model::Exception::Any->Trace(1) if $arg =~ /e/;
my $home = $ENV{HOME} || "";
my $log4perl_user_conf_file = "$home/.log4config-model";
if ( $log and -e $log4perl_user_conf_file ) {
Log::Log4perl::init($log4perl_user_conf_file);
}
else {
Log::Log4perl->easy_init( $arg =~ /l/ ? $DEBUG : $WARN );
}
ok( 1, "compiled" );
my $inst = $model->instance(
root_class_name => 'Master',
model_file => 't/big_model.pm',
instance_name => 'test1'
);
ok( $inst, "created dummy instance" );
$model->generate_doc('Master') if $trace;
$model->generate_doc( 'Master', $wr_root );
map { ok( -r "wr_root/Config/Model/models/$_", "Found doc $_" ); }
qw /Master.pod SlaveY.pod SlaveZ.pod SubSlave2.pod SubSlave.pod/;
memory_cycle_ok($model);