2026-01-16 11:37.00: New job: test ocurrent/bun https://github.com/ocurrent/bun.git#refs/heads/primary (edb099ddce28a538412a62564b419879c278c403) (linux-x86_64:ubuntu-24.04-4.14_opam-2.5) Base: ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d Opam project build To reproduce locally: git clone --recursive "https://github.com/ocurrent/bun.git" -b "primary" && cd "bun" && git reset --hard edb099dd cat > Dockerfile <<'END-OF-DOCKERFILE' FROM ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d # ubuntu-24.04-4.14_opam-2.5 USER 1000:1000 ENV CLICOLOR_FORCE="1" ENV OPAMCOLOR="always" WORKDIR /src RUN sudo ln -f /usr/bin/opam-2.5 /usr/bin/opam RUN opam init --reinit -ni RUN uname -rs && opam exec -- ocaml -version && opam --version WORKDIR /src RUN sudo chown opam /src RUN cd ~/opam-repository && (git cat-file -e 873cb18c37b308713d11ad3894c4bb78d73fb3e7 || git fetch origin master) && git reset -q --hard 873cb18c37b308713d11ad3894c4bb78d73fb3e7 && git log --no-decorate -n1 --oneline && opam update -u COPY --chown=1000:1000 bun.opam ./ RUN opam pin add -yn bun.dev './' RUN echo '(lang dune 3.0)' > './dune-project' ENV DEPS="afl.2.52b afl-persistent.1.4 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base bos.0.2.1 cmdliner.2.1.0 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 dune.3.21.0 dune-configurator.3.21.0 fmt.0.11.0 fpath.0.7.3 logs.0.10.0 lwt.6.0.0 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 rresult.0.7.0 topkg.1.1.1" ENV CI="true" ENV OCAMLCI="true" RUN opam update --depexts && opam install --cli=2.5 --depext-only -y bun.dev $DEPS RUN opam install $DEPS COPY --chown=1000:1000 . /src RUN opam exec -- dune build @install @check @runtest && rm -rf _build END-OF-DOCKERFILE docker build . END-REPRO-BLOCK 2026-01-16 11:37.00: Using cache hint "ocurrent/bun-ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d-ubuntu-24.04-4.14_opam-2.5-ea96a1d6ff66001b24ea88807bbcc281" 2026-01-16 11:37.00: Using OBuilder spec: ((from ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d) (comment ubuntu-24.04-4.14_opam-2.5) (user (uid 1000) (gid 1000)) (env CLICOLOR_FORCE 1) (env OPAMCOLOR always) (workdir /src) (run (shell "sudo ln -f /usr/bin/opam-2.5 /usr/bin/opam")) (run (shell "opam init --reinit -ni")) (run (shell "uname -rs && opam exec -- ocaml -version && opam --version")) (workdir /src) (run (shell "sudo chown opam /src")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "cd ~/opam-repository && (git cat-file -e 873cb18c37b308713d11ad3894c4bb78d73fb3e7 || git fetch origin master) && git reset -q --hard 873cb18c37b308713d11ad3894c4bb78d73fb3e7 && git log --no-decorate -n1 --oneline && opam update -u")) (copy (src bun.opam) (dst ./)) (run (network host) (shell "opam pin add -yn bun.dev './'")) (run (network host) (shell "echo '(lang dune 3.0)' > './dune-project'")) (env DEPS "afl.2.52b afl-persistent.1.4 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base bos.0.2.1 cmdliner.2.1.0 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 dune.3.21.0 dune-configurator.3.21.0 fmt.0.11.0 fpath.0.7.3 logs.0.10.0 lwt.6.0.0 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 rresult.0.7.0 topkg.1.1.1") (env CI true) (env OCAMLCI true) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update --depexts && opam install --cli=2.5 --depext-only -y bun.dev $DEPS")) (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam install $DEPS")) (copy (src .) (dst /src)) (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build")) ) 2026-01-16 11:37.00: Waiting for resource in pool OCluster 2026-01-16 12:24.03: Waiting for worker… 2026-01-16 12:28.04: Got resource from pool OCluster Building on eumache All commits already cached HEAD is now at edb099d Merge pull request #32 from ocurrent/revert-31-patch-1 (from ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d) Unable to find image 'ocaml/opam:ubuntu-24.04-ocaml-4.14@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d' locally docker.io/ocaml/opam@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d: Pulling from ocaml/opam 20043066d3d5: Already exists 74a201e1c126: Already exists d63bb9fbbf86: Already exists 9467c6371b02: Already exists 404716bfcac3: Already exists fed733e23844: Already exists 707d11c2eefa: Already exists 399e5b85a0fc: Already exists d0bd8a3f061c: Already exists a49e067103b6: Already exists 564fcb11fd5c: Already exists b54d000bca39: Already exists 1022f2c60c0e: Already exists d0473c037ed5: Already exists b4b0a2839de5: Already exists f95ab9582825: Already exists 20d40f2e0f67: Already exists 20d40f2e0f67: Already exists 7e5f024df647: Already exists d39cb8682827: Already exists 72072a576a9f: Already exists 7b230cb3ef48: Already exists 4f4fb700ef54: Already exists 23c320078945: Already exists 8f7a7c3573c5: Already exists 1564848c4b7b: Already exists cc7ba7d9e277: Already exists 14120930af46: Already exists baa80d4afe8f: Already exists 68007a21c1c4: Already exists d2df30cde401: Already exists f21ee1a89225: Already exists fde2d5a241cf: Already exists 6d474fa3c976: Already exists a45b9e268599: Already exists fb9fa892ed79: Already exists ba013a08453d: Already exists 9be3559c7d84: Already exists 57e25f9db71c: Already exists ade4c34ce8e6: Already exists 7ad8fb0274dc: Already exists 9938feee8fe6: Already exists 8e8b4e5d5c39: Already exists f4499fee2455: Already exists b28e8701a421: Already exists Digest: sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d Status: Downloaded newer image for ocaml/opam@sha256:0acc50675a0605f7ee55b7f8d24695d91093a2873644ca50c93aa04d51508d0d 2026-01-16 12:28.04 ---> using "8e09f142ca4c8b9565a6c3a204c9c7517ea1af6e151cb81a7b7a04b2b0967b6a" from cache /: (comment ubuntu-24.04-4.14_opam-2.5) /: (user (uid 1000) (gid 1000)) /: (env CLICOLOR_FORCE 1) /: (env OPAMCOLOR always) /: (workdir /src) /src: (run (shell "sudo ln -f /usr/bin/opam-2.5 /usr/bin/opam")) 2026-01-16 12:28.04 ---> using "f325c0c2183638b636db8a2f91be5e39de6f57e84d62e0ce8dc9a6251900cc44" from cache /src: (run (shell "opam init --reinit -ni")) Configuring from /home/opam/.opamrc and then from 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 /home/opam/.opam from version 2.0 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 255 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=255 --global Format upgrade done. <><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><> [default] Initialised 2026-01-16 12:28.04 ---> using "df24b76d0250e0ea71ceefb6d8f72a47d0814044fd65d400c9e0d48210be8513" from cache /src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version")) Linux 5.15.0-131-generic The OCaml toplevel, version 4.14.2 2.5.0 2026-01-16 12:28.04 ---> using "780cd0436a1463041a6e02c287c8134bac0bb8a0263f925bee9e6eed14cef8fc" from cache /src: (workdir /src) /src: (run (shell "sudo chown opam /src")) 2026-01-16 12:28.04 ---> using "cee6b822f8c3b2846ee95a2109a23189a410379c16461e164d03506cd1852976" from cache /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "cd ~/opam-repository && (git cat-file -e 873cb18c37b308713d11ad3894c4bb78d73fb3e7 || git fetch origin master) && git reset -q --hard 873cb18c37b308713d11ad3894c4bb78d73fb3e7 && git log --no-decorate -n1 --oneline && opam update -u")) From https://github.com/ocaml/opam-repository * branch master -> FETCH_HEAD 235b964523..873cb18c37 master -> origin/master 873cb18c37 Merge pull request #29216 from shonfeder/release-dune-3.21.0 <><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><> [default] synchronised from git+file:///home/opam/opam-repository Everything as up-to-date as possible (run with --verbose to show unavailable upgrades). However, you may "opam upgrade" these packages explicitly at these versions (e.g. "opam upgrade ocaml.5.4.0"), which will ask permission to downgrade or uninstall the conflicting packages. Nothing to do. # To update the current shell environment, run: eval $(opam env) 2026-01-16 12:28.04 ---> using "ff10ecb93c652de8e72d8afebbc6323054adfc57283296e86f9137eb06ecdf04" from cache /src: (copy (src bun.opam) (dst ./)) 2026-01-16 12:28.05 ---> saved as "db2d3beafcf1731ea53da5843f9ce83864d05d753d06acba79370d66e1183974" /src: (run (network host) (shell "opam pin add -yn bun.dev './'")) [bun.dev] synchronised (file:///src) bun is now pinned to file:///src (version dev) 2026-01-16 12:28.09 ---> saved as "d2aaa4b049ddaaa94386b00e5c1aa36b87a5ae42b2c1f86d65a650590a57e09b" /src: (run (network host) (shell "echo '(lang dune 3.0)' > './dune-project'")) 2026-01-16 12:28.09 ---> saved as "2d326f0920a4e187b2db9a7add4753074c92ab57534deef98c33a6e8f3c1668d" /src: (env DEPS "afl.2.52b afl-persistent.1.4 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base bos.0.2.1 cmdliner.2.1.0 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 dune.3.21.0 dune-configurator.3.21.0 fmt.0.11.0 fpath.0.7.3 logs.0.10.0 lwt.6.0.0 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 rresult.0.7.0 topkg.1.1.1") /src: (env CI true) /src: (env OCAMLCI true) /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (network host) (shell "opam update --depexts && opam install --cli=2.5 --depext-only -y bun.dev $DEPS")) + /usr/bin/sudo "apt-get" "update" - Get:1 http://security.ubuntu.com/ubuntu noble-security InRelease [126 kB] - Hit:2 http://archive.ubuntu.com/ubuntu noble InRelease - Get:3 http://archive.ubuntu.com/ubuntu noble-updates InRelease [126 kB] - Get:4 http://archive.ubuntu.com/ubuntu noble-backports InRelease [126 kB] - Get:5 http://security.ubuntu.com/ubuntu noble-security/main amd64 Packages [1769 kB] - Get:6 http://security.ubuntu.com/ubuntu noble-security/universe amd64 Packages [1189 kB] - Get:7 http://security.ubuntu.com/ubuntu noble-security/restricted amd64 Packages [2919 kB] - Get:8 http://archive.ubuntu.com/ubuntu noble-updates/main amd64 Packages [2142 kB] - Get:9 http://archive.ubuntu.com/ubuntu noble-updates/universe amd64 Packages [1956 kB] - Get:10 http://archive.ubuntu.com/ubuntu noble-updates/restricted amd64 Packages [3077 kB] - Fetched 13.4 MB in 2s (8288 kB/s) - Reading package lists... - <><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><> [bun.dev] synchronised (file:///src) [NOTE] Package ocaml-options-vanilla is already installed (current version is 1). [NOTE] Package ocaml-config is already installed (current version is 2). [NOTE] Package ocaml-base-compiler is already installed (current version is 4.14.2). [NOTE] Package ocaml is already installed (current version is 4.14.2). [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-bigarray is already installed (current version is base). # To update the current shell environment, run: eval $(opam env) 2026-01-16 12:28.28 ---> saved as "e8b619dfb60cb7096e01ed1943cb716607971a2a8e18ba980a41c3acd1cf9043" /src: (run (cache (opam-archives (target /home/opam/.opam/download-cache))) (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 2). [NOTE] Package ocaml-base-compiler is already installed (current version is 4.14.2). [NOTE] Package ocaml is already installed (current version is 4.14.2). [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-bigarray is already installed (current version is base). The following actions will be performed: === install 20 packages - install afl 2.52b - install afl-persistent 1.4 - install astring 0.8.5 - install base-bytes base - install bos 0.2.1 - install cmdliner 2.1.0 - install cppo 1.8.0 - install crowbar 0.2.2 - install csexp 1.5.2 - install dune 3.21.0 - install dune-configurator 3.21.0 - install fmt 0.11.0 - install fpath 0.7.3 - install logs 0.10.0 - install lwt 6.0.0 - install ocamlbuild 0.16.1 - install ocamlfind 1.9.8 - install ocplib-endian 1.2 - install rresult 0.7.0 - install topkg 1.1.1 <><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><> -> retrieved afl.2.52b (cached) -> retrieved afl-persistent.1.4 (cached) -> retrieved astring.0.8.5 (cached) -> retrieved bos.0.2.1 (cached) -> retrieved cppo.1.8.0 (cached) -> retrieved cmdliner.2.1.0 (cached) -> retrieved crowbar.0.2.2 (cached) -> retrieved csexp.1.5.2 (cached) -> retrieved fmt.0.11.0 (cached) -> retrieved fpath.0.7.3 (cached) -> retrieved logs.0.10.0 (cached) -> retrieved lwt.6.0.0 (cached) -> retrieved ocamlbuild.0.16.1 (cached) -> retrieved ocamlfind.1.9.8 (cached) -> retrieved ocplib-endian.1.2 (cached) -> retrieved rresult.0.7.0 (cached) -> retrieved topkg.1.1.1 (cached) -> retrieved dune.3.21.0, dune-configurator.3.21.0 (cached) -> installed cmdliner.2.1.0 -> installed ocamlbuild.0.16.1 -> installed afl.2.52b -> installed ocamlfind.1.9.8 -> installed base-bytes.base -> installed topkg.1.1.1 -> installed rresult.0.7.0 -> installed fmt.0.11.0 -> installed astring.0.8.5 -> installed fpath.0.7.3 -> installed dune.3.21.0 -> installed afl-persistent.1.4 -> installed csexp.1.5.2 -> installed cppo.1.8.0 -> installed crowbar.0.2.2 -> installed ocplib-endian.1.2 -> installed dune-configurator.3.21.0 -> installed lwt.6.0.0 -> installed logs.0.10.0 -> installed bos.0.2.1 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 4.14.2+afl ocaml-variants.4.14.2+options ocaml-option-afl # To update the current shell environment, run: eval $(opam env) 2026-01-16 12:29.35 ---> saved as "ebe41e82f07c1ccc33b4547712e348a8254c870f2b03f45709b3127d5515da9c" /src: (copy (src .) (dst /src)) 2026-01-16 12:29.35 ---> saved as "7a8eed5716515cd1eb5fa81344bc049c6f352e52822cef2cf712257260787541" /src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build")) (cd _build/default/test && /usr/bin/bash -e -u -o pipefail -c '! timeout 30s ../src/bun.exe -vv --max-cores=2 ./short.exe') > _build/default/test/shorttest-output 12:29.37:[EXEC:55]['afl-gotcpu'] 12:29.37:[EXEC:56]['grep' 'more processes on '] 12:29.38:[DEBUG]cores line: 3 to 27 cores. <<< 12:29.38:[INFO]2 available cores detected! 12:29.38:[INFO]Executing /home/opam/.opam/4.14/bin/afl-fuzz -m 200 -i input -o output -M 1 -- ./short.exe @@ 12:29.38:[INFO]/home/opam/.opam/4.14/bin/afl-fuzz launched: PID 129 12:29.38:[INFO]Executing /home/opam/.opam/4.14/bin/afl-fuzz -m 200 -i input -o output -S 2 -- ./short.exe @@ 12:29.38:[INFO]/home/opam/.opam/4.14/bin/afl-fuzz launched: PID 130 12:29.38:[EXEC:138]['base64' '-w' '0' 'output/2/crashes/id:000000,sig:06,src:000000,op:havoc,rep:32'] 12:29.38:[INFO]Terminating fuzzer 1 (pid=129) 12:29.38:[INFO]Fuzzer 1 (pid=129) shut down, as requested bun: All fuzzers finished, but some crashes were found! (cd _build/default/test && /usr/bin/bash -e -u -o pipefail -c 'grep '\''Crashes found!'\'' shorttest-output || (cat shorttest-output; echo FAILED; exit 1)') Crashes found! Take a look; copy/paste to save for reproduction: 12:29.38:Fuzzers launched: [1 (pid=129); 2 (pid=130)]. afl-fuzz 2.52b by <lcamtuf@google.com> [+] Disabling the UI because AFL_NO_UI is set. [+] You have 72 CPU cores and 74 runnable tasks (utilization: 103%). [!] WARNING: Not binding to a CPU core (AFL_NO_AFFINITY set). [*] Checking core_pattern... [*] Setting up output directories... [*] Scanning 'input'... [+] No auto-generated dictionary tokens to reuse. [*] Creating hard links for all input files... [*] Validating target binary... [+] Persistent mode binary detected. [*] Attempting dry run with 'id:000000,orig:bun_autogenerated_seed'... [*] Spinning up the fork server... [+] All right - fork server is up. len = 396, map size = 1, exec speed = 297 us [+] All test cases processed. [+] Here are some useful stats: Test case count : 1 favored, 0 variable, 1 total Bitmap range : 1 to 1 bits (average: 1.00 bits) Exec timing : 297 to 297 us (average: 297 us) [*] No -t option specified, so I'll use exec timeout of 20 ms. [+] All set and ready to roll! [*] Entering queue cycle 1. [*] Fuzzing test case #0 (1 total, 0 uniq crashes found)... afl-fuzz 2.52b by <lcamtuf@google.com> [+] Disabling the UI because AFL_NO_UI is set. [+] You have 72 CPU cores and 74 runnable tasks (utilization: 103%). [!] WARNING: Not binding to a CPU core (AFL_NO_AFFINITY set). [*] Checking core_pattern... [*] Setting up output directories... [*] Scanning 'input'... [+] No auto-generated dictionary tokens to reuse. [*] Creating hard links for all input files... [*] Validating target binary... [+] Persistent mode binary detected. [*] Attempting dry run with 'id:000000,orig:bun_autogenerated_seed'... [*] Spinning up the fork server... [+] All right - fork server is up. len = 396, map size = 1, exec speed = 292 us [+] All test cases processed. [+] Here are some useful stats: Test case count : 1 favored, 0 variable, 1 total Bitmap range : 1 to 1 bits (average: 1.00 bits) Exec timing : 292 to 292 us (average: 292 us) [*] No -t option specified, so I'll use exec timeout of 20 ms. [+] All set and ready to roll! [*] Entering queue cycle 1. [*] Fuzzing test case #0 (1 total, 0 uniq crashes found)... [*] Entering queue cycle 2. [*] Fuzzing test case #0 (1 total, 0 uniq crashes found)... [*] Entering queue cycle 3. [*] Fuzzing test case #0 (1 total, 1 uniq crashes found)... [*] Entering queue cycle 4. [*] Fuzzing test case #0 (1 total, 1 uniq crashes found)... +++ Testing aborted programmatically +++ [+] We're done here. Have a nice day! 12:29.38:Fuzzer 2 (pid=130) finished Crashes found! Take a look; copy/paste to save for reproduction: echo AAAAAAAAAAAAAAAAAAAAAAAgAAAAIAAAAAAAAQAAAIAAAAAgAQAAFgABEABkAP/i | base64 -d > crash_0.$(date -u +%s) 2026-01-16 12:29.38 ---> saved as "6f8c2f5515744e2bdc3942b3734151cf90155230d397391fb7720deccc0dd985" Job succeeded 2026-01-16 12:29.38: Job succeeded