diff options
author | Jarkko Hietaniemi <jhi@iki.fi> | 1999-07-04 20:10:44 +0000 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 1999-07-04 20:10:44 +0000 |
commit | 2a680da6beb63f7dc6442e9c4beb1cf75b8ae796 (patch) | |
tree | f9613691a14978ba2008d1b67b3c381c0ab1c2f3 /t | |
parent | 31351b0411cad332df82232d3c7919b62fb21d0c (diff) | |
download | perl-2a680da6beb63f7dc6442e9c4beb1cf75b8ae796.tar.gz |
Add test for change #3568 plus general cleanup.
p4raw-link: @3568 on //depot/cfgperl: 31351b0411cad332df82232d3c7919b62fb21d0c
p4raw-id: //depot/cfgperl@3571
Diffstat (limited to 't')
-rwxr-xr-x | t/pragma/locale.t | 180 |
1 files changed, 82 insertions, 98 deletions
diff --git a/t/pragma/locale.t b/t/pragma/locale.t index 871c5d8d6b..9fa565ed52 100755 --- a/t/pragma/locale.t +++ b/t/pragma/locale.t @@ -376,8 +376,22 @@ setlocale(LC_ALL, "C"); debug "# Locales = @Locale\n"; my %Problem; +my %Okay; +my %Testing; my @Neoalpha; +sub tryneoalpha { + my ($Locale, $i, $test) = @_; + debug "# testing $i with locale '$Locale'\n" + unless $Testing{$i}{$Locale}++; + unless ($test) { + $Problem{$i}{$Locale} = 1; + debug "# failed $i with locale '$Locale'\n"; + } else { + push @{$Okay{$i}}, $Locale; + } +} + foreach $Locale (@Locale) { debug "# Locale = $Locale\n"; @Alnum_ = getalnum_(); @@ -442,44 +456,34 @@ foreach $Locale (@Locale) { # Test \w. - debug "# testing 99 with locale '$Locale'\n"; { my $word = join('', @Neoalpha); $word =~ /^(\w+)$/; - if ($1 ne $word) { - $Problem{99}{$Locale} = 1; - debug "# failed 99 ($1 vs $word)\n"; - } + tryneoalpha($Locale, 99, $1 eq $word); } - # Cross-check whole character set. + # Cross-check the whole 8-bit character set. - debug "# testing 100 with locale '$Locale'\n"; for (map { chr } 0..255) { - if ((/\w/ and /\W/) or (/\d/ and /\D/) or (/\s/ and /\S/)) { - $Problem{100}{$Locale} = 1; - debug "# failed 100 for chr(", ord(), ")\n"; - } + tryneoalpha($Locale, 100, + (/\w/ xor /\W/) || + (/\d/ xor /\D/) || + (/\s/ xor /\S/)); } # Test for read-only scalars' locale vs non-locale comparisons. - debug "# testing 101 with locale '$Locale'\n"; { no locale; $a = "qwerty"; { use locale; - if ($a cmp "qwerty") { - $Problem{101}{$Locale} = 1; - debug "# failed 101\n"; - } + tryneoalpha($Locale, 101, ($a cmp "qwerty") == 0); } } - debug "# testing 102 with locale '$Locale'\n"; { my ($from, $to, $lesser, $greater, @test, %test, $test, $yes, $no, $sign); @@ -519,9 +523,8 @@ foreach $Locale (@Locale) { $test{$ti} = eval $ti; $test ||= $test{$ti} } + tryneoalpha($Locale, 102, $test == 0); if ($test) { - $Problem{102}{$Locale} = 1; - debug "# failed 102 at:\n"; debug "# lesser = '$lesser'\n"; debug "# greater = '$greater'\n"; debug "# lesser cmp greater = ", @@ -552,106 +555,87 @@ foreach $Locale (@Locale) { printf ''; # printf used to reset locale to "C" my $b = "$y"; - debug "# testing 103 with locale '$Locale'\n"; - unless ($a eq $b) { - $Problem{103}{$Locale} = 1; - debug "# failed 103\n"; - } + debug "# 103..107: a = $a, b = $b, Locale = $Locale\n"; + + tryneoalpha($Locale, 103, $a eq $b); my $c = "$x"; my $z = sprintf ''; # sprintf used to reset locale to "C" my $d = "$y"; - debug "# 103..107: a = $a, b = $b, c = $c, d = $d, Locale = $Locale\n"; + debug "# 104..107: c = $c, d = $d, Locale = $Locale\n"; - debug "# testing 104 with locale '$Locale'\n"; - unless ($c eq $d) { - $Problem{104}{$Locale} = 1; - debug "# failed 104\n"; - } + tryneoalpha($Locale, 104, $c eq $d); - my $w = 0; - local $SIG{__WARN__} = sub { $w++ }; - local $^W = 1; + { + my $w = 0; + local $SIG{__WARN__} = sub { $w++ }; + local $^W = 1; - # the == (among other things) used to warn for locales - # that had something else than "." as the radix character + # the == (among other ops) used to warn for locales + # that had something else than "." as the radix character - debug "# testing 105 with locale '$Locale'\n"; - unless ($c == 1.23) { - $Problem{105}{$Locale} = 1; - debug "# failed 105\n"; - } + tryneoalpha($Locale, 105, $c == 1.23); - debug "# testing 106 with locale '$Locale'\n"; - unless ($c == $x) { - $Problem{106}{$Locale} = 1; - debug "# failed 106\n"; - } + tryneoalpha($Locale, 106, $c == $x); - debug "# testing 107 with locale '$Locale'\n"; - unless ($c == $d) { - $Problem{107}{$Locale} = 1; - debug "# failed 107\n"; - } + tryneoalpha($Locale, 107, $c == $d); - { - no locale; + { + no locale; - my $e = "$x"; + my $e = "$x"; - debug "# 108..110: e = $e, Locale = $Locale\n"; + debug "# 108..110: e = $e, Locale = $Locale\n"; - debug "# testing 108 with locale '$Locale'\n"; - unless ($e == 1.23) { - $Problem{108}{$Locale} = 1; - debug "# failed 108\n"; - } + tryneoalpha($Locale, 108, $e == 1.23); - debug "# testing 109 with locale '$Locale'\n"; - unless ($e == $x) { - $Problem{109}{$Locale} = 1; - debug "# failed 109\n"; + tryneoalpha($Locale, 109, $e == $x); + + tryneoalpha($Locale, 110, $e == $c); } + + tryneoalpha($Locale, 111, $w == 0); - debug "# testing 110 with locale '$Locale'\n"; - unless ($e == $c) { - $Problem{110}{$Locale} = 1; - debug "# failed 110\n"; - } - } + my $f = "1.23"; + + debug "# 112..114: f = $f, locale = $Locale\n"; + + tryneoalpha($Locale, 112, $f == 1.23); - debug "# testing 111 with locale '$Locale'\n"; - unless ($w == 0) { - $Problem{110}{$Locale} = 1; - debug "# failed 111\n"; + tryneoalpha($Locale, 113, $f == $x); + + tryneoalpha($Locale, 114, $f == $c); } - my $f = "1.23"; + debug "# testing 115 with locale '$Locale'\n"; + { + use locale; - debug "# 112..114: f = $f, locale = $Locale\n"; + sub lcA { + my $lc0 = lc $_[0]; + my $lc1 = lc $_[1]; + return $lc0 cmp $lc1; + } - debug "# testing 112 with locale '$Locale'\n"; - unless ($f == 1.23) { - $Problem{112}{$Locale} = 1; - debug "# failed 112\n"; - } + sub lcB { + return lc($_[0]) cmp lc($_[1]); + } - debug "# testing 113 with locale '$Locale'\n"; - unless ($f == $x) { - $Problem{113}{$Locale} = 1; - debug "# failed 113\n"; - } + my $x = "ab"; + my $y = "aa"; + my $z = "AB"; - debug "# testing 114 with locale '$Locale'\n"; - unless ($f == $c) { - $Problem{114}{$Locale} = 1; - debug "# failed 114\n"; + tryneoalpha($Locale, 115, + lcA($x, $y) == 1 && lcB($x, $y) == 1 || + lcA($x, $z) == 0 && lcB($x, $z) == 0); } } +# Recount the errors. + foreach (99..115) { - if ($Problem{$_}) { + if ($Problem{$_} || !defined $Okay{$_} || !@{$Okay{$_}}) { if ($_ == 102) { print "# The failure of test 102 is not necessarily fatal.\n"; print "# It usually indicates a problem in the enviroment,\n"; @@ -662,6 +646,8 @@ foreach (99..115) { print "ok $_\n"; } +# Give final advice. + my $didwarn = 0; foreach (99..115) { @@ -669,13 +655,14 @@ foreach (99..115) { my @f = sort keys %{ $Problem{$_} }; my $f = join(" ", @f); $f =~ s/(.{50,60}) /$1\n#\t/g; - warn - "# The locale ", (@f == 1 ? "definition" : "definitions"), "\n#\n", + print + "#\n", + "# The locale ", (@f == 1 ? "definition" : "definitions"), "\n#\n", "#\t", $f, "\n#\n", "# on your system may have errors because the locale test $_\n", "# failed in ", (@f == 1 ? "that locale" : "those locales"), ".\n"; - warn <<EOW; + print <<EOW; # # If your users are not using these locales you are safe for the moment, # but please report this failure first to perlbug\@perl.com using the @@ -688,6 +675,8 @@ EOW } } +# Tell which locales ere okay. + if ($didwarn) { my @s; @@ -708,9 +697,4 @@ if ($didwarn) { "# tested okay.\n#\n", } -{ - use locale; - -} - # eof |