blob: cb53f57ed9417158d2e968116a27a074af1ee0fc (
plain)
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
46
47
48
49
50
51
52
53
|
#!perl -w
BEGIN {
if ($] < 5.006) {
print "1..0 # Skipped: your perl don't know unicode\n";
exit;
}
}
print "1..5\n";
use strict;
use Digest::MD5 qw(md5_hex);
my $str;
$str = "foo\xFF\x{100}";
eval {
print md5_hex($str);
print "not ok 1\n"; # should not run
};
print "not " unless $@ && $@ =~ /^(Big byte|Wide character)/;
print "ok 1\n";
my $exp = ord "A" == 193 ? # EBCDIC
"c307ec81deba65e9a222ca81cd8f6ccd" :
"503debffe559537231ed24f25651ec20"; # Latin 1
chop($str); # only bytes left
print "not " unless md5_hex($str) eq $exp;
print "ok 2\n";
# reference
print "not " unless md5_hex("foo\xFF") eq $exp;
print "ok 3\n";
# autopromotion
if ($] >= 5.007003) {
my $unistring = "Oslo.pm har sosialt medlemsmøte onsdag 1. April 2008, klokken 18:30. Vi treffes på Marhaba Café, Keysersgate 1.";
require Encode;
$unistring = Encode::decode_utf8($unistring);
print "not " if ( not utf8::is_utf8($unistring));
print "ok 4\n";
md5_hex($unistring, "");
print "not " if ( not utf8::is_utf8($unistring));
print "ok 5\n"
} else {
print "ok 4 # SKIP Your perl is too old to properly test unicode semantics\nok 5 # SKIP No, really\n";
}
|