From: Jarkko Hietaniemi Date: Fri, 18 Jun 1999 10:28:45 +0000 (+0000) Subject: Spice up locale.t. X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=6be75cd7bb190325edc048513563b9b026ef1a86;p=p5sagit%2Fp5-mst-13.2.git Spice up locale.t. p4raw-id: //depot/cfgperl@3543 --- diff --git a/t/pragma/locale.t b/t/pragma/locale.t index 760bc4b..7def681 100755 --- a/t/pragma/locale.t +++ b/t/pragma/locale.t @@ -14,6 +14,14 @@ use strict; my $debug = 1; +sub debug { + print @_ if $debug; +} + +sub debugf { + printf @_ if $debug; +} + my $have_setlocale = 0; eval { require POSIX; @@ -221,39 +229,68 @@ exit unless $have_setlocale; # Find locales. +debug "# Scanning for locales...\n"; + +# Note that it's okay that some languages have their native names +# capitalized here even though that's not "right". They are lowercased +# anyway later during the scanning process (and besides, some clueless +# vendor might have them capitalized errorneously anyway). + my $locales = < $#Alnum_); - $lesser = join('', @Alnum_[$from..$to]); - # Select a slice one character on. - $from++; $to++; - $to = $#Alnum_ if ($to > $#Alnum_); - $greater = join('', @Alnum_[$from..$to]); - ($yes, $no, $sign) = ($lesser lt $greater - ? (" ", "not ", 1) - : ("not ", " ", -1)); - # all these tests should FAIL (return 0). - # Exact lt or gt cannot be tested because - # in some locales, say, eacute and E may test equal. - @test = - ( - $no.' ($lesser le $greater)', # 1 - 'not ($lesser ne $greater)', # 2 - ' ($lesser eq $greater)', # 3 - $yes.' ($lesser ge $greater)', # 4 - $yes.' ($lesser ge $greater)', # 5 - $yes.' ($greater le $lesser )', # 7 - 'not ($greater ne $lesser )', # 8 - ' ($greater eq $lesser )', # 9 - $no.' ($greater ge $lesser )', # 10 - 'not (($lesser cmp $greater) == -$sign)' # 12 - ); - @test{@test} = 0 x @test; - $test = 0; - for my $ti (@test) { $test{$ti} = eval $ti ; $test ||= $test{$ti} } - if ($test) { - $Problem{102}{$Locale} = 1; - debug "# failed 102 at:\n"; - debug "# lesser = '$lesser'\n"; - debug "# greater = '$greater'\n"; - debug "# lesser cmp greater = ", $lesser cmp $greater, "\n"; - debug "# greater cmp lesser = ", $greater cmp $lesser, "\n"; - debug "# (greater) from = $from, to = $to\n"; + debug "# testing 102 with locale '$Locale'\n"; + { + my ($from, $to, $lesser, $greater, + @test, %test, $test, $yes, $no, $sign); + + for (0..9) { + # Select a slice. + $from = int(($_*@Alnum_)/10); + $to = $from + int(@Alnum_/10); + $to = $#Alnum_ if ($to > $#Alnum_); + $lesser = join('', @Alnum_[$from..$to]); + # Select a slice one character on. + $from++; $to++; + $to = $#Alnum_ if ($to > $#Alnum_); + $greater = join('', @Alnum_[$from..$to]); + ($yes, $no, $sign) = ($lesser lt $greater + ? (" ", "not ", 1) + : ("not ", " ", -1)); + # all these tests should FAIL (return 0). + # Exact lt or gt cannot be tested because + # in some locales, say, eacute and E may test equal. + @test = + ( + $no.' ($lesser le $greater)', # 1 + 'not ($lesser ne $greater)', # 2 + ' ($lesser eq $greater)', # 3 + $yes.' ($lesser ge $greater)', # 4 + $yes.' ($lesser ge $greater)', # 5 + $yes.' ($greater le $lesser )', # 7 + 'not ($greater ne $lesser )', # 8 + ' ($greater eq $lesser )', # 9 + $no.' ($greater ge $lesser )', # 10 + 'not (($lesser cmp $greater) == -$sign)' # 12 + ); + @test{@test} = 0 x @test; + $test = 0; for my $ti (@test) { - debugf("# %-40s %-4s", $ti, - $test{$ti} ? 'FAIL' : 'ok'); - if ($ti =~ /\(\.*(\$.+ +cmp +\$[^\)]+)\.*\)/) { - debugf("(%s == %4d)", $1, eval $1); - } - debug "\n#"; + $test{$ti} = eval $ti; + $test ||= $test{$ti} } + if ($test) { + $Problem{102}{$Locale} = 1; + debug "# failed 102 at:\n"; + debug "# lesser = '$lesser'\n"; + debug "# greater = '$greater'\n"; + debug "# lesser cmp greater = ", + $lesser cmp $greater, "\n"; + debug "# greater cmp lesser = ", + $greater cmp $lesser, "\n"; + debug "# (greater) from = $from, to = $to\n"; + for my $ti (@test) { + debugf("# %-40s %-4s", $ti, + $test{$ti} ? 'FAIL' : 'ok'); + if ($ti =~ /\(\.*(\$.+ +cmp +\$[^\)]+)\.*\)/) { + debugf("(%s == %4d)", $1, eval $1); + } + debug "\n#"; + } - last; + last; + } } } } + + use locale; + + my ($x, $y) = (1.23, 1.23); + + my $a = "$x"; + 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"; + } + + 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 "# testing 104 with locale '$Locale'\n"; + unless ($c eq $d) { + $Problem{104}{$Locale} = 1; + debug "# failed 104\n"; + } + + 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 + + debug "# testing 105 with locale '$Locale'\n"; + unless ($c == 1.23) { + $Problem{105}{$Locale} = 1; + debug "# failed 105\n"; + } + + debug "# testing 106 with locale '$Locale'\n"; + unless ($c == $x) { + $Problem{106}{$Locale} = 1; + debug "# failed 106\n"; + } + + debug "# testing 107 with locale '$Locale'\n"; + unless ($c == $d) { + $Problem{107}{$Locale} = 1; + debug "# failed 107\n"; + } + + { + no locale; + + my $e = "$x"; + + 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"; + } + + debug "# testing 109 with locale '$Locale'\n"; + unless ($e == $x) { + $Problem{109}{$Locale} = 1; + debug "# failed 109\n"; + } + + debug "# testing 110 with locale '$Locale'\n"; + unless ($e == $c) { + $Problem{110}{$Locale} = 1; + debug "# failed 110\n"; + } + } + + debug "# testing 111 with locale '$Locale'\n"; + unless ($w == 0) { + $Problem{110}{$Locale} = 1; + debug "# failed 111\n"; + } + + my $f = "1.23"; + + debug "# 112..114: f = $f, locale = $Locale\n"; + + debug "# testing 112 with locale '$Locale'\n"; + unless ($f == 1.23) { + $Problem{112}{$Locale} = 1; + debug "# failed 112\n"; + } + + debug "# testing 113 with locale '$Locale'\n"; + unless ($f == $x) { + $Problem{113}{$Locale} = 1; + debug "# failed 113\n"; + } + + debug "# testing 114 with locale '$Locale'\n"; + unless ($f == $c) { + $Problem{114}{$Locale} = 1; + debug "# failed 114\n"; + } } -foreach (99..102) { +foreach (99..114) { if ($Problem{$_}) { if ($_ == 102) { print "# The failure of test 102 is not necessarily fatal.\n"; @@ -524,7 +662,7 @@ foreach (99..102) { my $didwarn = 0; -foreach (102..102) { +foreach (99..114) { if ($Problem{$_}) { my @f = sort keys %{ $Problem{$_} }; my $f = join(" ", @f); @@ -571,72 +709,6 @@ if ($didwarn) { { use locale; - my ($x, $y) = (1.23, 1.23); - - my $a = "$x"; - printf ''; # printf used to reset locale to "C" - my $b = "$y"; - - print "not " unless $a eq $b; - print "ok 103\n"; - - my $c = "$x"; - my $z = sprintf ''; # sprintf used to reset locale to "C" - my $d = "$y"; - - print "not " unless $c eq $d; - print "ok 104\n"; - - 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 - - print "not " unless $c == 1.23; - print "ok 105\n"; - - print "not " unless $c == $x; - print "ok 106\n"; - - print "not " unless $c == $d; - print "ok 107\n"; - - debug "# 103..107: a = $a, b = $b, c = $c, d = $d\n"; - - { - no locale; - - my $e = "$x"; - - print "not " unless $e == 1.23; - print "ok 108\n"; - - print "not " unless $e == $x; - print "ok 109\n"; - - print "not " unless $e == $c; - print "ok 110\n"; - - debug "# 108..110: e = $e\n"; - } - - print "not " unless $w == 0; - print "ok 111\n"; - - my $f = "1.23"; - - print "not " unless $f == 1.23; - print "ok 112\n"; - - print "not " unless $f == $x; - print "ok 113\n"; - - print "not " unless $f == $c; - print "ok 114\n"; - - debug "# 112..114: f = $f\n"; } # eof