1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
use strict;
use warnings;
use Test::More import => ['!pass'];
plan skip_all => "YAML or YAML::XS needed to run these tests"
unless Dancer::ModuleLoader->load('YAML::XS')
or Dancer::ModuleLoader->load('YAML');
plan skip_all => "File::Temp 0.22 required"
unless Dancer::ModuleLoader->load( 'File::Temp', '0.22' );
plan tests => 17;
use Dancer ':syntax';
use File::Spec;
use lib File::Spec->catdir( 't', 'lib' );
use TestUtils;
my $dir = File::Temp::tempdir(CLEANUP => 1, TMPDIR => 1);
set appdir => $dir;
my $envdir = File::Spec->catdir($dir, 'environments');
mkdir $envdir;
my $conffile = Dancer::Config->conffile;
ok(defined($conffile), 'default conffile is defined');
Dancer::ModuleLoader->load('YAML::XS')
and config->{engines}->{YAML}->{module} = 'YAML::XS';
ok(Dancer::Config->load, 'Config load works without conffile');
# create the conffile
my $conf = '
port: 4500
startup_info: 0
charset: "UTF8"
logger: file
';
write_file($conffile => $conf);
ok(Dancer::Config->load, 'Config load works with a conffile');
is(setting('environment'), 'development',
'setting environment looks good');
is(setting('port'), '4500',
'setting port looks good');
is(setting('startup_info'), 0,
'setting startup_info looks good');
is(setting('logger'), 'file',
'setting logger looks good');
# issue GH#153
is(setting('charset'), 'utf8',
"charset setting is normalized");
ok(defined(Dancer::Logger->logger), 'logger is defined');
my $test_env = '
log: debug
startup_info: 1
foo_test: 54
';
write_file(Dancer::Config->environment_file, $test_env);
ok(Dancer::Config->load, 'load test environment');
is(setting('log'), 'debug', 'log setting looks good');
is(setting('startup_info'), '1', 'startup_info setting looks good');
is(setting('foo_test'), '54', 'random setting set');
unlink Dancer::Config->environment_file;
my $prod_env = '
log: "warning"
startup_info: 0
foo_prod: 42
';
setting('environment' => 'prod');
write_file(Dancer::Config->environment_file, $prod_env);
ok(Dancer::Config->load, 'load prod environment');
is(setting('log'), 'warning', 'log setting looks good');
is(setting('foo_prod'), '42', 'random setting set');
is(setting('startup_info'), '0', 'startup_info setting looks good');
Dancer::Logger::logger->{fh}->close;
unlink Dancer::Config->environment_file;
unlink $conffile;
File::Temp::cleanup();
|