2009-10-10 16:21:31 +00:00
|
|
|
# -*-perl-*-
|
2009-10-10 16:11:25 +00:00
|
|
|
# testscript for Config::General Classes by Thomas Linden
|
|
|
|
|
#
|
2009-10-10 16:07:21 +00:00
|
|
|
# needs to be invoked using the command "make test" from
|
2009-10-10 16:11:25 +00:00
|
|
|
# the Config::General source directory.
|
|
|
|
|
#
|
|
|
|
|
# Under normal circumstances every test should succeed.
|
2009-10-10 16:07:21 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
|
2009-10-10 16:10:12 +00:00
|
|
|
use Data::Dumper;
|
2009-10-10 16:40:22 +00:00
|
|
|
use Test::More tests => 38;
|
2009-10-10 16:38:28 +00:00
|
|
|
#use Test::More qw(no_plan);
|
2009-10-10 16:21:31 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 1
|
|
|
|
|
BEGIN { use_ok "Config::General"};
|
|
|
|
|
require_ok( 'Config::General' );
|
2009-10-10 16:26:19 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 2 - 7
|
|
|
|
|
foreach my $num (2..7) {
|
|
|
|
|
my $cfg = "t/cfg.$num";
|
|
|
|
|
open T, "<$cfg";
|
|
|
|
|
my @file = <T>;
|
|
|
|
|
close T;
|
|
|
|
|
my $fst = $file[0];
|
|
|
|
|
chomp $fst;
|
|
|
|
|
$fst =~ s/\#\s*//g;
|
|
|
|
|
eval {
|
|
|
|
|
my $conf = new Config::General($cfg);
|
|
|
|
|
my %hash = $conf->getall;
|
|
|
|
|
};
|
|
|
|
|
ok(!$@, "$fst");
|
|
|
|
|
}
|
2009-10-10 16:21:31 +00:00
|
|
|
|
2009-10-10 16:07:21 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 8
|
2009-10-10 16:10:12 +00:00
|
|
|
my $conf = new Config::General("t/cfg.8");
|
2009-10-10 16:07:21 +00:00
|
|
|
my %hash = $conf->getall;
|
2009-10-10 16:21:31 +00:00
|
|
|
$conf->save_file("t/cfg.out");
|
2009-10-10 16:07:21 +00:00
|
|
|
my $copy = new Config::General("t/cfg.out");
|
|
|
|
|
my %copyhash = $copy->getall;
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply(\%hash, \%copyhash, "Writing Config Hash to disk and compare with original");
|
2009-10-10 16:07:21 +00:00
|
|
|
|
2009-10-10 16:11:25 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 9
|
2009-10-10 16:21:31 +00:00
|
|
|
$conf = new Config::General(
|
2009-10-10 16:38:28 +00:00
|
|
|
-ExtendedAccess => 1,
|
|
|
|
|
-ConfigFile => "t/test.rc");
|
|
|
|
|
ok($conf, "Creating a new object from config file");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 10
|
2009-10-10 16:21:31 +00:00
|
|
|
my $conf2 = new Config::General(
|
2009-10-10 16:38:28 +00:00
|
|
|
-ExtendedAccess => 1,
|
|
|
|
|
-ConfigFile => "t/test.rc",
|
|
|
|
|
-AllowMultiOptions => "yes"
|
|
|
|
|
);
|
|
|
|
|
ok($conf2, "Creating a new object using the hash parameter way");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 11
|
2009-10-10 16:11:25 +00:00
|
|
|
my $domain = $conf->obj("domain");
|
2009-10-10 16:38:28 +00:00
|
|
|
ok($domain, "Creating a new object from a block");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 12
|
2009-10-10 16:11:25 +00:00
|
|
|
my $addr = $domain->obj("bar.de");
|
2009-10-10 16:38:28 +00:00
|
|
|
ok($addr, "Creating a new object from a sub block");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 13
|
2009-10-10 16:11:25 +00:00
|
|
|
my @keys = $conf->keys("domain");
|
2009-10-10 16:38:28 +00:00
|
|
|
ok($#keys > -1, "Getting values from the object");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 14
|
2009-10-10 16:11:25 +00:00
|
|
|
# test various OO methods
|
2009-10-10 16:38:28 +00:00
|
|
|
my $a;
|
2009-10-10 16:11:25 +00:00
|
|
|
if ($conf->is_hash("domain")) {
|
|
|
|
|
my $domains = $conf->obj("domain");
|
|
|
|
|
foreach my $domain ($conf->keys("domain")) {
|
|
|
|
|
my $domain_obj = $domains->obj($domain);
|
|
|
|
|
foreach my $address ($domains->keys($domain)) {
|
2009-10-10 16:38:28 +00:00
|
|
|
$a = $domain_obj->value($address);
|
2009-10-10 16:11:25 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-10 16:38:28 +00:00
|
|
|
ok($a, "Using keys() and values()");
|
2009-10-10 16:21:31 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 15
|
2009-10-10 16:11:25 +00:00
|
|
|
# test AUTOLOAD methods
|
2009-10-10 16:38:28 +00:00
|
|
|
eval {
|
|
|
|
|
my $conf3 = new Config::General(
|
|
|
|
|
-ExtendedAccess => 1,
|
|
|
|
|
-ConfigHash => { name => "Moser", prename => "Hannes"}
|
|
|
|
|
);
|
|
|
|
|
my $n = $conf3->name;
|
|
|
|
|
my $p = $conf3->prename;
|
|
|
|
|
$conf3->name("Meier");
|
|
|
|
|
$conf3->prename("Max");
|
|
|
|
|
$conf3->save_file("t/test.cfg");
|
|
|
|
|
};
|
|
|
|
|
ok (!$@, "Using AUTOLOAD methods");
|
2009-10-10 16:11:25 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 16
|
2009-10-10 16:17:24 +00:00
|
|
|
# testing variable interpolation
|
2009-10-10 16:25:41 +00:00
|
|
|
my $conf16 = new Config::General(-ConfigFile => "t/cfg.16", -InterPolateVars => 1, -StrictVars => 0);
|
2009-10-10 16:17:24 +00:00
|
|
|
my %h16 = $conf16->getall();
|
2009-10-10 16:38:28 +00:00
|
|
|
if($h16{etc}->{log} eq "/usr/log/logfile" and
|
|
|
|
|
$h16{etc}->{users}->{home} eq "/usr/home/max" and
|
|
|
|
|
exists $h16{dir}->{teri}->{bl}) {
|
|
|
|
|
pass("Testing variable interpolation");
|
2009-10-10 16:17:24 +00:00
|
|
|
}
|
|
|
|
|
else {
|
2009-10-10 16:38:28 +00:00
|
|
|
fail("Testing variable interpolation");
|
2009-10-10 16:17:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 17
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
# testing value pre-setting using a hash
|
|
|
|
|
my $conf17 = new Config::General(
|
2009-10-10 16:38:28 +00:00
|
|
|
-file => "t/cfg.17",
|
|
|
|
|
-DefaultConfig => { home => "/exports/home", logs => "/var/backlog" },
|
|
|
|
|
-MergeDuplicateOptions => 1,
|
|
|
|
|
-MergeDuplicateBlocks => 1
|
|
|
|
|
);
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
my %h17 = $conf17->getall();
|
2009-10-10 16:38:28 +00:00
|
|
|
ok ($h17{home} eq "/home/users", "Testing value pre-setting using a hash");
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 18
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
# testing value pre-setting using a string
|
|
|
|
|
my $conf18 = new Config::General(
|
2009-10-10 16:38:28 +00:00
|
|
|
-file => "t/cfg.17", # reuse the file
|
|
|
|
|
-DefaultConfig => "home = /exports/home\nlogs = /var/backlog",
|
|
|
|
|
-MergeDuplicateOptions => 1,
|
|
|
|
|
-MergeDuplicateBlocks => 1
|
|
|
|
|
);
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
my %h18 = $conf18->getall();
|
2009-10-10 16:38:28 +00:00
|
|
|
ok ($h18{home} eq "/home/users", "Testing value pre-setting using a string");
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 19
|
2009-10-10 16:26:19 +00:00
|
|
|
# testing various otion/value assignment notations
|
2009-10-10 16:22:10 +00:00
|
|
|
my $conf19 = new Config::General(-file => "t/cfg.19");
|
|
|
|
|
my %h19 = $conf19->getall();
|
|
|
|
|
my $works = 1;
|
|
|
|
|
foreach my $key (keys %h19) {
|
|
|
|
|
if ($key =~ /\s/) {
|
|
|
|
|
$works = 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-10-10 16:38:28 +00:00
|
|
|
ok ($works, "Testing various otion/value assignment notations");
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 20
|
2009-10-10 16:31:34 +00:00
|
|
|
# testing files() method
|
|
|
|
|
my $conf20 = Config::General->new(
|
|
|
|
|
-file => "t/cfg.20.a",
|
|
|
|
|
-MergeDuplicateOptions => 1
|
|
|
|
|
);
|
|
|
|
|
my %h20 = $conf20->getall();
|
|
|
|
|
my %files = map { $_ => 1 } $conf20->files();
|
|
|
|
|
my %expected_files = map { $_ => 1 } (
|
|
|
|
|
't/cfg.20.a',
|
|
|
|
|
't/cfg.20.b',
|
|
|
|
|
't/cfg.20.c',
|
|
|
|
|
);
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply (\%files, \%expected_files, "testing files() method");
|
2009-10-10 16:31:34 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 22
|
2009-10-10 16:31:34 +00:00
|
|
|
# testing improved IncludeRelative option
|
|
|
|
|
# First try without -IncludeRelative
|
|
|
|
|
# this should fail
|
|
|
|
|
eval {
|
|
|
|
|
my $conf21 = Config::General->new(
|
|
|
|
|
-file => "t/sub1/sub2/sub3/cfg.sub3",
|
|
|
|
|
-MergeDuplicateOptions => 1,
|
|
|
|
|
);
|
|
|
|
|
};
|
2009-10-10 16:38:28 +00:00
|
|
|
ok ($@, "prevented from loading relative cfgs without -IncludeRelative");
|
2009-10-10 16:31:34 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
|
|
|
|
|
### 23
|
2009-10-10 16:31:34 +00:00
|
|
|
# Now try with -IncludeRelative
|
|
|
|
|
# this should fail
|
|
|
|
|
my $conf22 = Config::General->new(
|
|
|
|
|
-file => "t/sub1/sub2/sub3/cfg.sub3",
|
|
|
|
|
-MergeDuplicateOptions => 1,
|
|
|
|
|
-IncludeRelative => 1,
|
|
|
|
|
);
|
|
|
|
|
my %h22 = $conf22->getall;
|
|
|
|
|
my %expected_h22 = (
|
2009-10-10 16:36:29 +00:00
|
|
|
'sub3_seen' => 'yup',
|
|
|
|
|
'sub2_seen' => 'yup',
|
|
|
|
|
'sub2b_seen' => 'yup',
|
|
|
|
|
'sub1_seen' => 'yup',
|
|
|
|
|
'sub1b_seen' => 'yup',
|
|
|
|
|
'fruit' => 'mango',
|
2009-10-10 16:31:34 +00:00
|
|
|
);
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply(\%h22, \%expected_h22, "loaded relative to included files");
|
2009-10-10 16:31:34 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 24
|
2009-10-10 16:36:29 +00:00
|
|
|
# Testing IncludeDirectories option
|
|
|
|
|
my $conf23 = Config::General->new(
|
|
|
|
|
-String => "<<include t/sub1>>",
|
|
|
|
|
-IncludeDirectories => 1
|
|
|
|
|
);
|
|
|
|
|
my %h23 = $conf23->getall;
|
|
|
|
|
my %expected_h23 = (
|
|
|
|
|
fruit => 'mango',
|
|
|
|
|
sub1_seen => 'yup',
|
|
|
|
|
sub1b_seen => 'yup',
|
|
|
|
|
test => 'value',
|
|
|
|
|
test2 => 'value2',
|
|
|
|
|
test3 => 'value3'
|
|
|
|
|
);
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply(\%h23, \%expected_h23, "including a directory with -IncludeDirectories");
|
2009-10-10 16:36:29 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 24
|
2009-10-10 16:36:29 +00:00
|
|
|
# Testing IncludeGlob option
|
|
|
|
|
my $conf24 = Config::General->new(
|
|
|
|
|
-String => "<<include t/sub1/cfg.sub[123]{c,d,e}>>",
|
|
|
|
|
-IncludeGlob => 1
|
|
|
|
|
);
|
|
|
|
|
my %h24 = $conf24->getall;
|
|
|
|
|
my %expected_h24 = (
|
|
|
|
|
test => 'value',
|
|
|
|
|
test2 => 'value2',
|
|
|
|
|
test3 => 'value3'
|
|
|
|
|
);
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply(\%h24, \%expected_h24, "including multiple files via glob pattern with -IncludeGlob");
|
2009-10-10 16:36:29 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 25
|
2009-10-10 16:36:29 +00:00
|
|
|
# Testing block and block name quoting
|
|
|
|
|
my $conf25 = Config::General->new(
|
|
|
|
|
-String => <<TEST,
|
|
|
|
|
<block "/">
|
|
|
|
|
opt1 val1
|
|
|
|
|
</block>
|
|
|
|
|
<"block2 /">
|
|
|
|
|
opt2 val2
|
|
|
|
|
</"block2 /">
|
|
|
|
|
<"block 3" "/">
|
|
|
|
|
opt3 val3
|
|
|
|
|
</"block 3">
|
|
|
|
|
<block4 />
|
|
|
|
|
opt4 val4
|
|
|
|
|
</block4>
|
|
|
|
|
TEST
|
|
|
|
|
-SlashIsDirectory => 1
|
|
|
|
|
);
|
|
|
|
|
my %h25 = $conf25->getall;
|
|
|
|
|
my %expected_h25 = (
|
|
|
|
|
block => { '/' => { opt1 => 'val1' } },
|
|
|
|
|
'block2 /' => { opt2 => 'val2' },
|
|
|
|
|
'block 3' => { '/' => { opt3 => 'val3' } },
|
|
|
|
|
block4 => { '/' => { opt4 => 'val4' } }
|
|
|
|
|
);
|
2009-10-10 16:38:28 +00:00
|
|
|
is_deeply(\%h25, \%expected_h25, "block and block name quoting");
|
2009-10-10 16:36:29 +00:00
|
|
|
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 26
|
|
|
|
|
# Testing 0-value handling
|
|
|
|
|
my $conf26 = Config::General->new(
|
|
|
|
|
-String => <<TEST,
|
|
|
|
|
<foo 0>
|
|
|
|
|
0
|
|
|
|
|
</foo>
|
|
|
|
|
TEST
|
|
|
|
|
);
|
|
|
|
|
my %h26 = $conf26->getall;
|
|
|
|
|
my %expected_h26 = (
|
|
|
|
|
foo => { 0 => { 0 => '' } },
|
|
|
|
|
);
|
|
|
|
|
is_deeply(\%h26, \%expected_h26, "testing 0-values in block names");
|
2009-10-10 16:31:34 +00:00
|
|
|
|
|
|
|
|
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
#
|
|
|
|
|
# look if invalid input gets rejected right
|
|
|
|
|
#
|
1.36 - simplified new() parameter parsing, should be now a little
bit better to understand.
- added new parameter -DefaultConfig, which can hold a hashref
or a string, which will be used to pre-define values
of the resulting hash after parsing a config.
Thanks to Mark Hampton <mark.hampton@qualis.com> for the
suggestion.
- added new parameter -MergeDuplicateOptions, which allows
one to overwrite duplicate options, which is required,
if you turn on -DefaultConfig, because otherwise a
array would be created, which is probably not what you
wanted.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::keys(), which allows to
retrieve the keys of the object itself (which was not
directly possible before)
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::Extended::value(), which allows to
set a value to a (perlish-) nontrue value. This was a
bug.
- added patch by Danial Pearce <danial@infoxchange.net.au>
to Config::General::_parse_value, which fixes a bug in
this method, which in prior versions caused values of
"0" (zero digit) to be wiped out of the config.
- added tests in t/run.t for the new default config feature.
git-svn-id: http://dev.catalyst.perl.org/repos/Config-General/trunk@25 be1acefe-a474-0410-9a34-9b3221f2030f
2009-10-10 16:19:00 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
### 27
|
|
|
|
|
# testing invalid parameter calls, expected to fail
|
|
|
|
|
my @pt = (
|
|
|
|
|
{
|
|
|
|
|
p => {-ConfigHash => "StringNotHash"},
|
|
|
|
|
t => "-ConfigHash HASH required"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
p => {-String => {}},
|
|
|
|
|
t => "-String STRING required"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
p => {-ConfigFile => {}},
|
|
|
|
|
t => "-ConfigFile STRING required"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
p => {-ConfigFile => "NoFile"},
|
|
|
|
|
t => "-ConfigFile STRING File must exist and be readable"
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
foreach my $C (@pt) {
|
|
|
|
|
eval {
|
|
|
|
|
my $cfg = new Config::General(%{$C->{p}});
|
|
|
|
|
};
|
|
|
|
|
ok ($@, "check parameter failure handling $C->{t}");
|
2009-10-10 16:07:21 +00:00
|
|
|
}
|
|
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
### 32
|
|
|
|
|
# check Flagbits
|
|
|
|
|
my $cfg28 = new Config::General(
|
|
|
|
|
-String => "Mode = CLEAR | UNSECURE",
|
|
|
|
|
-FlagBits => {
|
|
|
|
|
Mode => {
|
|
|
|
|
CLEAR => 1,
|
|
|
|
|
STRONG => 1,
|
|
|
|
|
UNSECURE => "32bit"
|
2009-10-10 16:07:21 +00:00
|
|
|
}
|
2009-10-10 16:38:28 +00:00
|
|
|
} );
|
|
|
|
|
my %cfg28 = $cfg28->getall();
|
|
|
|
|
is_deeply(\%cfg28,
|
|
|
|
|
{
|
|
|
|
|
'Mode' => {
|
|
|
|
|
'STRONG' => undef,
|
|
|
|
|
'UNSECURE' => '32bit',
|
|
|
|
|
'CLEAR' => 1
|
|
|
|
|
}}, "Checking -Flagbits resolving");
|
2009-10-10 16:26:19 +00:00
|
|
|
|
2009-10-10 16:38:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
### 33
|
|
|
|
|
# checking functional interface
|
|
|
|
|
eval {
|
|
|
|
|
my %conf = Config::General::ParseConfig(-ConfigFile => "t/test.rc");
|
|
|
|
|
Config::General::SaveConfig("t/test.rc.out", \%conf);
|
|
|
|
|
my %next = Config::General::ParseConfig(-ConfigFile => "t/test.rc.out");
|
|
|
|
|
my @a = sort keys %conf;
|
|
|
|
|
my @b = sort keys %next;
|
|
|
|
|
if (@a != @b) {
|
|
|
|
|
die "Re-parsed result differs from original";
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
ok(! $@, "Testing functional interface $@");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 34
|
|
|
|
|
# testing -AutoTrue
|
|
|
|
|
my $cfg34 = new Config::General(-AutoTrue => 1, -ConfigFile => "t/cfg.34");
|
|
|
|
|
my %cfg34 = $cfg34->getall();
|
|
|
|
|
my %expect34 = (
|
|
|
|
|
'a' => {
|
|
|
|
|
'var6' => 0,
|
|
|
|
|
'var3' => 1,
|
|
|
|
|
'var1' => 1,
|
|
|
|
|
'var4' => 0,
|
|
|
|
|
'var2' => 1,
|
|
|
|
|
'var5' => 0
|
|
|
|
|
},
|
|
|
|
|
'b' => {
|
|
|
|
|
'var6' => 0,
|
|
|
|
|
'var3' => 1,
|
|
|
|
|
'var1' => 1,
|
|
|
|
|
'var4' => 0,
|
|
|
|
|
'var2' => 1,
|
|
|
|
|
'var5' => 0
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
is_deeply(\%cfg34, \%expect34, "Using -AutoTrue");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### 35
|
|
|
|
|
# testing -SplitPolicy
|
|
|
|
|
my %conf35 = Config::General::ParseConfig(
|
|
|
|
|
-String =>
|
|
|
|
|
qq(var1 :: alpha
|
|
|
|
|
var2 :: beta
|
|
|
|
|
var3 = gamma # use wrong delimiter by purpose),
|
|
|
|
|
-SplitPolicy => 'custom',
|
|
|
|
|
-SplitDelimiter => '\s*::\s*'
|
|
|
|
|
);
|
|
|
|
|
my %expect35 = (
|
|
|
|
|
'var3 = gamma' => '',
|
|
|
|
|
'var1' => 'alpha',
|
|
|
|
|
'var2' => 'beta'
|
|
|
|
|
);
|
|
|
|
|
is_deeply(\%conf35, \%expect35, "Using -SplitPolicy and custom -SplitDelimiter");
|
2009-10-10 16:40:22 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### Include both
|
|
|
|
|
my $conf36 = Config::General->new( -ConfigFile => "t/dual-include.conf",
|
|
|
|
|
-IncludeAgain => 1 );
|
|
|
|
|
my %C36 = $conf36->getall;
|
|
|
|
|
is_deeply( \%C36, { bit => { one => { honk=>'bonk' },
|
|
|
|
|
two => { honk=>'bonk' }
|
|
|
|
|
} }, "Included twice" );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### Include once
|
|
|
|
|
diag "\nPlease ignore the following message about IncludeAgain";
|
|
|
|
|
my $conf37 = Config::General->new( "t/dual-include.conf" );
|
|
|
|
|
my %C37 = $conf37->getall;
|
|
|
|
|
is_deeply( \%C37, { bit => { one => { honk=>'bonk' },
|
|
|
|
|
two => {}
|
|
|
|
|
} }, "Included once-only" );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### apache-style Include
|
|
|
|
|
my $conf38 = Config::General->new( -ConfigFile => "t/apache-include.conf",
|
|
|
|
|
-IncludeAgain => 1,
|
|
|
|
|
-UseApacheInclude => 1 );
|
|
|
|
|
my %C38 = $conf38->getall;
|
|
|
|
|
is_deeply( \%C38, { bit => { one => { honk=>'bonk' },
|
|
|
|
|
two => { honk=>'bonk' }
|
|
|
|
|
} }, "Apache-style include" );
|