The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
use strict;
use warnings;

use SQL::Abstract::Test import => [qw/is_same_sql_bind/];
use SQL::Abstract::More;

use DBIx::DataModel -compatibility=> undef;

use constant NTESTS  => 2;
use Test::More tests => NTESTS;


DBIx::DataModel->Schema('HR') # Human Resources
->Table(Employee   => T_Employee   => qw/emp_id/);

my $sqlam = SQL::Abstract::More->new(array_datatypes => 1);

HR->singleton->sql_abstract($sqlam);

SKIP: {
  eval "use DBD::Mock 1.36; 1"
    or skip "DBD::Mock 1.36 does not seem to be installed", NTESTS;

  my $dbh = DBI->connect('DBI:Mock:', '', '', 
                         {RaiseError => 1, AutoCommit => 1});
  HR->dbh($dbh);

  sub sqlLike { # closure on $dbh
                # TODO : fix line number, should report the caller's line
    my $msg = pop @_;

    for (my $hist_index = -(@_ / 2); $hist_index < 0; $hist_index++) {
      my ($sql, $bind)  = (shift, shift);
      my $hist = $dbh->{mock_all_history}[$hist_index];

      is_same_sql_bind($hist->statement, $hist->bound_params,
                       $sql,             $bind, "$msg [$hist_index]");
    }
    $dbh->{mock_clear_history} = 1;
  }

  # update using verbatim SQL
  my $emp_id = 9876;
  my $food   = [qw/potatoes tomatoes/];
  HR->table('Employee')->update($emp_id, {food => $food});
  sqlLike("UPDATE T_Employee SET food = ? WHERE ( emp_id = ? )",
          [$food, $emp_id],
          "update array datatype");


  HR->table('Employee')->insert({emp_id => $emp_id, food => $food});
  sqlLike("INSERT INTO T_Employee(emp_id, food) VALUES (?, ?)",
          [$emp_id, $food],
          "insert array datatype");

}