(for PR #29582)
2026-03-25 13:14.40: New job: test yuujinchou.5.0.1 with ocaml-compiler.5.4.0, using opam dev
from https://github.com/ocaml/opam-repository.git#refs/pull/29582/head (fa5fb3a6a806e832e4c7791145889a6bbe8b64ef)
on debian-13-ocaml-5.4/amd64
To reproduce locally:
cd $(mktemp -d)
git clone --recursive "https://github.com/ocaml/opam-repository.git" && cd "opam-repository" && git fetch origin "refs/pull/29582/head" && git reset --hard fa5fb3a6
git fetch origin master
git merge --no-edit 2f93e9d4614d6376ed929fc2cee7c59cb9d5833b
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-5.4@sha256:bd342cbd7766c453282fdafbc2e565ae3361320ec344722cf4372b782e4a97f6
USER 1000:1000
WORKDIR /home/opam
RUN sudo ln -f /usr/bin/opam-dev /usr/bin/opam
RUN opam init --reinit -ni
RUN opam option solver=builtin-0install && opam config report
ENV OPAMDOWNLOADJOBS="1"
ENV OPAMERRLOGLEN="0"
ENV OPAMPRECISETRACKING="1"
ENV CI="true"
ENV OPAM_REPO_CI="true"
RUN rm -rf opam-repository/
COPY --chown=1000:1000 . opam-repository/
RUN opam repository set-url --strict default opam-repository/
RUN opam update --depexts || true
RUN opam pin add -k version -yn ocaml-compiler.5.4.0 5.4.0
RUN opam reinstall --update-invariant ocaml-compiler.5.4.0; \
res=$?; \
test "$res" != 31 && exit "$res"; \
export OPAMCLI=2.0; \
build_dir=$(opam var prefix)/.opam-switch/build; \
failed=$(ls "$build_dir"); \
partial_fails=""; \
for pkg in $failed; do \
if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"debian-13\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'ocaml-compiler.5.4.0' && partial_fails="$partial_fails $pkg"; \
done; \
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
exit 1
RUN opam reinstall yuujinchou.5.0.1; \
res=$?; \
test "$res" != 31 && exit "$res"; \
export OPAMCLI=2.0; \
build_dir=$(opam var prefix)/.opam-switch/build; \
failed=$(ls "$build_dir"); \
partial_fails=""; \
for pkg in $failed; do \
if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"debian-13\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'yuujinchou.5.0.1' && partial_fails="$partial_fails $pkg"; \
done; \
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
exit 1
RUN (opam reinstall --with-test yuujinchou.5.0.1) || true
RUN opam reinstall --with-test --verbose yuujinchou.5.0.1; \
res=$?; \
test "$res" != 31 && exit "$res"; \
export OPAMCLI=2.0; \
build_dir=$(opam var prefix)/.opam-switch/build; \
failed=$(ls "$build_dir"); \
partial_fails=""; \
for pkg in $failed; do \
if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"debian-13\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'yuujinchou.5.0.1' && partial_fails="$partial_fails $pkg"; \
done; \
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
exit 1
END-OF-DOCKERFILE
docker build -f ../Dockerfile .
2026-03-25 13:14.40: Using cache hint "ocaml/opam:debian-13-ocaml-5.4@sha256:bd342cbd7766c453282fdafbc2e565ae3361320ec344722cf4372b782e4a97f6-ocaml-compiler.5.4.0-yuujinchou.5.0.1-fa5fb3a6a806e832e4c7791145889a6bbe8b64ef"
2026-03-25 13:14.40: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-5.4@sha256:bd342cbd7766c453282fdafbc2e565ae3361320ec344722cf4372b782e4a97f6)
(user (uid 1000) (gid 1000))
(workdir /home/opam)
(run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
(run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
(run (shell "opam option solver=builtin-0install && opam config report"))
(env OPAMDOWNLOADJOBS 1)
(env OPAMERRLOGLEN 0)
(env OPAMPRECISETRACKING 1)
(env CI true)
(env OPAM_REPO_CI true)
(run (shell "rm -rf opam-repository/"))
(copy (src .) (dst opam-repository/))
(run (shell "opam repository set-url --strict default opam-repository/"))
(run (network host)
(shell "opam update --depexts || true"))
(run (shell "opam pin add -k version -yn ocaml-compiler.5.4.0 5.4.0"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall --update-invariant ocaml-compiler.5.4.0;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'ocaml-compiler.5.4.0' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall yuujinchou.5.0.1;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'yuujinchou.5.0.1' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
(run (network host)
(shell "(opam reinstall --with-test yuujinchou.5.0.1) || true"))
(run (shell "opam reinstall --with-test --verbose yuujinchou.5.0.1;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'yuujinchou.5.0.1' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
)
2026-03-25 13:14.40: Waiting for resource in pool OCluster
2026-03-25 17:53.31: Waiting for worker…
2026-03-25 17:57.01: Got resource from pool OCluster
Building on clete.caelum.ci.dev
All commits already cached
Updating files: 65% (12213/18520)
Updating files: 66% (12224/18520)
Updating files: 67% (12409/18520)
Updating files: 68% (12594/18520)
Updating files: 69% (12779/18520)
Updating files: 70% (12964/18520)
Updating files: 71% (13150/18520)
Updating files: 72% (13335/18520)
Updating files: 73% (13520/18520)
Updating files: 74% (13705/18520)
Updating files: 75% (13890/18520)
Updating files: 76% (14076/18520)
Updating files: 77% (14261/18520)
Updating files: 78% (14446/18520)
Updating files: 79% (14631/18520)
Updating files: 80% (14816/18520)
Updating files: 81% (15002/18520)
Updating files: 82% (15187/18520)
Updating files: 83% (15372/18520)
Updating files: 84% (15557/18520)
Updating files: 85% (15742/18520)
Updating files: 86% (15928/18520)
Updating files: 87% (16113/18520)
Updating files: 88% (16298/18520)
Updating files: 89% (16483/18520)
Updating files: 90% (16668/18520)
Updating files: 91% (16854/18520)
Updating files: 92% (17039/18520)
Updating files: 93% (17224/18520)
Updating files: 94% (17409/18520)
Updating files: 95% (17594/18520)
Updating files: 96% (17780/18520)
Updating files: 97% (17965/18520)
Updating files: 98% (18150/18520)
Updating files: 99% (18335/18520)
Updating files: 100% (18520/18520)
Updating files: 100% (18520/18520), done.
HEAD is now at 2f93e9d461 Merge pull request #29592 from dinosaure/release-miou-v0.5.5
Merge made by the 'ort' strategy.
packages/ocaml-compiler/ocaml-compiler.5.3.0/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.3/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.4.0/opam | 5 ++++-
.../ocaml-compiler/ocaml-compiler.5.4.0~alpha1/opam | 5 ++++-
.../ocaml-compiler/ocaml-compiler.5.4.0~beta1/opam | 5 ++++-
.../ocaml-compiler/ocaml-compiler.5.4.0~beta2/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.4.0~rc1/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.4.1/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.4/opam | 5 ++++-
.../ocaml-compiler/ocaml-compiler.5.5.0~alpha1/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.5/opam | 5 ++++-
packages/ocaml-compiler/ocaml-compiler.5.6/opam | 5 ++++-
packages/ocaml-option-llvm/ocaml-option-llvm.1/opam | 18 ++++++++++++++++++
.../ocaml-options-vanilla/ocaml-options-vanilla.1/opam | 1 +
packages/ocaml-variants/ocaml-variants.5.2.0+msvc/opam | 2 ++
15 files changed, 69 insertions(+), 12 deletions(-)
create mode 100644 packages/ocaml-option-llvm/ocaml-option-llvm.1/opam
(from ocaml/opam:debian-13-ocaml-5.4@sha256:bd342cbd7766c453282fdafbc2e565ae3361320ec344722cf4372b782e4a97f6)
2026-03-25 17:57.07 ---> using "41eea30e3f639c18d8cf57c309ec76919ec7b2398036f7e41744cbce59a133d3" from cache
/: (user (uid 1000) (gid 1000))
/: (workdir /home/opam)
/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2026-03-25 17:57.07 ---> using "4ad7f430d684c40cedc651267e0edf890c044fe4e624255de377c471b4526bac" from cache
/home/opam: (run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
Configuring from /home/opam/.opamrc-sandbox, then /home/opam/.opamrc, and finally 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
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-03-25 17:57.07 ---> using "71fa58e52457bf6a7eac317c6a6ef1e2bdf53e533a1e4fd04b90c9349347e038" from cache
/home/opam: (run (shell "opam option solver=builtin-0install && opam config report"))
Set to 'builtin-0install' the field solver in global configuration
# opam config report
# opam-version 2.5.0
# self-upgrade no
# system arch=x86_64 os=linux os-distribution=debian os-version=13
# solver builtin-0install
# install-criteria -changed,-count[avoid-version,solution]
# upgrade-criteria -count[avoid-version,solution]
# jobs 71
# repositories 1 (version-controlled)
# pinned 1 (version)
# current-switch 5.4
# invariant ["ocaml-base-compiler" {= "5.4.0"}]
# compiler-packages ocaml-base-compiler.5.4.0, ocaml-compiler.5.4.0, ocaml-options-vanilla.1
# ocaml:native true
# ocaml:native-tools true
# ocaml:native-dynlink true
# ocaml:stubsdir /home/opam/.opam/5.4/lib/ocaml/stublibs:/home/opam/.opam/5.4/lib/ocaml
# ocaml:preinstalled false
# ocaml:compiler 5.4.0
2026-03-25 17:57.07 ---> using "ed86081cb38ca125a920162bfe6a4bb7b1c27c6973c917551687c83cf44dbfdf" from cache
/home/opam: (env OPAMDOWNLOADJOBS 1)
/home/opam: (env OPAMERRLOGLEN 0)
/home/opam: (env OPAMPRECISETRACKING 1)
/home/opam: (env CI true)
/home/opam: (env OPAM_REPO_CI true)
/home/opam: (run (shell "rm -rf opam-repository/"))
2026-03-25 17:57.07 ---> using "04a48515eea40c32b96da0c71328b4bba0edb66eed83d4f78554b39097cf1f25" from cache
/home/opam: (copy (src .) (dst opam-repository/))
2026-03-25 17:57.09 ---> using "034191995d824300f355cbba1072d6e5fe6d815701f24eb84d82c75009d73829" from cache
/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-03-25 17:57.09 ---> using "8232259ea36ea8848dc29ae49703acf145fd27b40f3ebd8fb785db7f8da1b9d4" from cache
/home/opam: (run (network host)
(shell "opam update --depexts || true"))
+ /usr/bin/sudo "apt-get" "update"
- Get:1 http://deb.debian.org/debian trixie InRelease [140 kB]
- Get:2 http://deb.debian.org/debian trixie-updates InRelease [47.3 kB]
- Get:3 http://deb.debian.org/debian-security trixie-security InRelease [43.4 kB]
- Get:4 http://deb.debian.org/debian trixie/main amd64 Packages [9671 kB]
- Get:5 http://deb.debian.org/debian-security trixie-security/main amd64 Packages [114 kB]
- Fetched 10.0 MB in 1s (6734 kB/s)
- Reading package lists...
-
2026-03-25 17:57.09 ---> using "a75782a571df4fc8f8933e94c681af881015ee87cdd4c652f8ae9af1d8cfad37" from cache
/home/opam: (run (shell "opam pin add -k version -yn ocaml-compiler.5.4.0 5.4.0"))
ocaml-compiler is now pinned to version 5.4.0
2026-03-25 17:57.09 ---> using "60e129f7398974b5fa5afc8f56ec09bd24a9182f5e9834464bfc959db1aa6b14" from cache
/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall --update-invariant ocaml-compiler.5.4.0;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'ocaml-compiler.5.4.0' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
The following actions will be performed:
=== recompile 8 packages
- recompile base-domains base [uses ocaml]
- recompile base-effects base [uses ocaml]
- recompile base-nnp base [uses base-domains]
- recompile ocaml 5.4.0 [uses ocaml-base-compiler]
- recompile ocaml-base-compiler 5.4.0 (pinned) [uses ocaml-compiler]
- recompile ocaml-compiler 5.4.0 (pinned)
- recompile ocaml-config 3 [uses ocaml-base-compiler]
- recompile opam-depext 1.2.3 [uses ocaml]
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved ocaml-compiler.5.4.0 (cached)
-> retrieved ocaml-config.3 (cached)
-> retrieved opam-depext.1.2.3 (cached)
-> removed base-effects.base
-> removed base-nnp.base
-> removed base-domains.base
-> removed opam-depext.1.2.3
-> removed ocaml.5.4.0
-> removed ocaml-config.3
-> removed ocaml-base-compiler.5.4.0
-> removed ocaml-compiler.5.4.0
-> installed ocaml-compiler.5.4.0
-> installed ocaml-base-compiler.5.4.0
-> installed ocaml-config.3
-> installed ocaml.5.4.0
-> installed base-domains.base
-> installed base-effects.base
-> installed base-nnp.base
-> installed opam-depext.1.2.3
Done.
<><> opam-depext.1.2.3 installed successfully <><><><><><><><><><><><><><><><><>
=> opam-depext is unnecessary when used with opam >= 2.1. Please use opam install directly instead
# To update the current shell environment, run: eval $(opam env)
2026-03-25 17:59.56 ---> saved as "efbc92fc0c607605c8bb33f9e4c8fe340a48c67e14d2f61592db8a4edc5c0b15"
/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam reinstall yuujinchou.5.0.1;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'yuujinchou.5.0.1' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
yuujinchou.5.0.1 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 4 packages
- install algaeff 1.1.0 [required by yuujinchou]
- install bwd 2.3.0 [required by yuujinchou]
- install dune 3.22.0 [required by yuujinchou]
- install yuujinchou 5.0.1
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved algaeff.1.1.0 (cached)
-> retrieved bwd.2.3.0 (cached)
-> retrieved dune.3.22.0 (cached)
-> retrieved yuujinchou.5.0.1 (https://opam.ocaml.org/cache)
-> installed dune.3.22.0
-> installed algaeff.1.1.0
-> installed bwd.2.3.0
-> installed yuujinchou.5.0.1
Done.
# To update the current shell environment, run: eval $(opam env)
2026-03-25 18:01.53 ---> saved as "b0524b555292cbd8100996f3803159245a0580ccbe65e68720746e406bf831aa"
/home/opam: (run (network host)
(shell "(opam reinstall --with-test yuujinchou.5.0.1) || true"))
The following actions will be performed:
=== recompile 1 package
- recompile yuujinchou 5.0.1
=== install 12 packages
- install alcotest 1.9.1 [required by yuujinchou]
- install astring 0.8.5 [required by alcotest]
- install cmdliner 2.1.0 [required by alcotest]
- install fmt 0.11.0 [required by alcotest]
- install ocaml-syntax-shims 1.0.0 [required by alcotest]
- install ocamlbuild 0.16.1 [required by fmt, astring, uutf]
- install ocamlfind 1.9.8 [required by fmt, astring, uutf]
- install qcheck-core 0.91 [required by yuujinchou]
- install re 1.14.0 [required by alcotest]
- install stdlib-shims 0.3.0 [required by alcotest]
- install topkg 1.1.1 [required by fmt, astring, uutf]
- install uutf 1.0.4 [required by alcotest]
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved alcotest.1.9.1 (https://opam.ocaml.org/cache)
-> retrieved astring.0.8.5 (https://opam.ocaml.org/cache)
-> retrieved cmdliner.2.1.0 (https://opam.ocaml.org/cache)
-> retrieved fmt.0.11.0 (https://opam.ocaml.org/cache)
-> retrieved ocaml-syntax-shims.1.0.0 (https://opam.ocaml.org/cache)
-> retrieved ocamlbuild.0.16.1 (https://opam.ocaml.org/cache)
-> retrieved ocamlfind.1.9.8 (https://opam.ocaml.org/cache)
-> retrieved qcheck-core.0.91 (https://opam.ocaml.org/cache)
-> retrieved re.1.14.0 (https://opam.ocaml.org/cache)
-> retrieved stdlib-shims.0.3.0 (https://opam.ocaml.org/cache)
-> retrieved topkg.1.1.1 (https://opam.ocaml.org/cache)
-> retrieved uutf.1.0.4 (https://opam.ocaml.org/cache)
-> retrieved yuujinchou.5.0.1 (https://opam.ocaml.org/cache)
-> installed stdlib-shims.0.3.0
-> installed ocaml-syntax-shims.1.0.0
-> installed re.1.14.0
-> installed qcheck-core.0.91
-> installed ocamlfind.1.9.8
-> installed cmdliner.2.1.0
-> removed yuujinchou.5.0.1
-> installed ocamlbuild.0.16.1
-> installed topkg.1.1.1
-> installed fmt.0.11.0
-> installed uutf.1.0.4
-> installed astring.0.8.5
-> installed alcotest.1.9.1
-> installed yuujinchou.5.0.1
Done.
# To update the current shell environment, run: eval $(opam env)
2026-03-25 18:03.02 ---> saved as "d7e6919d2e3dd2c3d2eaa8a1f6d420a17d9a5bfb0b4f0634034cd0acbc647e74"
/home/opam: (run (shell "opam reinstall --with-test --verbose yuujinchou.5.0.1;\
\n res=$?;\
\n test \"$res\" != 31 && exit \"$res\";\
\n export OPAMCLI=2.0;\
\n build_dir=$(opam var prefix)/.opam-switch/build;\
\n failed=$(ls \"$build_dir\");\
\n partial_fails=\"\";\
\n for pkg in $failed; do\
\n if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"debian-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'yuujinchou.5.0.1' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
The following actions will be performed:
=== recompile 1 package
- recompile yuujinchou 5.0.1
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing 1/4: [yuujinchou.5.0.1: extract]
-> retrieved yuujinchou.5.0.1 (cached)
Processing 2/4: [yuujinchou: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "yuujinchou" "-j" "71" (CWD=/home/opam/.opam/5.4/.opam-switch/build/yuujinchou.5.0.1)
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlc.opt -w -40 -g -bin-annot -bin-annot-occurrences -I src/.Yuujinchou.objs/byte -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Trie.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/byte/yuujinchou__Trie.cmo -c -impl src/Trie.ml)
- File "src/Trie.ml", line 228, characters 47-49:
- 228 | let d, t = union_node ~prefix:(prefix #< seg) m (d1, t1) (d2, t2) in
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "src/Trie.ml", line 241, characters 58-61:
- 241 | update_cont path v1 @@ fun v1 -> union_ ~prefix:(prefix <>< path) m v1 v2
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "src/Trie.ml", line 253, characters 62-65:
- 253 | update_cont path v1 @@ fun v1 -> union_root ~prefix:(prefix <>< path) m v1 v2
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "src/Trie.ml", line 280, characters 52-54:
- 280 | SegMap.iter (fun seg -> iter_node ~prefix:(prefix #< seg) f) (get_children_node n)
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "src/Trie.ml", line 287, characters 66-68:
- 287 | SegMap.filter_map (fun seg -> filter_map_node ~prefix:(prefix #< seg) f) (get_children_node n)
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlc.opt -w -40 -g -bin-annot -bin-annot-occurrences -I src/.Yuujinchou.objs/byte -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Scope.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/byte/yuujinchou__Scope.cmo -c -impl src/Scope.ml)
- File "src/Scope.ml", line 89, characters 51-54:
- 89 | Internal.run ~export_prefix:(export_prefix() <>< p) ~init_visible:(S.get()).visible @@ fun () ->
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlc.opt -w -40 -g -bin-annot -bin-annot-occurrences -I src/.Yuujinchou.objs/byte -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Modifier.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/byte/yuujinchou__Modifier.cmo -c -impl src/Modifier.ml)
- File "src/Modifier.ml", line 53, characters 42-45:
- 53 | Trie.update_subtree p (go (prefix <>< p) m) t
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Trie.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/native/yuujinchou__Trie.cmx -c -impl src/Trie.ml)
- File "src/Trie.ml", line 228, characters 47-49:
- 228 | let d, t = union_node ~prefix:(prefix #< seg) m (d1, t1) (d2, t2) in
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "src/Trie.ml", line 241, characters 58-61:
- 241 | update_cont path v1 @@ fun v1 -> union_ ~prefix:(prefix <>< path) m v1 v2
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "src/Trie.ml", line 253, characters 62-65:
- 253 | update_cont path v1 @@ fun v1 -> union_root ~prefix:(prefix <>< path) m v1 v2
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "src/Trie.ml", line 280, characters 52-54:
- 280 | SegMap.iter (fun seg -> iter_node ~prefix:(prefix #< seg) f) (get_children_node n)
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "src/Trie.ml", line 287, characters 66-68:
- 287 | SegMap.filter_map (fun seg -> filter_map_node ~prefix:(prefix #< seg) f) (get_children_node n)
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Modifier.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/native/yuujinchou__Modifier.cmx -c -impl src/Modifier.ml)
- File "src/Modifier.ml", line 53, characters 42-45:
- 53 | Trie.update_subtree p (go (prefix <>< p) m) t
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -cmi-file src/.Yuujinchou.objs/byte/yuujinchou__Scope.cmi -no-alias-deps -open Yuujinchou__ -o src/.Yuujinchou.objs/native/yuujinchou__Scope.cmx -c -impl src/Scope.ml)
- File "src/Scope.ml", line 89, characters 51-54:
- 89 | Internal.run ~export_prefix:(export_prefix() <>< p) ~init_visible:(S.get()).visible @@ fun () ->
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "yuujinchou" "-j" "71" "@runtest" (CWD=/home/opam/.opam/5.4/.opam-switch/build/yuujinchou.5.0.1)
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I test/.TestTrie.eobjs/byte -I test/.TestTrie.eobjs/native -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -I /home/opam/.opam/5.4/lib/ocaml/unix -I /home/opam/.opam/5.4/lib/qcheck-core -I /home/opam/.opam/5.4/lib/qcheck-core/runner -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -cmi-file test/.TestTrie.eobjs/byte/dune__exe__ListAsTrie.cmi -no-alias-deps -open Dune__exe -o test/.TestTrie.eobjs/native/dune__exe__ListAsTrie.cmx -c -impl test/ListAsTrie.ml)
- File "test/ListAsTrie.ml", line 36, characters 37-40:
- 36 | List.iter (fun (p, x) -> f (prefix <>< p) x) l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "test/ListAsTrie.ml", line 38, characters 45-48:
- 38 | List.map (fun (p, (d, t)) -> (p, f (prefix <>< p) (d, t))) l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "test/ListAsTrie.ml", line 40, characters 44-47:
- 40 | List.filter (fun (p, (d, t)) -> f (prefix <>< p) (d, t)) l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "test/ListAsTrie.ml", line 42, characters 78-81:
- 42 | List.filter_map (fun (p, (d, t)) -> Option.map (fun x -> p, x) @@ f (prefix <>< p) (d, t)) l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "test/ListAsTrie.ml", line 74, characters 21-24:
- 74 | (p1, m (prefix <>< p1) x1 x2) :: merge_uniq ~prefix m l1' l2'
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
-
- File "test/ListAsTrie.ml", line 95, characters 32-35:
- 95 | Seq.map (fun (p, x) -> prefix <>> p, x) @@ List.to_seq l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<>>
- Use (@>) instead
-
- File "test/ListAsTrie.ml", line 97, characters 32-35:
- 97 | Seq.map (fun (p, x) -> prefix <>< p, x) @@ List.to_seq l
- ^^^
- Alert deprecated: Bwd.Bwd.Infix.<><
- Use (<@) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I test/.TestModifier.eobjs/byte -I test/.TestModifier.eobjs/native -I /home/opam/.opam/5.4/lib/alcotest -I /home/opam/.opam/5.4/lib/alcotest/engine -I /home/opam/.opam/5.4/lib/alcotest/stdlib_ext -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/astring -I /home/opam/.opam/5.4/lib/bwd -I /home/opam/.opam/5.4/lib/cmdliner -I /home/opam/.opam/5.4/lib/fmt -I /home/opam/.opam/5.4/lib/fmt/cli -I /home/opam/.opam/5.4/lib/fmt/tty -I /home/opam/.opam/5.4/lib/ocaml/unix -I /home/opam/.opam/5.4/lib/re -I /home/opam/.opam/5.4/lib/stdlib-shims -I /home/opam/.opam/5.4/lib/uutf -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -cmi-file test/.TestModifier.eobjs/byte/dune__exe__TestModifier.cmi -no-alias-deps -o test/.TestModifier.eobjs/native/dune__exe__TestModifier.cmx -c -impl test/TestModifier.ml)
- File "test/TestModifier.ml", line 96, characters 40-42:
- 96 | (WrappedBindingNotFound (Emp #< "x" #< "y"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 96, characters 33-35:
- 96 | (WrappedBindingNotFound (Emp #< "x" #< "y"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 117, characters 40-42:
- 117 | (WrappedBindingNotFound (Emp #< "x" #< "y"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 117, characters 33-35:
- 117 | (WrappedBindingNotFound (Emp #< "x" #< "y"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 132, characters 33-35:
- 132 | (WrappedBindingNotFound (Emp #< "x"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 153, characters 33-35:
- 153 | (WrappedBindingNotFound (Emp #< "x"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 192, characters 33-35:
- 192 | (WrappedBindingNotFound (Emp #< "x"))
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 203, characters 29-31:
- 203 | (of_list [["x"], U ((Emp #< "x"), N 10, N 10); ["y"], N 20])
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
-
- File "test/TestModifier.ml", line 208, characters 29-31:
- 208 | (of_list [["x"], U ((Emp #< "x"), N 10, N 10); ["y"], N 20])
- ^^
- Alert deprecated: Bwd.Bwd.Infix.#<
- Use (<:) instead
- (cd _build/default && /home/opam/.opam/5.4/bin/ocamlopt.opt -w -40 -g -I test/.TestTrie.eobjs/byte -I test/.TestTrie.eobjs/native -I /home/opam/.opam/5.4/lib/algaeff -I /home/opam/.opam/5.4/lib/bwd -I /home/opam/.opam/5.4/lib/ocaml/unix -I /home/opam/.opam/5.4/lib/qcheck-core -I /home/opam/.opam/5.4/lib/qcheck-core/runner -I src/.Yuujinchou.objs/byte -I src/.Yuujinchou.objs/native -cmi-file test/.TestTrie.eobjs/byte/dune__exe__TestTrie.cmi -no-alias-deps -open Dune__exe -o test/.TestTrie.eobjs/native/dune__exe__TestTrie.cmx -c -impl test/TestTrie.ml)
- File "test/TestTrie.ml", line 17, characters 22-32:
- 17 | let gen_path = Q.Gen.(small_list @@ small_string ~gen:printable)
- ^^^^^^^^^^
- Alert deprecated: Q.Gen.small_list
- Use [list_small] instead
-
- File "test/TestTrie.ml", line 17, characters 36-48:
- 17 | let gen_path = Q.Gen.(small_list @@ small_string ~gen:printable)
- ^^^^^^^^^^^^
- Alert deprecated: Q.Gen.small_string
- Use [string_small] instead
-
- File "test/TestTrie.ml", line 19, characters 33-42:
- 19 | let gen_tagged = Q.Gen.(pair int small_nat)
- ^^^^^^^^^
- Alert deprecated: Q.Gen.small_nat
- Use [nat_small] instead
-
- File "test/TestTrie.ml", line 21, characters 11-21:
- 21 | Q.Gen.(small_list @@ pair gen_path gen_tagged)
- ^^^^^^^^^^
- Alert deprecated: Q.Gen.small_list
- Use [list_small] instead
-
- File "test/TestTrie.ml", line 48, characters 45-48:
- 48 | Q.Test.make ~count ~name:"root_opt" Q.Gen.(opt gen_tagged) ~print:Q.Print.(option print_tagged)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 71, characters 47-50:
- 71 | Q.Test.make ~count ~name:"iter" Q.Gen.(pair (opt gen_bwd_path) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 81, characters 19-22:
- 81 | Q.Gen.(triple (opt gen_bwd_path) (Q.fun2 obs_bwd_path obs_tagged gen_tagged) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 89, characters 19-22:
- 89 | Q.Gen.(triple (opt gen_bwd_path) (Q.fun2 obs_bwd_path obs_tagged bool) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 97, characters 19-22:
- 97 | Q.Gen.(triple (opt gen_bwd_path) (Q.fun2 obs_bwd_path Q.Observable.(pair int int) (opt gen_tagged)) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 97, characters 87-90:
- 97 | Q.Gen.(triple (opt gen_bwd_path) (Q.fun2 obs_bwd_path Q.Observable.(pair int int) (opt gen_tagged)) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 118, characters 73-76:
- 118 | Q.Gen.(triple gen_path (Q.fun1 Q.Observable.(option (pair int int)) (opt gen_tagged)) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 127, characters 62-65:
- 127 | Q.Gen.(pair (Q.fun1 Q.Observable.(option (pair int int)) (opt gen_tagged)) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 139, characters 17-20:
- 139 | Q.Gen.(quad (opt gen_bwd_path) gen_merge gen_list gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 148, characters 17-20:
- 148 | Q.Gen.(quad (opt gen_bwd_path) gen_merge gen_list (pair gen_path gen_list))
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 157, characters 17-20:
- 157 | Q.Gen.(quad (opt gen_bwd_path) gen_merge gen_list (pair gen_path gen_tagged))
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 166, characters 17-20:
- 166 | Q.Gen.(quad (opt gen_bwd_path) gen_merge gen_list gen_tagged)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 199, characters 49-52:
- 199 | Q.Test.make ~count ~name:"to_seq" Q.Gen.(pair (opt gen_bwd_path) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 206, characters 64-67:
- 206 | Q.Test.make ~count ~name:"to_seq_with_bwd_paths" Q.Gen.(pair (opt gen_bwd_path) gen_list)
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 220, characters 11-21:
- 220 | Q.Gen.(small_list @@ pair gen_path gen_tagged)
- ^^^^^^^^^^
- Alert deprecated: Q.Gen.small_list
- Use [list_small] instead
-
- File "test/TestTrie.ml", line 228, characters 19-22:
- 228 | Q.Gen.(triple (opt gen_bwd_path) gen_merge (small_list @@ pair gen_path gen_tagged))
- ^^^
- Alert deprecated: Q.Gen.opt
- Use [option] instead
-
- File "test/TestTrie.ml", line 228, characters 48-58:
- 228 | Q.Gen.(triple (opt gen_bwd_path) gen_merge (small_list @@ pair gen_path gen_tagged))
- ^^^^^^^^^^
- Alert deprecated: Q.Gen.small_list
- Use [list_small] instead
- (cd _build/default/test && ./TestModifier.exe)
- Testing `Modifier'.
- This run has ID `SRTSNCSD'.
-
- [OK] none 0 none.
- [OK] none 1 none.
- [OK] none 2 none.
- [OK] all 0 all.
- [OK] all 1 all.
- [OK] all 2 all.
- [OK] all 3 all.
- [OK] only 0 only.
- [OK] only 1 only.
- [OK] only 2 only.
- [OK] only 3 only.
- [OK] except 0 except.
- [OK] except 1 except.
- [OK] except 2 except.
- [OK] in_ 0 in_.
- [OK] in_ 1 in_.
- [OK] in_ 2 in_.
- [OK] in_ 3 in_.
- [OK] renaming 0 renaming.
- [OK] renaming 1 renaming.
- [OK] renaming 2 renaming.
- [OK] renaming 3 renaming.
- [OK] renaming 4 renaming.
- [OK] renaming 5 renaming.
- [OK] seq 0 seq.
- [OK] seq 1 seq.
- [OK] seq 2 seq.
- [OK] seq 3 seq.
- [OK] seq 4 seq.
- [OK] union 0 union.
- [OK] union 1 union.
- [OK] union 2 union.
- [OK] union 3 union.
-
- Full test results in `~/.opam/5.4/.opam-switch/build/yuujinchou.5.0.1/_build/default/test/_build/_tests/Modifier'.
- Test Successful in 0.005s. 33 tests run.
- (cd _build/default/test && ./TestTrie.exe)
-
random seed: 455925811
- generated error fail pass / total time test name
-
[ ] 0 0 0 0 / 100 0.0s empty
[✓] 100 0 0 100 / 100 0.0s empty
-
[ ] 0 0 0 0 / 100 0.0s is_empty
[ ] 32 0 0 32 / 100 0.1s is_empty (collecting)
[ ] 65 0 0 65 / 100 0.2s is_empty (collecting)
[ ] 96 0 0 96 / 100 0.3s is_empty (collecting)
[✓] 100 0 0 100 / 100 0.3s is_empty
-
[ ] 0 0 0 0 / 100 0.0s root
[✓] 100 0 0 100 / 100 0.0s root
-
[ ] 0 0 0 0 / 100 0.0s root_opt
[✓] 100 0 0 100 / 100 0.0s root_opt
-
[ ] 0 0 0 0 / 100 0.0s prefix
[ ] 9 0 0 9 / 100 0.1s prefix (collecting)
[ ] 42 0 0 42 / 100 0.2s prefix (collecting)
[ ] 56 0 0 56 / 100 0.3s prefix (collecting)
[ ] 81 0 0 81 / 100 0.4s prefix (collecting)
[✓] 100 0 0 100 / 100 0.5s prefix
-
[ ] 0 0 0 0 / 100 0.0s singleton
[✓] 100 0 0 100 / 100 0.0s singleton
-
[ ] 0 0 0 0 / 100 0.0s find_subtree
[ ] 11 0 0 11 / 100 0.1s find_subtree (collecting)
[ ] 45 0 0 45 / 100 0.2s find_subtree (collecting)
[ ] 63 0 0 63 / 100 0.3s find_subtree (collecting)
[ ] 97 0 0 97 / 100 0.4s find_subtree (collecting)
[✓] 100 0 0 100 / 100 0.4s find_subtree
-
[ ] 0 0 0 0 / 100 0.0s find_singleton
[ ] 11 0 0 11 / 100 0.1s find_singleton (collecting)
[ ] 45 0 0 45 / 100 0.2s find_singleton (collecting)
[ ] 60 0 0 60 / 100 0.3s find_singleton (collecting)
[ ] 94 0 0 94 / 100 0.4s find_singleton (collecting)
[✓] 100 0 0 100 / 100 0.5s find_singleton
-
[ ] 0 0 0 0 / 100 0.0s find_root
[ ] 38 0 0 38 / 100 0.1s find_root (collecting)
[ ] 69 0 0 69 / 100 0.2s find_root (collecting)
[✓] 100 0 0 100 / 100 0.3s find_root
-
[ ] 0 0 0 0 / 100 0.0s iter
[ ] 37 0 0 37 / 100 0.1s iter (collecting)
[ ] 53 0 0 53 / 100 0.2s iter (collecting)
[ ] 72 0 0 72 / 100 0.3s iter (collecting)
[ ] 99 0 0 99 / 100 0.4s iter
[✓] 100 0 0 100 / 100 0.4s iter
-
[ ] 0 0 0 0 / 100 0.0s map
[ ] 26 0 0 26 / 100 0.1s map (collecting)
[ ] 59 0 0 59 / 100 0.2s map (collecting)
[ ] 79 0 0 79 / 100 0.3s map
[✓] 100 0 0 100 / 100 0.4s map
-
[ ] 0 0 0 0 / 100 0.0s filter
[ ] 26 0 0 26 / 100 0.1s filter (collecting)
[ ] 60 0 0 60 / 100 0.2s filter
[ ] 79 0 0 79 / 100 0.3s filter
[✓] 100 0 0 100 / 100 0.4s filter
-
[ ] 0 0 0 0 / 100 0.0s filter_map
[ ] 26 0 0 26 / 100 0.1s filter_map (collecting)
[ ] 60 0 0 60 / 100 0.2s filter_map
[ ] 78 0 0 78 / 100 0.3s filter_map (collecting)
[✓] 100 0 0 100 / 100 0.4s filter_map
-
[ ] 0 0 0 0 / 100 0.0s update_subtree
[ ] 16 0 0 16 / 100 0.1s update_subtree (collecting)
[ ] 26 0 0 26 / 100 0.2s update_subtree (collecting)
[ ] 37 0 0 37 / 100 0.3s update_subtree
[ ] 44 0 0 44 / 100 0.4s update_subtree
[ ] 52 0 0 52 / 100 0.5s update_subtree (collecting)
[ ] 65 0 0 65 / 100 0.6s update_subtree (collecting)
[ ] 71 0 0 71 / 100 0.7s update_subtree (collecting)
[ ] 76 0 0 76 / 100 0.9s update_subtree
[ ] 83 0 0 83 / 100 1.0s update_subtree (collecting)
[ ] 93 0 0 93 / 100 1.1s update_subtree
[✓] 100 0 0 100 / 100 1.2s update_subtree
-
[ ] 0 0 0 0 / 100 0.0s update_singleton
[ ] 39 0 0 39 / 100 0.1s update_singleton (collecting)
[ ] 65 0 0 65 / 100 0.2s update_singleton (collecting)
[ ] 75 0 0 75 / 100 0.3s update_singleton (collecting)
[✓] 100 0 0 100 / 100 0.4s update_singleton
-
[ ] 0 0 0 0 / 100 0.0s update_root
[ ] 36 0 0 36 / 100 0.1s update_root (collecting)
[ ] 62 0 0 62 / 100 0.2s update_root (collecting)
[ ] 98 0 0 98 / 100 0.3s update_root (collecting)
[✓] 100 0 0 100 / 100 0.3s update_root
-
[ ] 0 0 0 0 / 100 0.0s union
[ ] 10 0 0 10 / 100 0.1s union (collecting)
[ ] 21 0 0 21 / 100 0.2s union (collecting)
[ ] 28 0 0 28 / 100 0.3s union (collecting)
[ ] 41 0 0 41 / 100 0.4s union (collecting)
[ ] 50 0 0 50 / 100 0.5s union (collecting)
[ ] 70 0 0 70 / 100 0.6s union (collecting)
[ ] 91 0 0 91 / 100 0.7s union (collecting)
[✓] 100 0 0 100 / 100 0.8s union
-
[ ] 0 0 0 0 / 100 0.0s union_subtree
[ ] 17 0 0 17 / 100 0.1s union_subtree (collecting)
[ ] 30 0 0 30 / 100 0.2s union_subtree (collecting)
[ ] 37 0 0 37 / 100 0.3s union_subtree (collecting)
[ ] 44 0 0 44 / 100 0.4s union_subtree (collecting)
[ ] 58 0 0 58 / 100 0.5s union_subtree (collecting)
[ ] 79 0 0 79 / 100 0.6s union_subtree (collecting)
[ ] 98 0 0 98 / 100 0.7s union_subtree (collecting)
[✓] 100 0 0 100 / 100 0.7s union_subtree
-
[ ] 0 0 0 0 / 100 0.0s union_singleton
[ ] 25 0 0 25 / 100 0.1s union_singleton (collecting)
[ ] 47 0 0 47 / 100 0.2s union_singleton (collecting)
[ ] 76 0 0 76 / 100 0.3s union_singleton (collecting)
[✓] 100 0 0 100 / 100 0.4s union_singleton
-
[ ] 0 0 0 0 / 100 0.0s union_root
[ ] 25 0 0 25 / 100 0.1s union_root (collecting)
[ ] 49 0 0 49 / 100 0.2s union_root (collecting)
[ ] 82 0 0 82 / 100 0.3s union_root (collecting)
[✓] 100 0 0 100 / 100 0.4s union_root
-
[ ] 0 0 0 0 / 100 0.0s detach_subtree
[ ] 11 0 0 11 / 100 0.1s detach_subtree (collecting)
[ ] 43 0 0 43 / 100 0.2s detach_subtree (collecting)
[ ] 58 0 0 58 / 100 0.3s detach_subtree (collecting)
[ ] 91 0 0 91 / 100 0.4s detach_subtree (collecting)
[✓] 100 0 0 100 / 100 0.5s detach_subtree
-
[ ] 0 0 0 0 / 100 0.0s detach_singleton
[ ] 11 0 0 11 / 100 0.1s detach_singleton (collecting)
[ ] 44 0 0 44 / 100 0.2s detach_singleton
[ ] 58 0 0 58 / 100 0.3s detach_singleton (collecting)
[ ] 94 0 0 94 / 100 0.4s detach_singleton
[✓] 100 0 0 100 / 100 0.5s detach_singleton
-
[ ] 0 0 0 0 / 100 0.0s detach_root
[ ] 37 0 0 37 / 100 0.1s detach_root (collecting)
[ ] 67 0 0 67 / 100 0.2s detach_root (collecting)
[ ] 96 0 0 96 / 100 0.3s detach_root (collecting)
[✓] 100 0 0 100 / 100 0.3s detach_root
-
[ ] 0 0 0 0 / 100 0.0s to_seq
[ ] 37 0 0 37 / 100 0.1s to_seq (collecting)
[ ] 55 0 0 55 / 100 0.2s to_seq (collecting)
[ ] 76 0 0 76 / 100 0.3s to_seq (collecting)
[✓] 100 0 0 100 / 100 0.4s to_seq
-
[ ] 0 0 0 0 / 100 0.0s to_seq_with_bwd_paths
[ ] 37 0 0 37 / 100 0.1s to_seq_with_bwd_paths (collecting)
[ ] 56 0 0 56 / 100 0.2s to_seq_with_bwd_paths (collecting)
[ ] 74 0 0 74 / 100 0.3s to_seq_with_bwd_paths (collecting)
[ ] 99 0 0 99 / 100 0.4s to_seq_with_bwd_paths
[✓] 100 0 0 100 / 100 0.4s to_seq_with_bwd_paths
-
[ ] 0 0 0 0 / 100 0.0s to_seq_values
[ ] 37 0 0 37 / 100 0.1s to_seq_values (collecting)
[ ] 65 0 0 65 / 100 0.2s to_seq_values (collecting)
[ ] 96 0 0 96 / 100 0.3s to_seq_values (collecting)
[✓] 100 0 0 100 / 100 0.3s to_seq_values
-
[ ] 0 0 0 0 / 100 0.0s of_seq
[ ] 37 0 0 37 / 100 0.1s of_seq (collecting)
[ ] 67 0 0 67 / 100 0.2s of_seq (collecting)
[ ] 96 0 0 96 / 100 0.3s of_seq (collecting)
[✓] 100 0 0 100 / 100 0.3s of_seq
-
[ ] 0 0 0 0 / 100 0.0s of_seq_with_merger
[ ] 26 0 0 26 / 100 0.1s of_seq_with_merger (collecting)
[ ] 64 0 0 64 / 100 0.2s of_seq_with_merger (collecting)
[ ] 85 0 0 85 / 100 0.3s of_seq_with_merger (collecting)
[✓] 100 0 0 100 / 100 0.4s of_seq_with_merger
-
[ ] 0 0 0 0 / 100 0.0s retag
[ ] 22 0 0 22 / 100 0.1s retag (collecting)
[ ] 52 0 0 52 / 100 0.2s retag (collecting)
[ ] 97 0 0 97 / 100 0.3s retag (collecting)
[✓] 100 0 0 100 / 100 0.3s retag
-
[ ] 0 0 0 0 / 100 0.0s retag_subtree
[ ] 38 0 0 38 / 100 0.1s retag_subtree
[ ] 53 0 0 53 / 100 0.2s retag_subtree (collecting)
[ ] 71 0 0 71 / 100 0.3s retag_subtree (collecting)
[ ] 85 0 0 85 / 100 0.4s retag_subtree (collecting)
[✓] 100 0 0 100 / 100 0.4s retag_subtree
-
[ ] 0 0 0 0 / 100 0.0s untag
[ ] 33 0 0 33 / 100 0.1s untag (collecting)
[ ] 65 0 0 65 / 100 0.2s untag (collecting)
[ ] 96 0 0 96 / 100 0.3s untag (collecting)
[✓] 100 0 0 100 / 100 0.3s untag
-
[ ] 0 0 0 0 / 100 0.0s set_of_tags
[ ] 37 0 0 37 / 100 0.1s set_of_tags (collecting)
[ ] 69 0 0 69 / 100 0.2s set_of_tags (collecting)
[✓] 100 0 0 100 / 100 0.3s set_of_tags
- ================================================================================
- success (ran 32 tests)
-> compiled yuujinchou.5.0.1
-> removed yuujinchou.5.0.1
-> installed yuujinchou.5.0.1
Done.
# To update the current shell environment, run: eval $(opam env)
2026-03-25 18:03.27 ---> saved as "0295f4beffbd38667d3be794789f2430177b1f140dd1fda67fc497a09476db76"
Job succeeded
2026-03-25 18:03.37: Job succeeded