2025-08-09 11:24.29: New job: test ocaml-multicore/eio https://github.com/ocaml-multicore/eio.git#refs/heads/main (1dce15f1aad822089828968f5e0421b7c5f06c92) (macos-arm64:macos-homebrew-5.3_arm64_opam-2.4)
Base: macos-homebrew-ocaml-5.3
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ocaml-multicore/eio.git" -b "main" && cd "eio" && git reset --hard 1dce15f1
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM macos-homebrew-ocaml-5.3
# macos-homebrew-5.3_arm64_opam-2.4
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
RUN ln -f ~/local/bin/opam-2.4 ~/local/bin/opam
RUN opam init --reinit -ni
RUN uname -rs && opam exec -- ocaml -version && opam --version
RUN cd ~/opam-repository && (git cat-file -e e77940d8ff8706305602d0d643bf01c77beef2e7 || git fetch origin master) && git reset -q --hard e77940d8ff8706305602d0d643bf01c77beef2e7 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 eio_windows.opam eio_posix.opam eio_main.opam eio_linux.opam eio.opam ./src/./
RUN opam pin add -yn eio_windows.dev './src/./' && \
opam pin add -yn eio_posix.dev './src/./' && \
opam pin add -yn eio_main.dev './src/./' && \
opam pin add -yn eio_linux.dev './src/./' && \
opam pin add -yn eio.dev './src/./'
RUN echo '(lang dune 3.0)' > './src/./dune-project'
ENV DEPS="afl-persistent.1.4 alcotest.1.9.0 astring.0.8.5 backoff.0.1.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-bash.1 containers.3.16 cppo.1.8.0 crowbar.0.2.1 csexp.1.5.2 cstruct.6.2.0 domain-local-await.1.0.1 domain-local-timeout.1.0.1 dscheck.0.5.0 dune.3.19.1 dune-configurator.3.19.1 either.1.0.0 fmt.0.11.0 hmap.0.8.1 iomux.0.3 kcas.0.7.0 logs.0.9.0 lwt-dllist.1.1.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 optint.0.3.0 oseq.0.5.1 psq.0.2.1 re.1.13.2 result.1.5 seq.base stdlib-shims.0.3.0 thread-table.1.0.0 topkg.1.1.0 tsort.2.2.0 uutf.1.0.4 yojson.3.0.0"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.4 --depext-only -y eio_windows.dev eio_posix.dev eio_main.dev eio.dev $DEPS
RUN opam install $DEPS
COPY --chown=1000:1000 . ./src
RUN cd ./src && opam exec -- dune build --only-packages=eio_windows,eio_posix,eio_main,eio @install @check @runtest && rm -rf _build
END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK
2025-08-09 11:24.29: Using cache hint "ocaml-multicore/eio-macos-homebrew-ocaml-5.3-macos-homebrew-5.3_arm64_opam-2.4-3e184857709cd525fef077e95bcbdf0b"
2025-08-09 11:24.29: Using OBuilder spec:
((from macos-homebrew-ocaml-5.3)
(comment macos-homebrew-5.3_arm64_opam-2.4)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(run (shell "ln -f ~/local/bin/opam-2.4 ~/local/bin/opam"))
(run (shell "opam init --reinit -ni"))
(run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
(run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e e77940d8ff8706305602d0d643bf01c77beef2e7 || git fetch origin master) && git reset -q --hard e77940d8ff8706305602d0d643bf01c77beef2e7 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src eio_windows.opam eio_posix.opam eio_main.opam eio_linux.opam eio.opam)
(dst ./src/./))
(run (network host)
(shell "opam pin add -yn eio_windows.dev './src/./' && \
\nopam pin add -yn eio_posix.dev './src/./' && \
\nopam pin add -yn eio_main.dev './src/./' && \
\nopam pin add -yn eio_linux.dev './src/./' && \
\nopam pin add -yn eio.dev './src/./'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > './src/./dune-project'"))
(env DEPS "afl-persistent.1.4 alcotest.1.9.0 astring.0.8.5 backoff.0.1.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-bash.1 containers.3.16 cppo.1.8.0 crowbar.0.2.1 csexp.1.5.2 cstruct.6.2.0 domain-local-await.1.0.1 domain-local-timeout.1.0.1 dscheck.0.5.0 dune.3.19.1 dune-configurator.3.19.1 either.1.0.0 fmt.0.11.0 hmap.0.8.1 iomux.0.3 kcas.0.7.0 logs.0.9.0 lwt-dllist.1.1.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 optint.0.3.0 oseq.0.5.1 psq.0.2.1 re.1.13.2 result.1.5 seq.base stdlib-shims.0.3.0 thread-table.1.0.0 topkg.1.1.0 tsort.2.2.0 uutf.1.0.4 yojson.3.0.0")
(env CI true)
(env OCAMLCI true)
(run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "opam update --depexts && opam install --cli=2.4 --depext-only -y eio_windows.dev eio_posix.dev eio_main.dev eio.dev $DEPS"))
(run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "opam install $DEPS"))
(copy (src .) (dst ./src))
(run (shell "cd ./src && opam exec -- dune build --only-packages=eio_windows,eio_posix,eio_main,eio @install @check @runtest && rm -rf _build"))
)
2025-08-09 11:24.29: Waiting for resource in pool OCluster
2025-08-09 11:24.30: Waiting for worker…
2025-08-09 11:24.30: Got resource from pool OCluster
Building on m1-worker-03
HEAD is now at 9cb52c3 Add setuid fork action
HEAD is now at 1dce15f Merge pull request #817 from talex5/fix-windows-link
(from macos-homebrew-ocaml-5.3)
2025-08-09 11:24.31 ---> using "6ee950b55569b1a3f8a7953dc679318bf303d3a70ac7d49901c0ac2ca3805d7c" from cache
/: (comment macos-homebrew-5.3_arm64_opam-2.4)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (run (shell "ln -f ~/local/bin/opam-2.4 ~/local/bin/opam"))
2025-08-09 11:24.31 ---> using "98f27ffc931cc35f6fd0434c4b7cb74004ae5b966eac1b4d0d724f37574600ad" from cache
/: (run (shell "opam init --reinit -ni"))
No configuration file found, using built-in defaults.
Checking for available remotes: rsync and local, git.
- you won't be able to use mercurial repositories unless you install the hg command on your system.
- you won't be able to use darcs repositories unless you install the darcs command on your system.
This version of opam requires an update to the layout of /Users/mac1000/.opam from version 2.1 to version 2.2, which can't be reverted.
You may want to back it up before going further.
Continue? [Y/n] y
[NOTE] The 'jobs' option was reset, its value was 1 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
opam option jobs=1 --global
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] no changes from git+file:///Users/mac1000/opam-repository
2025-08-09 11:24.31 ---> using "05bef02621f4f152ba73fa5008f45408f9224fb6a3f95400ffe628ff48189e9f" from cache
/: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Darwin 24.5.0
The OCaml toplevel, version 5.3.0
2.4.1
2025-08-09 11:24.31 ---> using "a78de44d0fa6eb2299c3aff4eac17004df22cc4faa362aec41a39eccbcb56bb5" from cache
/: (run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e e77940d8ff8706305602d0d643bf01c77beef2e7 || git fetch origin master) && git reset -q --hard e77940d8ff8706305602d0d643bf01c77beef2e7 && git log --no-decorate -n1 --oneline && opam update -u"))
e77940d8ff Merge pull request #28255 from dbuenzli/b0-publish-fmt.0.11.0
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from git+file:///Users/mac1000/opam-repository
Already up-to-date.
Nothing to do.
# To update the current shell environment, run: eval $(opam env)
2025-08-09 11:24.57 ---> saved as "d89547fd02733b2b6bb0ad652051f3459ffc6563d2c80b2a8f8ecf2ed7cec010"
/: (copy (src eio_windows.opam eio_posix.opam eio_main.opam eio_linux.opam eio.opam)
(dst ./src/./))
2025-08-09 11:24.58 ---> saved as "2e65768412fdfd22bf93ce3cef8b3efbd44fbce353122d7bbb649a2e38d03f98"
/: (run (network host)
(shell "opam pin add -yn eio_windows.dev './src/./' && \
\nopam pin add -yn eio_posix.dev './src/./' && \
\nopam pin add -yn eio_main.dev './src/./' && \
\nopam pin add -yn eio_linux.dev './src/./' && \
\nopam pin add -yn eio.dev './src/./'"))
[eio_windows.dev] synchronised (file:///Users/mac1000/src)
eio_windows is now pinned to file:///Users/mac1000/src (version dev)
[eio_posix.dev] synchronised (file:///Users/mac1000/src)
eio_posix is now pinned to file:///Users/mac1000/src (version dev)
[eio_main.dev] synchronised (file:///Users/mac1000/src)
eio_main is now pinned to file:///Users/mac1000/src (version dev)
[eio_linux.dev] synchronised (file:///Users/mac1000/src)
eio_linux is now pinned to file:///Users/mac1000/src (version dev)
[eio.dev] synchronised (file:///Users/mac1000/src)
eio is now pinned to file:///Users/mac1000/src (version dev)
2025-08-09 11:25.14 ---> saved as "d332761bddf682369b123e332753d76197ccfe56ce419ea46145ebd05ce9840b"
/: (run (network host)
(shell "echo '(lang dune 3.0)' > './src/./dune-project'"))
2025-08-09 11:25.15 ---> saved as "7e6cedcfa8f1590099861199229bb87af68e148f6bc43169a57869bec762d9e4"
/: (env DEPS "afl-persistent.1.4 alcotest.1.9.0 astring.0.8.5 backoff.0.1.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base bigstringaf.0.10.0 camlp-streams.5.0.1 cmdliner.1.3.0 conf-bash.1 containers.3.16 cppo.1.8.0 crowbar.0.2.1 csexp.1.5.2 cstruct.6.2.0 domain-local-await.1.0.1 domain-local-timeout.1.0.1 dscheck.0.5.0 dune.3.19.1 dune-configurator.3.19.1 either.1.0.0 fmt.0.11.0 hmap.0.8.1 iomux.0.3 kcas.0.7.0 logs.0.9.0 lwt-dllist.1.1.0 mdx.2.5.0 mtime.2.1.0 multicore-magic.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 optint.0.3.0 oseq.0.5.1 psq.0.2.1 re.1.13.2 result.1.5 seq.base stdlib-shims.0.3.0 thread-table.1.0.0 topkg.1.1.0 tsort.2.2.0 uutf.1.0.4 yojson.3.0.0")
/: (env CI true)
/: (env OCAMLCI true)
/: (run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "opam update --depexts && opam install --cli=2.4 --depext-only -y eio_windows.dev eio_posix.dev eio_main.dev eio.dev $DEPS"))
+ /opt/homebrew/bin/brew "update"
- ==> Updating Homebrew...
- ==> Homebrew collects anonymous analytics.
- Read the analytics documentation (and how to opt-out) here:
- https://docs.brew.sh/Analytics
- No analytics have been recorded yet (nor will be during this `brew` run).
-
- ==> Homebrew is run entirely by unpaid volunteers. Please consider donating:
- https://github.com/Homebrew/brew#donations
-
- Updated 2 taps (homebrew/core and homebrew/cask).
- ==> New Formulae
- msolve: Library for Polynomial System Solving through Algebraic Methods
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[eio_posix.dev] synchronised (file:///Users/mac1000/src)
[eio_main.dev] synchronised (file:///Users/mac1000/src)
[eio.dev] synchronised (file:///Users/mac1000/src)
[eio_windows.dev] synchronised (file:///Users/mac1000/src)
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
2025-08-09 11:25.37 ---> saved as "5bd9a4aef092ce75e157b7b6dcb807d5dc524dcf88b2381af5ae7a5db29705c2"
/: (run (cache (opam-archives (target /Users/mac1000/.opam/download-cache)) (homebrew (target /Users/mac1000/Library/Caches/Homebrew)))
(network host)
(shell "opam install $DEPS"))
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[NOTE] Package base-unix is already installed (current version is base).
[NOTE] Package base-threads is already installed (current version is base).
[NOTE] Package base-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains is already installed (current version is base).
[NOTE] Package base-bigarray is already installed (current version is base).
The following actions will be performed:
=== install 46 packages
- install afl-persistent 1.4
- install alcotest 1.9.0
- install astring 0.8.5
- install backoff 0.1.1
- install base-bytes base
- install bigstringaf 0.10.0
- install camlp-streams 5.0.1
- install cmdliner 1.3.0
- install conf-bash 1
- install containers 3.16
- install cppo 1.8.0
- install crowbar 0.2.1
- install csexp 1.5.2
- install cstruct 6.2.0
- install domain-local-await 1.0.1
- install domain-local-timeout 1.0.1
- install dscheck 0.5.0
- install dune 3.19.1
- install dune-configurator 3.19.1
- install either 1.0.0
- install fmt 0.11.0
- install hmap 0.8.1
- install iomux 0.3
- install kcas 0.7.0
- install logs 0.9.0
- install lwt-dllist 1.1.0
- install mdx 2.5.0
- install mtime 2.1.0
- install multicore-magic 2.3.1
- install ocaml-syntax-shims 1.0.0
- install ocaml-version 4.0.1
- install ocamlbuild 0.16.1
- install ocamlfind 1.9.8
- install ocplib-endian 1.2
- install optint 0.3.0
- install oseq 0.5.1
- install psq 0.2.1
- install re 1.13.2
- install result 1.5
- install seq base
- install stdlib-shims 0.3.0
- install thread-table 1.0.0
- install topkg 1.1.0
- install tsort 2.2.0
- install uutf 1.0.4
- install yojson 3.0.0
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved astring.0.8.5 (cached)
-> retrieved alcotest.1.9.0 (cached)
-> retrieved backoff.0.1.1 (cached)
-> retrieved afl-persistent.1.4 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved camlp-streams.5.0.1 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> installed conf-bash.1
-> retrieved crowbar.0.2.1 (cached)
-> retrieved cppo.1.8.0 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved domain-local-await.1.0.1 (cached)
-> retrieved cstruct.6.2.0 (cached)
-> retrieved domain-local-timeout.1.0.1 (cached)
-> retrieved dscheck.0.5.0 (cached)
-> retrieved containers.3.16 (cached)
-> retrieved either.1.0.0 (cached)
-> retrieved fmt.0.11.0 (cached)
-> retrieved hmap.0.8.1 (cached)
-> retrieved iomux.0.3 (cached)
-> retrieved kcas.0.7.0 (cached)
-> retrieved logs.0.9.0 (cached)
-> retrieved lwt-dllist.1.1.0 (cached)
-> retrieved mtime.2.1.0 (cached)
-> retrieved multicore-magic.2.3.1 (cached)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocaml-version.4.0.1 (cached)
-> retrieved mdx.2.5.0 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved ocplib-endian.1.2 (cached)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved oseq.0.5.1 (cached)
-> retrieved optint.0.3.0 (cached)
-> retrieved psq.0.2.1 (cached)
-> retrieved result.1.5 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved re.1.13.2 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved thread-table.1.0.0 (cached)
-> retrieved tsort.2.2.0 (cached)
-> retrieved topkg.1.1.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved yojson.3.0.0 (cached)
-> retrieved dune.3.19.1, dune-configurator.3.19.1 (cached)
-> installed cmdliner.1.3.0
-> installed ocamlbuild.0.16.1
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed topkg.1.1.0
-> installed hmap.0.8.1
-> installed uutf.1.0.4
-> installed mtime.2.1.0
-> installed astring.0.8.5
-> installed fmt.0.11.0
-> installed logs.0.9.0
-> installed dune.3.19.1
-> installed csexp.1.5.2
-> installed afl-persistent.1.4
-> installed lwt-dllist.1.1.0
-> installed either.1.0.0
-> installed cstruct.6.2.0
-> installed cppo.1.8.0
-> installed camlp-streams.5.0.1
-> installed backoff.0.1.1
-> installed optint.0.3.0
-> installed ocaml-version.4.0.1
-> installed multicore-magic.2.3.1
-> installed ocplib-endian.1.2
-> installed oseq.0.5.1
-> installed ocaml-syntax-shims.1.0.0
-> installed psq.0.2.1
-> installed result.1.5
-> installed stdlib-shims.0.3.0
-> installed thread-table.1.0.0
-> installed crowbar.0.2.1
-> installed tsort.2.2.0
-> installed dune-configurator.3.19.1
-> installed domain-local-timeout.1.0.1
-> installed domain-local-await.1.0.1
-> installed re.1.13.2
-> installed bigstringaf.0.10.0
-> installed iomux.0.3
-> installed kcas.0.7.0
-> installed yojson.3.0.0
-> installed alcotest.1.9.0
-> installed containers.3.16
-> installed mdx.2.5.0
-> installed dscheck.0.5.0
Done.
<><> afl-persistent.1.4 installed successfully ><><><><><><><><><><><><><><><><>
=> afl-persistent is installed, but since the current OCaml compiler does
not enable AFL instrumentation by default, most packages will not be
instrumented and fuzzing with afl-fuzz may not be effective.
To globally enable AFL instrumentation, create an OCaml switch like:
opam switch create 5.3.0+afl ocaml-variants.5.3.0+options ocaml-option-afl
# To update the current shell environment, run: eval $(opam env)
2025-08-09 11:26.26 ---> saved as "3581fbdc0ac3fd6e4ed3894aaf04ba46c96e8035936dc32d445d4c0ac9834cb8"
/: (copy (src .) (dst ./src))
2025-08-09 11:26.27 ---> saved as "f07627191bb759a0a65dffdd62833bf979b77a852f28ca6f02c48ca6d4317ccf"
/: (run (shell "cd ./src && opam exec -- dune build --only-packages=eio_windows,eio_posix,eio_main,eio @install @check @runtest && rm -rf _build"))
(cd _build/default/fuzz && ./fuzz_inherit_fds.exe)
inherit_fds: PASS
(cd _build/default/fuzz && ./fuzz_buf_read.exe)
random ops: PASS
(cd _build/default/fuzz && ./fuzz_buf_write.exe)
random ops: PASS
2025-08-09 11:26.34 ---> saved as "f0e054c9fd2ccb52f163962ae5c85d4f621fb5d7f2ca9508c6f262e02e8318f9"
Job succeeded
2025-08-09 11:26.38: Job succeeded