diff options
author | Karl Williamson <khw@cpan.org> | 2015-05-18 10:47:50 -0600 |
---|---|---|
committer | Karl Williamson <khw@cpan.org> | 2015-08-25 16:58:01 -0600 |
commit | 7adaf5b2acaa653a831bb68ed91d8d205fbf9fb2 (patch) | |
tree | 2cd3de01267a765d5498661498bc0e851e7bfb8f /lib/utf8.t | |
parent | 900924803afbe9797cd65fc2e423c8d52b014139 (diff) | |
download | perl-7adaf5b2acaa653a831bb68ed91d8d205fbf9fb2.tar.gz |
lib/utf8.t: Add some tests to stress EBCDIC
The tests for the Latin1 \xFF aren't a fair test of UTF-8 on EBCDIC
platforms, because it is generally a UTF-8 invariant character, so is
the same regardless of being in UTF-8 or not. This adds some tests
where the UTF-EBCDIC version is 2 bytes (as well as the UTF-8 version).
Diffstat (limited to 'lib/utf8.t')
-rw-r--r-- | lib/utf8.t | 48 |
1 files changed, 35 insertions, 13 deletions
diff --git a/lib/utf8.t b/lib/utf8.t index 275e7c95a5..c09f96e073 100644 --- a/lib/utf8.t +++ b/lib/utf8.t @@ -336,15 +336,21 @@ SKIP: { { my $a = "A"; my $b = chr(0x0FF); - my $c = chr(0x100); + my $c = chr(0x0DF); # FF is invariant in many EBCDIC pages, so is not a + # fair test of 'beyond'; but DF is variant (in all + # supported EBCDIC pages so far), so make 2 'beyond' + # tests + my $d = chr(0x100); ok( utf8::valid($a), "utf8::valid basic"); ok( utf8::valid($b), "utf8::valid beyond"); - ok( utf8::valid($c), "utf8::valid unicode"); + ok( utf8::valid($c), "utf8::valid beyond"); + ok( utf8::valid($d), "utf8::valid unicode"); ok(!utf8::is_utf8($a), "!utf8::is_utf8 basic"); ok(!utf8::is_utf8($b), "!utf8::is_utf8 beyond"); - ok( utf8::is_utf8($c), "utf8::is_utf8 unicode"); + ok(!utf8::is_utf8($c), "!utf8::is_utf8 beyond"); + ok( utf8::is_utf8($d), "utf8::is_utf8 unicode"); is(utf8::upgrade($a), 1, "utf8::upgrade basic"); if ($::IS_EBCDIC) { # EBCDIC. @@ -352,35 +358,44 @@ SKIP: { } else { is(utf8::upgrade($b), 2, "utf8::upgrade beyond"); } - is(utf8::upgrade($c), 2, "utf8::upgrade unicode"); + is(utf8::upgrade($c), 2, "utf8::upgrade beyond"); + is(utf8::upgrade($d), 2, "utf8::upgrade unicode"); is($a, "A", "basic"); is($b, "\xFF", "beyond"); - is($c, "\x{100}", "unicode"); + is($c, "\xDF", "beyond"); + is($d, "\x{100}", "unicode"); ok( utf8::valid($a), "utf8::valid basic"); ok( utf8::valid($b), "utf8::valid beyond"); - ok( utf8::valid($c), "utf8::valid unicode"); + ok( utf8::valid($c), "utf8::valid beyond"); + ok( utf8::valid($d), "utf8::valid unicode"); ok( utf8::is_utf8($a), "utf8::is_utf8 basic"); ok( utf8::is_utf8($b), "utf8::is_utf8 beyond"); - ok( utf8::is_utf8($c), "utf8::is_utf8 unicode"); + ok( utf8::is_utf8($c), "utf8::is_utf8 beyond"); + ok( utf8::is_utf8($d), "utf8::is_utf8 unicode"); is(utf8::downgrade($a), 1, "utf8::downgrade basic"); is(utf8::downgrade($b), 1, "utf8::downgrade beyond"); + is(utf8::downgrade($c), 1, "utf8::downgrade beyond"); is($a, "A", "basic"); is($b, "\xFF", "beyond"); + is($c, "\xDF", "beyond"); ok( utf8::valid($a), "utf8::valid basic"); ok( utf8::valid($b), "utf8::valid beyond"); + ok( utf8::valid($c), "utf8::valid beyond"); ok(!utf8::is_utf8($a), "!utf8::is_utf8 basic"); ok(!utf8::is_utf8($b), "!utf8::is_utf8 beyond"); + ok(!utf8::is_utf8($c), "!utf8::is_utf8 beyond"); utf8::encode($a); utf8::encode($b); utf8::encode($c); + utf8::encode($d); is($a, "A", "basic"); if ($::IS_EBCDIC) { # EBCDIC. @@ -388,28 +403,34 @@ SKIP: { } else { is(length($b), 2, "beyond length"); } - is(length($c), 2, "unicode length"); + is(length($c), 2, "beyond length"); + is(length($d), 2, "unicode length"); ok(utf8::valid($a), "utf8::valid basic"); ok(utf8::valid($b), "utf8::valid beyond"); - ok(utf8::valid($c), "utf8::valid unicode"); + ok(utf8::valid($c), "utf8::valid beyond"); + ok(utf8::valid($d), "utf8::valid unicode"); # encode() clears the UTF-8 flag (unlike upgrade()). ok(!utf8::is_utf8($a), "!utf8::is_utf8 basic"); ok(!utf8::is_utf8($b), "!utf8::is_utf8 beyond"); - ok(!utf8::is_utf8($c), "!utf8::is_utf8 unicode"); + ok(!utf8::is_utf8($c), "!utf8::is_utf8 beyond"); + ok(!utf8::is_utf8($d), "!utf8::is_utf8 unicode"); utf8::decode($a); utf8::decode($b); utf8::decode($c); + utf8::decode($d); is($a, "A", "basic"); is($b, "\xFF", "beyond"); - is($c, "\x{100}", "unicode"); + is($c, "\xDF", "beyond"); + is($d, "\x{100}", "unicode"); ok(utf8::valid($a), "!utf8::valid basic"); ok(utf8::valid($b), "!utf8::valid beyond"); - ok(utf8::valid($c), " utf8::valid unicode"); + ok(utf8::valid($c), "!utf8::valid beyond"); + ok(utf8::valid($d), " utf8::valid unicode"); ok(!utf8::is_utf8($a), "!utf8::is_utf8 basic"); if ($::IS_EBCDIC) { # EBCDIC. @@ -417,7 +438,8 @@ SKIP: { } else { ok( utf8::is_utf8($b), " utf8::is_utf8 beyond"); # $b stays in UTF-8. } - ok( utf8::is_utf8($c), " utf8::is_utf8 unicode"); + ok( utf8::is_utf8($c), " utf8::is_utf8 beyond"); # $c stays in UTF-8. + ok( utf8::is_utf8($d), " utf8::is_utf8 unicode"); } { |