+++ /dev/null
-use strict;
-use warnings;
-
-use Test::More;
-use lib qw(t/lib);
-use DBIC::SqlMakerTest;
-
-use_ok('DBICTest');
-
-my $schema = DBICTest->init_schema;
-
-my $where_bind = {
- where => \'name like ?',
- bind => [ 'Cat%' ],
-};
-
-my $rs;
-
-TODO: {
- local $TODO = 'bind args order needs fixing (semifor)';
-
- # First, the simple cases...
- $rs = $schema->resultset('Artist')->search(
- { artistid => 1 },
- $where_bind,
- );
-
- is ( $rs->count, 1, 'where/bind combined' );
-
- $rs= $schema->resultset('Artist')->search({}, $where_bind)
- ->search({ artistid => 1});
-
- is ( $rs->count, 1, 'where/bind first' );
-
- $rs = $schema->resultset('Artist')->search({ artistid => 1})
- ->search({}, $where_bind);
-
- is ( $rs->count, 1, 'where/bind last' );
-}
-
-{
- # More complex cases, based primarily on the Cookbook
- # "Arbitrary SQL through a custom ResultSource" technique,
- # which seems to be the only place the bind attribute is
- # documented. Breaking this technique probably breaks existing
- # application code.
- my $source = DBICTest::Artist->result_source_instance;
- my $new_source = $source->new($source);
- $new_source->source_name('Complex');
-
- $new_source->name(\<<'');
- ( SELECT a.*, cd.cdid AS cdid, cd.title AS title, cd.year AS year
- FROM artist a
- JOIN cd ON cd.artist = a.artistid
- WHERE cd.year = ?)
-
- $schema->register_extra_source('Complex' => $new_source);
-
- $rs = $schema->resultset('Complex')->search({}, { bind => [ 1999 ] });
- is ( $rs->count, 1, 'cookbook arbitrary sql example' );
-
- $rs = $schema->resultset('Complex')->search({ 'artistid' => 1 }, { bind => [ 1999 ] });
- is ( $rs->count, 1, '...cookbook + search condition' );
-
- $rs = $schema->resultset('Complex')->search({}, { bind => [ 1999 ] })
- ->search({ 'artistid' => 1 });
- is ( $rs->count, 1, '...cookbook (bind first) + chained search' );
-
- $rs = $schema->resultset('Complex')->search({}, { bind => [ 1999 ] })->search({}, { where => \"title LIKE ?", bind => [ 'Spoon%' ] });
- is_same_sql_bind(
- $rs->as_query,
- "(SELECT me.artistid, me.name, me.rank, me.charfield FROM (SELECT a.*, cd.cdid AS cdid, cd.title AS title, cd.year AS year FROM artist a JOIN cd ON cd.artist = a.artistid WHERE cd.year = ?) me WHERE title LIKE ?)",
- [
- [ '!!dummy' => '1999' ],
- [ '!!dummy' => 'Spoon%' ]
- ],
- 'got correct SQL'
- );
-}
-
-{
- # More complex cases, based primarily on the Cookbook
- # "Arbitrary SQL through a custom ResultSource" technique,
- # which seems to be the only place the bind attribute is
- # documented. Breaking this technique probably breaks existing
- # application code.
-
- $rs = $schema->resultset('CustomSql')->search({}, { bind => [ 1999 ] });
- is ( $rs->count, 1, 'cookbook arbitrary sql example (in separate file)' );
-
- $rs = $schema->resultset('CustomSql')->search({ 'artistid' => 1 }, { bind => [ 1999 ] });
- is ( $rs->count, 1, '...cookbook (in separate file) + search condition' );
-
- $rs = $schema->resultset('CustomSql')->search({}, { bind => [ 1999 ] })
- ->search({ 'artistid' => 1 });
- is ( $rs->count, 1, '...cookbook (bind first, in separate file) + chained search' );
-
- $rs = $schema->resultset('CustomSql')->search({}, { bind => [ 1999 ] })->search({}, { where => \"title LIKE ?", bind => [ 'Spoon%' ] });
- is_same_sql_bind(
- $rs->as_query,
- "(SELECT me.artistid, me.name, me.rank, me.charfield FROM (SELECT a.*, cd.cdid AS cdid, cd.title AS title, cd.year AS year FROM artist a JOIN cd ON cd.artist = a.artistid WHERE cd.year = ?) me WHERE title LIKE ?)",
- [
- [ '!!dummy' => '1999' ],
- [ '!!dummy' => 'Spoon%' ]
- ],
- 'got correct SQL (cookbook arbitrary SQL, in separate file)'
- );
-}
-
-TODO: {
- local $TODO = 'bind args order needs fixing (semifor)';
- $rs = $schema->resultset('Complex')->search({}, { bind => [ 1999 ] })
- ->search({ 'artistid' => 1 }, {
- where => \'title like ?',
- bind => [ 'Spoon%' ] });
- is ( $rs->count, 1, '...cookbook + chained search with extra bind' );
-}
-
-done_testing;