Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Test on Julia nightly (>=1.9) fails #48

Closed
terasakisatoshi opened this issue Dec 11, 2022 · 2 comments · Fixed by #49
Closed

Test on Julia nightly (>=1.9) fails #48

terasakisatoshi opened this issue Dec 11, 2022 · 2 comments · Fixed by #49

Comments

@terasakisatoshi
Copy link
Member

image

@terasakisatoshi
Copy link
Member Author

I could reproduce this issue locally on my mac

               _
   _       _ _(_)_     |  Documentation: https://docs.julialang.org
  (_)     | (_) (_)    |
   _ _   _| |_  __ _   |  Type "?" for help, "]?" for Pkg help.
  | | | | | | |/ _` |  |
  | | |_| | | | (_| |  |  Version 1.10.0-DEV.unknown (2022-11-16)
 _/ |\__'_|_|_|\__'_|  |  Commit ee0f3fc (25 days old master)
|__/                   |

(Replay) pkg> test
     Testing Replay
      Status `/private/var/folders/c_/f7y4cgjx113d8rrq_t63glzh0000gp/T/jl_6gyv45/Project.toml`
  [a8cc5b0e] Crayons v4.1.1
  [dd78c5bf] Replay v0.4.2 `~/work/atelierarith/Replay.jl`
  [44cfe95a] Pkg v1.8.0 `@stdlib/Pkg`
  [6462fe0b] Sockets `@stdlib/Sockets`
  [8dfed614] Test `@stdlib/Test`
      Status `/private/var/folders/c_/f7y4cgjx113d8rrq_t63glzh0000gp/T/jl_6gyv45/Manifest.toml`
  [a8cc5b0e] Crayons v4.1.1
  [dd78c5bf] Replay v0.4.2 `~/work/atelierarith/Replay.jl`
  [0dad84c5] ArgTools v1.1.1 `@stdlib/ArgTools`
  [56f22d72] Artifacts `@stdlib/Artifacts`
  [2a0f44e3] Base64 `@stdlib/Base64`
  [ade2ca70] Dates `@stdlib/Dates`
  [f43a241f] Downloads v1.6.0 `@stdlib/Downloads`
  [7b1f6079] FileWatching `@stdlib/FileWatching`
  [b77e0a4c] InteractiveUtils `@stdlib/InteractiveUtils`
  [b27032c2] LibCURL v0.6.3 `@stdlib/LibCURL`
  [76f85450] LibGit2 `@stdlib/LibGit2`
  [8f399da3] Libdl `@stdlib/Libdl`
  [56ddb016] Logging `@stdlib/Logging`
  [d6f4376e] Markdown `@stdlib/Markdown`
  [ca575930] NetworkOptions v1.2.0 `@stdlib/NetworkOptions`
  [44cfe95a] Pkg v1.8.0 `@stdlib/Pkg`
  [de0858da] Printf `@stdlib/Printf`
  [3fa0cd96] REPL `@stdlib/REPL`
  [9a3f8284] Random `@stdlib/Random`
  [ea8e919c] SHA v0.7.0 `@stdlib/SHA`
  [9e88b42a] Serialization `@stdlib/Serialization`
  [6462fe0b] Sockets `@stdlib/Sockets`
  [fa267f1f] TOML v1.0.3 `@stdlib/TOML`
  [a4e569a6] Tar v1.10.0 `@stdlib/Tar`
  [8dfed614] Test `@stdlib/Test`
  [cf7118a7] UUIDs `@stdlib/UUIDs`
  [4ec0a83e] Unicode `@stdlib/Unicode`
  [deac9b47] LibCURL_jll v7.84.0+0 `@stdlib/LibCURL_jll`
  [29816b5a] LibSSH2_jll v1.10.2+0 `@stdlib/LibSSH2_jll`
  [c8ffd9c3] MbedTLS_jll v2.28.0+0 `@stdlib/MbedTLS_jll`
  [14a3606d] MozillaCACerts_jll v2022.10.11 `@stdlib/MozillaCACerts_jll`
  [83775a58] Zlib_jll v1.2.13+0 `@stdlib/Zlib_jll`
  [8e850ede] nghttp2_jll v1.48.0+0 `@stdlib/nghttp2_jll`
  [3f19e933] p7zip_jll v17.4.0+0 `@stdlib/p7zip_jll`
     Testing Running tests...
replay: color=yes: Test Failed at /Users/atelier/work/atelierarith/Replay.jl/test/runtests.jl:21
  Expression: out == ref
   Evaluated: "\e[?25l\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cx = 1 + 1\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cx = 1 + 1\r\e[16C\r\n\e[?2004l\e[0m\e[1m\e[0m\e[0m2\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cprintln(\"Hello World\")\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cprintln(\"Hello World\")\r\e[29C\r\n\e[?2004l\e[0mHello World\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C@show x\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C@show x\r\e[14C\r\n\e[?2004l\e[0mx = 2\r\n\e[1m\e[0m\e[0m2\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cexit()\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cexit()\r\e[13C\r\n\e[?2004l\e[0m" == "\e[?25l\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cx = 1 + 1\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cx = 1 + 1\r\e[16C\r\n\e[?2004l\e[0m\e[0m2\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cprintln(\"Hello World\")\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cprintln(\"Hello World\")\r\e[29C\r\n\e[?2004l\e[0mHello World\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C@show x\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C@show x\r\e[14C\r\n\e[?2004l\e[0mx = 2\r\n\e[0m2\r\n\r\n\r\e[0K\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7C\e[?2004h\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7C\r\e[7Cexit()\r\e[0K\e[32m\e[1mjulia> \e[0m\e[0m\r\e[7Cexit()\r\e[13C\r\n\e[?2004l\e[0m"
Stacktrace:
 [1] macro expansion
   @ ~/julia_dev/share/julia/stdlib/v1.10/Test/src/Test.jl:477 [inlined]
 [2] macro expansion
   @ ~/work/atelierarith/Replay.jl/test/runtests.jl:21 [inlined]
 [3] macro expansion
   @ ~/julia_dev/share/julia/stdlib/v1.10/Test/src/Test.jl:1496 [inlined]
 [4] top-level scope
   @ ~/work/atelierarith/Replay.jl/test/runtests.jl:11
Test Summary:     | Fail  Total  Time
replay: color=yes |    1      1  7.2s
ERROR: LoadError: Some tests did not pass: 0 passed, 1 failed, 0 errored, 0 broken.
in expression starting at /Users/atelier/work/atelierarith/Replay.jl/test/runtests.jl:10
ERROR: Package Replay errored during testing

(Replay) pkg

@terasakisatoshi
Copy link
Member Author

terasakisatoshi commented Dec 11, 2022

It seems REPL package in Julia 1.9 introduced new feature

"Add ability to add output prefixes to the REPL output and use that to implement an IPython mode"

Ref: JuliaLang/julia#46781

LineEdit.jl has the following function that adds \e[1m\e[0m (:bold, :normal)

function write_output_prefix(io::IO, p::Prompt, color::Bool)
    prefix = prompt_string(p.output_prefix_prefix)
    suffix = prompt_string(p.output_prefix_suffix)
    print(io, prefix)
    color && write(io, Base.text_colors[:bold])
    width = write_prompt(io, p.output_prefix, color)
    color && write(io, Base.text_colors[:normal])
    print(io, suffix)
    return width
end

and the display method in REPL.jl calls the function above:

function display(d::REPLDisplay, mime::MIME"text/plain", x)
    x = Ref{Any}(x)
    with_repl_linfo(d.repl) do io
        io = IOContext(io, :limit => true, :module => active_module(d)::Module)
        if d.repl isa LineEditREPL
            mistate = d.repl.mistate
            mode = LineEdit.mode(mistate)
            LineEdit.write_output_prefix(io, mode, get(io, :color, false)::Bool) # <-- HERE
        end
        get(io, :color, false)::Bool && write(io, answer_color(d.repl))
        if isdefined(d.repl, :options) && isdefined(d.repl.options, :iocontext)
            # this can override the :limit property set initially
            io = foldl(IOContext, d.repl.options.iocontext, init=io)
        end
        show(io, mime, x[])
        println(io)
    end
    return nothing
end

@terasakisatoshi terasakisatoshi changed the title CI fails for julia nightly version Test on Julia nightly (>=1.9) fails Jan 2, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant