Skip to content

Commit

Permalink
Clarify non-unicode korean tests
Browse files Browse the repository at this point in the history
Add explanation and extra tests to ensure that our non-unicode
transcription works properly and outputs a reasonable UTF-8 string.

Note that on musl, `setlocales()` never fails, and so we cannot test
this properly.
  • Loading branch information
staticfloat authored and pcjentsch committed Aug 18, 2022
1 parent 2c5ebe6 commit cda6550
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 13 deletions.
2 changes: 1 addition & 1 deletion stdlib/Dates/test/io.jl
Original file line number Diff line number Diff line change
Expand Up @@ -548,7 +548,7 @@ end
@test Time("$t12", "$HH:MMp") == t
end
local tmstruct, strftime
withlocales(["C"]) do
withlocales(["C"]) do locale
# test am/pm comparison handling
tmstruct = Libc.strptime("%I:%M%p", t12)
strftime = Libc.strftime("%I:%M%p", tmstruct)
Expand Down
29 changes: 19 additions & 10 deletions test/misc.jl
Original file line number Diff line number Diff line change
Expand Up @@ -986,19 +986,28 @@ end
@test_nowarn Core.eval(Main, :(import ....Main))

# issue #27239
using Base.BinaryPlatforms: HostPlatform, libc
@testset "strftime tests issue #27239" begin
# change to non-Unicode Korean
# change to non-Unicode Korean to test that it is properly transcoded into valid UTF-8
korloc = ["ko_KR.EUC-KR", "ko_KR.CP949", "ko_KR.949", "Korean_Korea.949"]
timestrs = String[]
withlocales(korloc) do
# system dependent formats
push!(timestrs, Libc.strftime(0.0))
push!(timestrs, Libc.strftime("%a %A %b %B %p %Z", 0))
at_least_one_locale_found = false
withlocales(korloc) do locale
at_least_one_locale_found = true
# Test both the default format and a custom formatting string
for s in (Libc.strftime(0.0), Libc.strftime("%a %A %b %B %p %Z", 0))
# Ensure that we always get valid UTF-8 back
@test isvalid(s)

# On `musl` it is impossible for `setlocale` to fail, it just falls back to
# the default system locale, which on our buildbots is en_US.UTF-8. We'll
# assert that what we get does _not_ start with `Thu`, as that's what all
# en_US.UTF-8 encodings would start with.
# X-ref: https://musl.openwall.narkive.com/kO1vpTWJ/setlocale-behavior-with-missing-locales
@test !startswith(s, "Thu") broken=(libc(HostPlatform()) == "musl")
end
end
# tests
isempty(timestrs) && @warn "skipping stftime tests: no locale found for testing"
for s in timestrs
@test isvalid(s)
if !at_least_one_locale_found
@warn "skipping stftime tests: no locale found for testing"
end
end

Expand Down
3 changes: 1 addition & 2 deletions test/testhelpers/withlocales.jl
Original file line number Diff line number Diff line change
Expand Up @@ -9,15 +9,14 @@ function withlocales(f, newlocales)
locales[cat] = unsafe_string(cstr)
end
end
timestrs = String[]
try
# change to each of given locales
for lc in newlocales
set = true
for (cat, _) in locales
set &= ccall(:setlocale, Cstring, (Cint, Cstring), cat, lc) != C_NULL
end
set && f()
set && f(lc)
end
finally
# recover locales
Expand Down

0 comments on commit cda6550

Please sign in to comment.