File: 56_unicode.t

package info (click to toggle)
libdbm-deep-perl 2.0008-1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 884 kB
  • sloc: perl: 7,383; sql: 36
file content (43 lines) | stat: -rw-r--r-- 1,138 bytes parent folder | download | duplicates (3)
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
use strict;
use warnings FATAL => 'all';

use Test::More;
use t::common qw( new_dbm );
use utf8;

use DBM::Deep;

my $dbm_factory = new_dbm();
while ( my $dbm_maker = $dbm_factory->() ) {
    my $db = $dbm_maker->();

    SKIP: {
       skip "This engine does not support Unicode", 1
         unless $db->supports( 'unicode' );

       my $quote
        = 'Ἐγένετο δὲ λόγῳ μὲν δημοκρατία, λόγῳ δὲ τοῦ πρώτου ἀνδρὸς ἀρχή.'
          .' —Θουκυδίδης';

       $db->{'тэкст'} = $quote;
       is join("-", keys %$db), 'тэкст', 'Unicode keys';
       is $db->{'тэкст'}, $quote, 'Unicode values';

       {
            no warnings 'utf8';
            # extra stress test
            $db->{"\x{d800}"} = "\x{dc00}";
            is join("-", sort keys %$db), "тэкст-\x{d800}",
               'Surrogate keys';
            is $db->{"\x{d800}"}, "\x{dc00}", 'Surrogate values';
       }

       $db->{feen} = "plare\xff";
       $db->{feen} = 'płare';
       is $db->{feen}, 'płare', 'values can be upgraded to Unicode';

    }

}

done_testing;