The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
# -*- cperl -*-

use warnings;
use strict;
use 5.10.0;

use ExtUtils::testlib;
use Test::More;
use Test::Memory::Cycle;
use Test::Differences;
use Config::Model;
use Log::Log4perl qw(:easy);


my ( $log, $show ) = (0) x 3;

my $arg = shift || '';

my $trace = $arg =~ /t/ ? 1 : 0;
$log     = 1 if $arg =~ /l/;
$show    = 1 if $arg =~ /s/;
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, "Compilation done" );

my $model = Config::Model->new();

my @slave_classes = ('Slave0' .. 'Slave1');
my @master_elems ;
foreach my $slave_class (@slave_classes) {
    $model->create_config_class(
        name      => $slave_class,
        element => [
            [qw/X Y/] => {
                type       => 'leaf',
                value_type => 'enum',
                choice     => [qw/Av Bv Cv/]
            }
        ]
    );

    push @master_elems , $slave_class => {
        type => 'warped_node',
        level => 'hidden',
        config_class_name => $slave_class,
        warp => {
            follow => { selected => '- macro1' },
            'rules' => [
                '$selected.is_set(&element_name)' => {
                    level => 'normal'
                }
            ]
        },
    };
}

$model->create_config_class(
    name       => 'Master',

    element => [
        macro1 => {
            type       => 'check_list',
            choice     => \@slave_classes
        },
        @master_elems
    ]
);

my $inst = $model->instance(
    root_class_name => 'Master',
    instance_name   => 'test1'
);
ok( $inst, "created dummy instance" );

my $root = $inst->config_root;

ok( $root, "Created Root" );

eq_or_diff( [$root->get_element_name], ['macro1'],"all slaves are hidden");

note("setting ",$slave_classes[0]) if $trace;
my $mac = $root->fetch_element('macro1');
$mac->check($slave_classes[0]);

eq_or_diff( [$root->get_element_name], ['macro1', $slave_classes[0]],"first slave is enabled");

$mac->check($slave_classes[1]);

eq_or_diff( [$root->get_element_name], ['macro1', @slave_classes[0,1]],"2 slave is enabled");

$mac->uncheck($slave_classes[0]);

eq_or_diff( [$root->get_element_name], ['macro1', $slave_classes[1]],"second slave is enabled");

$mac->uncheck($slave_classes[1]);
eq_or_diff( [$root->get_element_name], ['macro1'],"all slaves are hidden again");

memory_cycle_ok($model);

done_testing;