},
{
+# LDNOTE 23.03.09 : modified test below, just parentheses differ
where => { foo => {-not_like => [7,8,9]},
fum => {'like' => [qw/a b/]},
nix => {'between' => [100,200] },
wix => {'in' => [qw/zz yy/]},
wux => {'not_in' => [qw/30 40/]}
},
- stmt => " WHERE ( ( ( foo NOT LIKE ? ) OR ( foo NOT LIKE ? ) OR ( foo NOT LIKE ? ) ) AND ( ( fum LIKE ? ) OR ( fum LIKE ? ) ) AND nix BETWEEN ? AND ? AND nox NOT BETWEEN ? AND ? AND wix IN ( ?, ? ) AND wux NOT IN ( ?, ? ) )",
+ stmt => " WHERE ( ( ( foo NOT LIKE ? ) OR ( foo NOT LIKE ? ) OR ( foo NOT LIKE ? ) ) AND ( ( fum LIKE ? ) OR ( fum LIKE ? ) ) AND ( nix BETWEEN ? AND ? ) AND ( nox NOT BETWEEN ? AND ? ) AND wix IN ( ?, ? ) AND wux NOT IN ( ?, ? ) )",
bind => [7,8,9,'a','b',100,200,150,160,'zz','yy','30','40'],
},
{
where => {
- id => [],
bar => {'!=' => []},
},
- stmt => " WHERE ( 1=1 AND 0=1 )",
+ stmt => " WHERE ( 1=1 )",
+ bind => [],
+ },
+
+ {
+ where => {
+ id => [],
+ },
+ stmt => " WHERE ( 0=1 )",
bind => [],
},
},
);
-# add extra modifier tests, based on 2 outcomes
-my $mod_or_and = {
- stmt => 'WHERE ( foo = ? OR bar = ? ) AND baz = ? ',
- bind => [qw/1 2 3/],
-};
-my $mod_or_or = {
- stmt => 'WHERE ( foo = ? OR bar = ? ) OR baz = ?',
- bind => [qw/1 2 3/],
-};
-my $mod_and_or = {
- stmt => 'WHERE ( foo = ? AND bar = ? ) OR baz = ?',
- bind => [qw/1 2 3/],
-};
-
-push @handle_tests, (
- # test modifiers within hashrefs
- {
- where => { -or => [
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]},
- %$mod_or_or,
- },
- {
- where => { -and => [
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]},
- %$mod_or_and,
- },
-
- # test modifiers within arrayrefs
- {
- where => [ -or => [
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]],
- %$mod_or_or,
- },
- {
- where => [ -and => [
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]],
- %$mod_or_and,
- },
-
- # test ambiguous modifiers within hashrefs (op extends to to immediate RHS only)
- {
- where => { -and => [ -or =>
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]},
- %$mod_or_and,
- },
- {
- where => { -or => [ -and =>
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]},
- %$mod_and_or,
- },
-
- # test ambiguous modifiers within arrayrefs (op extends to to immediate RHS only)
- {
- where => [ -and => [ -or =>
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]],
- %$mod_or_and,
- },
- {
- where => [ -or => [ -and =>
- [ foo => 1, bar => 2 ],
- baz => 3,
- ]],
- %$mod_and_or,
- },
-);
-
plan tests => ( @handle_tests * 2 ) + 1;
for my $case (@handle_tests) {