-use Test::More tests => 58;
+use Test::More tests => 64;
use lib 't';
use utf8;
$::myconfig{dateformat} = 'dd.mm.yyyy';
$csv = SL::Helper::Csv->new(
- file => \"Kaffee;0.12;12,2;1,5234\n",
+ file => \"Kaffee;0.12;12,2;1,5234\n", # " # make emacs happy
header => [[ 'description', 'sellprice', 'lastcost_as_number', 'listprice' ]],
profile => [{profile => { listprice => 'listprice_as_number' },
class => 'SL::DB::Part',}],
Kaffee;;0.12;1,221.52
Beer;1123245;0.12;1.5234
EOL
+# " # make emacs happy
numberformat => '1,000.00',
profile => [{class => 'SL::DB::Part'}],
);
"Kaf"fee";;0.12;1,221.52
Beer;1123245;0.12;1.5234
EOL
+# " # make emacs happy
numberformat => '1,000.00',
profile => [{class => 'SL::DB::Part'}],
);
#####
$csv = SL::Helper::Csv->new(
- file => \"Kaffee",
+ file => \"Kaffee", # " # make emacs happy
header => [[ 'description' ]],
profile => [{class => 'SL::DB::Part'}],
);
#####
$csv = SL::Helper::Csv->new(
- file => \"Description\nKaffee",
+ file => \"Description\nKaffee", # " # make emacs happy
case_insensitive_header => 1,
- profile => [ {profile => { description => 'description' }, class => 'SL::DB::Part'} ],
+ profile => [{
+ profile => { description => 'description' },
+ class => 'SL::DB::Part'
+ }],
);
$csv->parse;
is_deeply $csv->get_data, [ { description => 'Kaffee' } ], 'case insensitive header from csv works';
#####
$csv = SL::Helper::Csv->new(
- file => \"Kaffee",
+ file => \"Kaffee", # " # make emacs happy
header => [[ 'Description' ]],
- profile => [{profile => { description => 'description' }, {class => 'SL::DB::Part'}],
+ case_insensitive_header => 1,
+ profile => [{
+ profile => { description => 'description' },
+ class => 'SL::DB::Part'
+ }],
);
$csv->parse;
is_deeply $csv->get_data, [ { description => 'Kaffee' } ], 'case insensitive header as param works';
#####
$csv = SL::Helper::Csv->new(
- file => \"\x{EF}\x{BB}\x{BF}description\nKaffee",
+ file => \"\x{EF}\x{BB}\x{BF}description\nKaffee", # " # make emacs happy
profile => [{class => 'SL::DB::Part'}],
encoding => 'utf8',
);
#####
$csv = SL::Helper::Csv->new(
- file => \"Kaffee",
+ file => \"Kaffee", # " # make emacs happy
header => [[ 'Description' ]],
profile => [{class => 'SL::DB::Part'}],
);
$csv->parse;
is_deeply $csv->get_data, undef, 'case insensitive header without flag ignores';
+#####
+
+$csv = SL::Helper::Csv->new(
+ file => \"Kaffee", # " # make emacs happy
+ header => [[ 'foo' ]],
+ profile => [{
+ profile => { foo => '' },
+ class => 'SL::DB::Part',
+ }],
+);
+$csv->parse;
+
+is_deeply $csv->get_data, [ { foo => 'Kaffee' } ], 'empty path still gets parsed into data';
+ok $csv->get_objects->[0], 'empty path gets ignored in object creation';
+
+#####
+
+$csv = SL::Helper::Csv->new(
+ file => \"Kaffee", # " # make emacs happy
+ header => [[ 'foo' ]],
+ strict_profile => 1,
+ profile => [{
+ profile => { foo => '' },
+ class => 'SL::DB::Part',
+ }],
+);
+$csv->parse;
+
+is_deeply $csv->get_data, [ { foo => 'Kaffee' } ], 'empty path still gets parsed into data (strict profile)';
+ok $csv->get_objects->[0], 'empty path gets ignored in object creation (strict profile)';
+
+$csv = SL::Helper::Csv->new(
+ file => \"Phil", # " # make emacs happy
+ header => [[ 'CVAR_grOUnDHog' ]],
+ strict_profile => 1,
+ case_insensitive_header => 1,
+ profile => [{
+ profile => { cvar_Groundhog => '' },
+ class => 'SL::DB::Part',
+ }],
+
+);
+$csv->parse;
+
+is_deeply $csv->get_data, [ { cvar_Groundhog => 'Phil' } ], 'using empty path to get cvars working';
+ok $csv->get_objects->[0], '...and not destorying the objects';
+
+#####
+
+$csv = SL::Helper::Csv->new(
+ file => \"description\nKaffee", # " # make emacs happy
+);
+$csv->parse;
+is_deeply $csv->get_data, [ { description => 'Kaffee' } ], 'without profile and class works';
+
#####
$csv = SL::Helper::Csv->new(
file => \"Kaffee;1,50\nSchoke;0,89\n",
row_ident => 'C' }
],
);
-$csv->parse;
ok $csv->_check_multiplexed, 'multiplex check works on multiplexed data';
ok $csv->is_multiplexed, 'multiplexed data is recognized';
],
);
-ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data an detects missing row_ident';
+ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data and detects missing row_ident';
#####
$csv = SL::Helper::Csv->new(
row_ident => 'C' }
],
);
-$csv->parse;
-ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data an detects missing class';
+ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data and detects missing class';
#####
$csv = SL::Helper::Csv->new(
],
);
-ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data an detects missing header';
+ok !$csv->_check_multiplexed, 'multiplex check works on multiplexed data and detects missing header';
#####
],
ignore_unknown_columns => 1,
);
+
$csv->parse;
is_deeply $csv->get_data,
[ { datatype => 'P', description => 'Kaffee', listprice => '1,50' }, { datatype => 'C', name => 'Meier' } ],
);
$csv->parse;
-is_deeply $csv->get_data, [ { description => 'Kaffee' } ], 'without profile and class works';
+is scalar @{ $csv->get_objects }, 2, 'multiplex: auto header works';
+is $csv->get_objects->[0]->description, 'Kaffee', 'multiplex: auto header first object';
+is $csv->get_objects->[1]->name, 'Meier', 'multiplex: auto header second object';
######