The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package SQL_OOP_CpmprehensiveTest2;
use strict;
use warnings;
use base 'Test::Class';
use Test::More;
use SQL::OOP;
use SQL::OOP::Select;
    
    __PACKAGE__->runtests;
    
    sub basic_test: Test(1) {
        
        my $expected = compress_sql(<<EXPECTED);
SELECT
    *
FROM
    table
WHERE
    "a" = ? AND "b" = ?
EXPECTED
        
        ### The following blocks are expected to generate same SQL
        {
            my $select = SQL::OOP::Select->new();
            $select->set(
                $select->ARG_FIELDS => '*',
                $select->ARG_FROM   => 'table',
                $select->ARG_WHERE  => q{"a" = ? AND "b" = ?},
            );
            
            is($select->to_string, $expected, 'All literaly');
        }
    }
    
    sub compress_sql {
        
        my $sql = shift;
        $sql =~ s/[\s\r\n]+/ /gs;
        $sql =~ s/[\s\r\n]+$//gs;
        $sql =~ s/\(\s/\(/gs;
        $sql =~ s/\s\)/\)/gs;
        return $sql;
    }