1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
|
use strict;
use warnings;
use Test::More;
use lib qw(t/lib);
use DBICTest;
my $schema = DBICTest->init_schema();
if ($] <= 5.008000) {
eval 'use Encode; 1' or plan skip_all => 'Need Encode run this test';
} else {
eval 'use utf8; 1' or plan skip_all => 'Need utf8 run this test';
}
plan tests => 3;
DBICTest::Schema::CD->load_components('UTF8Columns');
DBICTest::Schema::CD->utf8_columns('title');
Class::C3->reinitialize();
my $cd = $schema->resultset('CD')->create( { artist => 1, title => 'øni', year => 'foo' } );
my $utf8_char = 'uniuni';
if ($] <= 5.008000) {
ok( Encode::is_utf8( $cd->title ), 'got title with utf8 flag' );
ok( !Encode::is_utf8( $cd->year ), 'got year without utf8 flag' );
Encode::_utf8_on($utf8_char);
$cd->title($utf8_char);
ok( !Encode::is_utf8( $cd->{_column_data}{title} ), 'store utf8-less chars' );
} else {
ok( utf8::is_utf8( $cd->title ), 'got title with utf8 flag' );
ok( !utf8::is_utf8( $cd->year ), 'got year without utf8 flag' );
utf8::decode($utf8_char);
$cd->title($utf8_char);
ok( !utf8::is_utf8( $cd->{_column_data}{title} ), 'store utf8-less chars' );
}
|