X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=t%2Fcontrollers%2Fhelpers%2Fparse_filter.t;h=9d003c0453e55552f0a1d92e49c147e98ea8f303;hb=d26b7d6cdc2f6dea9d943f00fd005667effe5cc2;hp=84547e05b603655da0fc6ead6a1c5eb042ba3e03;hpb=a5fe0a32e0e9c68db14c0bb7b34cb80b4a79a311;p=kivitendo-erp.git diff --git a/t/controllers/helpers/parse_filter.t b/t/controllers/helpers/parse_filter.t index 84547e05b..9d003c045 100644 --- a/t/controllers/helpers/parse_filter.t +++ b/t/controllers/helpers/parse_filter.t @@ -1,6 +1,6 @@ use lib 't'; -use Test::More tests => 13; +use Test::More tests => 18; use Test::Deep; use Data::Dumper; @@ -12,14 +12,19 @@ undef *::any; # Test::Deep exports any (for junctions) and MoreCommon exports an Support::TestSetup::login(); my ($filter, $expected); -sub test ($$$) { - my $got = { parse_filter($_[0]) }; +sub test ($$$;%) { + my ($filter, $expect, $msg, %params) = @_; + my $target = delete $params{target}; + my $args = { parse_filter($filter, %params) }; + my $got = $args; $target ||= ''; + $got = $filter if $target =~ /filter/; + $got = $params{launder_to} if $target =~ /launder/; cmp_deeply( $got, - $_[1], - $_[2] + $expect, + $msg, ) or do { - print STDERR "expected => ", Dumper($_[1]), "\ngot: => ", Dumper($got), $/; + print STDERR "expected => ", Dumper($expect), "\ngot: => ", Dumper($got), $/; } } @@ -53,7 +58,7 @@ test { } }, { query => [ 'customer.chart.accno' => 'test' ], - with_objects => bag( 'customer', 'chart' ), + with_objects => bag( 'customer', 'customer.chart' ), }, 'nested joins'; test { @@ -77,7 +82,7 @@ test { }, { query => [ 'customer.chart.accno' => { like => '%1200' } ], - with_objects => bag('customer', 'chart' ), + with_objects => bag('customer', 'customer.chart' ), }, 'all together'; @@ -95,7 +100,7 @@ test { 'invoice.customer.name' => 'test', 'customer.name' => 'test', }} ], - 'with_objects' => bag( 'invoice', 'customer' ) + 'with_objects' => bag( 'invoice.customer', 'customer', 'invoice' ) }, 'object in more than one relationship'; test { @@ -126,3 +131,62 @@ test { ], }, 'arrays with filter'; + +########### laundering + +test { + 'sellprice:number' => [ + '123,4', '2,34', '0,4', + ] +}, { + 'sellprice:number' => [ '123,4', '2,34', '0,4' ], + 'sellprice_number' => [ '123,4', '2,34', '0,4' ], +}, 'laundering with array', target => 'filter'; + +my %args = ( + 'sellprice:number' => [ + '123,4', '2,34', '0,4', + ], +); +test { + %args, +}, { + %args +}, 'laundering into launder does not alter filter', target => 'filter', launder_to => {}; + + +test { + part => { + 'sellprice:number' => '123,4', + } +}, { + part => { + 'sellprice:number' => '123,4', + 'sellprice_number' => '123,4' + } +}, 'deep laundering', target => 'filter'; + + +test { + part => { + 'sellprice:number' => '123,4', + } +}, { + part => { + 'sellprice_number' => '123,4' + } +}, 'deep laundering, check for laundered hash', target => 'launder', launder_to => { }; + +### bug: sub objects + +test { + order => { + customer => { + 'name:substr::ilike' => 'test', + } + } +}, { + query => [ 'order.customer.name' => { ilike => '%test%' } ], + with_objects => bag('order.customer', 'order'), +}, 'sub objects have to retain their prefix'; +