The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use ExtUtils::testlib;
use Test::More;
use Test::Memory::Cycle;
use Config::Model;
use Pod::Simple;

use warnings;
no warnings qw(once);
use 5.10.1;

use strict;
use lib "t/lib";

my $arg = shift || '';
my $trace = $arg =~ /t/ ? 1 : 0;
Config::Model::Exception::Any->Trace(1) if $arg =~ /e/;

use Log::Log4perl qw(:easy);
Log::Log4perl->easy_init( $arg =~ /l/ ? $TRACE : $WARN );

my $model = Config::Model->new( legacy => 'ignore', );

ok( 1, "compiled" );

$model->load( 'Master', 'Config/Model/models/Master.pl' );
ok( 1, "big_model loaded" );

$model->augment_config_class(
    name => "Master",
    element => [
        'big_string' => {
            type => 'leaf',
            value_type => 'string',
            default => "A very\nlong\n\n\ndefault\nvalue\n"
        }
    ]
);

my $res = $model->get_model_doc('Master');
is_deeply(
    [ sort keys %$res ],
    [ map { "Config::Model::models::$_" } qw/Master SlaveY SlaveZ SubSlave SubSlave2/ ],
    "check doc classes"
);
like(
    $res->{'Config::Model::models::Master'},
    qr/Configuration class Master/,
    "check that doc is generated"
);

foreach my $class (sort keys %$res) {
    my $pod = $res->{$class};

    my $parser = Pod::Simple->new();
    $parser->no_errata_section( 1 );
    $parser->complain_stderr(1);

    $parser->parse_string_document($pod);
    my $res = $parser->any_errata_seen();

    say "Bad pod:\n++++++++++++\n$pod\n+++++++++++++" if $res;

    is($res, 0, "check generated pod error for class $class");
}


memory_cycle_ok($model, "memory cycles");

done_testing();