DBD-SQLeet

 view release on metacpan or  search on metacpan

t/rt_25924_user_defined_func_unicode.t  view on Meta::CPAN

#!/usr/bin/perl

use strict;

BEGIN {
  $|  = 1;
  $^W = 1;
}

use lib "t/lib";
use SQLeetTest qw/connect_ok @CALL_FUNCS/;
use Test::More;

BEGIN {
  if ( $] >= 5.008005 ) {
    plan( tests => 15 * @CALL_FUNCS + 1);
  } else {
    plan( skip_all => 'Unicode is not supported before 5.8.5' );
  }
}

use Test::NoWarnings;

foreach my $call_func (@CALL_FUNCS) {
  my $dbh = connect_ok( sqlite_unicode => 1 );
  ok($dbh->$call_func( "perl_uc", 1, \&perl_uc, "create_function" ));

  ok( $dbh->do(<<'END_SQL'), 'CREATE TABLE' );
CREATE TABLE foo (
  bar varchar(255)
)
END_SQL

  my @words = qw{Berg�re h�te h�ta�re h�tre};
  foreach my $word (@words) {
    # rt48048: don't need to "use utf8" nor "require utf8"
    utf8::upgrade($word);
    ok( $dbh->do("INSERT INTO foo VALUES ( ? )", {}, $word), 'INSERT' );
    my $foo = $dbh->selectall_arrayref("SELECT perl_uc(bar) FROM foo");
    is_deeply( $foo, [ [ perl_uc($word) ] ], 'unicode upcase ok' );
    ok( $dbh->do("DELETE FROM foo"), 'DELETE ok' );
  }
  $dbh->disconnect;
}

sub perl_uc {
  my $string = shift;
  return uc($string);
}



( run in 1.511 second using v1.01-cache-2.11-cpan-39bf76dae61 )