Organisationsocamlodoc4e00a3 ()opensuse-15.6-4.14_opam-2.5

opensuse-15.6-4.14_opam-2.5

Link Copied
Code Copied

Logs

2026-03-18 10:10.12: New job: test ocaml/odoc https://github.com/ocaml/odoc.git#refs/pull/1399/head (4e00a3bb431ecc5fa690c40825a2a6b79b9001f7) (linux-x86_64:opensuse-15.6-4.14_opam-2.5)
Base: ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9
Opam project build


To reproduce locally:


git clone --recursive "https://github.com/ocaml/odoc.git" && cd "odoc" && git fetch origin "refs/pull/1399/head" && git reset --hard 4e00a3bb
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9
# opensuse-15.6-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 31462e7d24da1419f9eb9099a0b60ea507d91ef6 || git fetch origin master) && git reset -q --hard 31462e7d24da1419f9eb9099a0b60ea507d91ef6 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 sherlodoc.opam odoc.opam odoc-parser.opam odoc-md.opam odoc-driver.opam odoc-bench.opam ./
RUN opam pin add -yn sherlodoc.dev './' && \
opam pin add -yn odoc.dev './' && \
opam pin add -yn odoc-parser.dev './' && \
opam pin add -yn odoc-md.dev './' && \
opam pin add -yn odoc-driver.dev './' && \
opam pin add -yn odoc-bench.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="alcotest.1.9.1 astring.0.8.5 b0.0.0.5 base.v0.16.4 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 base_bigstring.v0.16.0 base_quickcheck.v0.16.0 bigstringaf.0.10.0 bin_prot.v0.16.0 bisect_ppx.2.8.3 bos.0.2.1 brr.0.0.8 camlp-streams.5.0.1 checkseum.0.5.2 cmarkit.0.3.0 cmdliner.1.3.0 conf-jq.1 core.v0.16.2 core_kernel.v0.16.0 cppo.1.8.0 crunch.4.0.0 csexp.1.5.2 decompress.1.5.3 dune.3.21.1 dune-configurator.3.21.1 fieldslib.v0.16.0 fmt.0.11.0 fpath.0.7.3 gen.1.1 int_repr.v0.16.0 jane-street-headers.v0.16.0 js_of_ocaml.6.2.0 js_of_ocaml-compiler.6.2.0 js_of_ocaml-toplevel.6.2.0 jst-config.v0.16.0 logs.0.10.0 lwt.6.1.1 mdx.2.5.1 menhir.20260209 menhirCST.20260209 menhirGLR.20260209 menhirLib.20260209 menhirSdk.20260209 num.1.6 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.3 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 odig.0.0.9 optint.0.3.0 parsexp.v0.16.0 ppx_assert.v0.16.0 ppx_base.v0.16.0 ppx_bench.v0.16.0 ppx_bin_prot.v0.16.0 ppx_blob.0.9.0 ppx_cold.v0.16.0 ppx_compare.v0.16.0 ppx_custom_printf.v0.16.0 ppx_derivers.1.2.1 ppx_disable_unused_warnings.v0.16.0 ppx_enumerate.v0.16.0 ppx_expect.v0.16.2 ppx_fields_conv.v0.16.0 ppx_fixed_literal.v0.16.0 ppx_globalize.v0.16.0 ppx_hash.v0.16.0 ppx_here.v0.16.0 ppx_ignore_instrumentation.v0.16.0 ppx_inline_test.v0.16.1 ppx_jane.v0.16.0 ppx_let.v0.16.0 ppx_log.v0.16.0 ppx_module_timer.v0.16.0 ppx_optcomp.v0.16.0 ppx_optional.v0.16.0 ppx_pipebang.v0.16.0 ppx_sexp_conv.v0.16.0 ppx_sexp_message.v0.16.0 ppx_sexp_value.v0.16.0 ppx_stable.v0.16.0 ppx_stable_witness.v0.16.0 ppx_string.v0.16.0 ppx_tydi.v0.16.0 ppx_typerep_conv.v0.16.0 ppx_variants_conv.v0.16.0 ppxlib.0.35.0 ptime.1.2.0 re.1.14.0 result.1.5 rresult.0.7.0 sedlex.3.7 seq.base sexplib.v0.16.0 sexplib0.v0.16.0 splittable_random.v0.16.0 stdio.v0.16.0 stdlib-shims.0.3.0 time_now.v0.16.0 topkg.1.1.1 typerep.v0.16.0 tyxml.4.6.0 uutf.1.0.4 variantslib.v0.16.0 yojson.3.0.0"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.5 --depext-only -y sherlodoc.dev odoc.dev odoc-parser.dev odoc-md.dev odoc-bench.dev $DEPS
RUN opam install $DEPS
COPY --chown=1000:1000 . /src
RUN opam exec -- dune build --only-packages=sherlodoc,odoc,odoc-parser,odoc-md,odoc-bench @install @check @runtest && rm -rf _build


END-OF-DOCKERFILE
docker build .
END-REPRO-BLOCK


2026-03-18 10:10.12: Using cache hint "ocaml/odoc-ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9-opensuse-15.6-4.14_opam-2.5-ff44b598eaf7ff8972d594892015f170"
2026-03-18 10:10.12: Using OBuilder spec:
((from ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9)
(comment opensuse-15.6-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 31462e7d24da1419f9eb9099a0b60ea507d91ef6 || git fetch origin master) && git reset -q --hard 31462e7d24da1419f9eb9099a0b60ea507d91ef6 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src sherlodoc.opam odoc.opam odoc-parser.opam odoc-md.opam odoc-driver.opam odoc-bench.opam)
(dst ./))
(run (network host)
(shell  "opam pin add -yn sherlodoc.dev './' && \
\nopam pin add -yn odoc.dev './' && \
\nopam pin add -yn odoc-parser.dev './' && \
\nopam pin add -yn odoc-md.dev './' && \
\nopam pin add -yn odoc-driver.dev './' && \
\nopam pin add -yn odoc-bench.dev './'"))
(run (shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "alcotest.1.9.1 astring.0.8.5 b0.0.0.5 base.v0.16.4 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 base_bigstring.v0.16.0 base_quickcheck.v0.16.0 bigstringaf.0.10.0 bin_prot.v0.16.0 bisect_ppx.2.8.3 bos.0.2.1 brr.0.0.8 camlp-streams.5.0.1 checkseum.0.5.2 cmarkit.0.3.0 cmdliner.1.3.0 conf-jq.1 core.v0.16.2 core_kernel.v0.16.0 cppo.1.8.0 crunch.4.0.0 csexp.1.5.2 decompress.1.5.3 dune.3.21.1 dune-configurator.3.21.1 fieldslib.v0.16.0 fmt.0.11.0 fpath.0.7.3 gen.1.1 int_repr.v0.16.0 jane-street-headers.v0.16.0 js_of_ocaml.6.2.0 js_of_ocaml-compiler.6.2.0 js_of_ocaml-toplevel.6.2.0 jst-config.v0.16.0 logs.0.10.0 lwt.6.1.1 mdx.2.5.1 menhir.20260209 menhirCST.20260209 menhirGLR.20260209 menhirLib.20260209 menhirSdk.20260209 num.1.6 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.3 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 odig.0.0.9 optint.0.3.0 parsexp.v0.16.0 ppx_assert.v0.16.0 ppx_base.v0.16.0 ppx_bench.v0.16.0 ppx_bin_prot.v0.16.0 ppx_blob.0.9.0 ppx_cold.v0.16.0 ppx_compare.v0.16.0 ppx_custom_printf.v0.16.0 ppx_derivers.1.2.1 ppx_disable_unused_warnings.v0.16.0 ppx_enumerate.v0.16.0 ppx_expect.v0.16.2 ppx_fields_conv.v0.16.0 ppx_fixed_literal.v0.16.0 ppx_globalize.v0.16.0 ppx_hash.v0.16.0 ppx_here.v0.16.0 ppx_ignore_instrumentation.v0.16.0 ppx_inline_test.v0.16.1 ppx_jane.v0.16.0 ppx_let.v0.16.0 ppx_log.v0.16.0 ppx_module_timer.v0.16.0 ppx_optcomp.v0.16.0 ppx_optional.v0.16.0 ppx_pipebang.v0.16.0 ppx_sexp_conv.v0.16.0 ppx_sexp_message.v0.16.0 ppx_sexp_value.v0.16.0 ppx_stable.v0.16.0 ppx_stable_witness.v0.16.0 ppx_string.v0.16.0 ppx_tydi.v0.16.0 ppx_typerep_conv.v0.16.0 ppx_variants_conv.v0.16.0 ppxlib.0.35.0 ptime.1.2.0 re.1.14.0 result.1.5 rresult.0.7.0 sedlex.3.7 seq.base sexplib.v0.16.0 sexplib0.v0.16.0 splittable_random.v0.16.0 stdio.v0.16.0 stdlib-shims.0.3.0 time_now.v0.16.0 topkg.1.1.1 typerep.v0.16.0 tyxml.4.6.0 uutf.1.0.4 variantslib.v0.16.0 yojson.3.0.0")
(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 sherlodoc.dev odoc.dev odoc-parser.dev odoc-md.dev odoc-bench.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 --only-packages=sherlodoc,odoc,odoc-parser,odoc-md,odoc-bench @install @check @runtest && rm -rf _build"))
)


2026-03-18 10:10.12: Waiting for resource in pool OCluster
2026-03-18 10:10.12: Waiting for worker…
2026-03-18 10:10.12: Got resource from pool OCluster
Building on doris.caelum.ci.dev
HEAD is now at a3a6c2213 Add CI for OxCaml to github workflows
HEAD is now at 4e00a3bb4 Fix CI: no bisect_ppx coverage for OxCaml


(from ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9)
Unable to find image 'ocaml/opam:opensuse-15.6-ocaml-4.14@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9' locally
docker.io/ocaml/opam@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9: Pulling from ocaml/opam
88fec4ee27fa: Pulling fs layer
0c29b9b81895: Pulling fs layer
e13a07a82ff2: Pulling fs layer
a4f587681cd2: Pulling fs layer
b654fe557977: Pulling fs layer
07b50a5ff06e: Pulling fs layer
2524e7100bda: Pulling fs layer
62a0e072f540: Pulling fs layer
e4d4efb28b71: Pulling fs layer
4d22927afde6: Pulling fs layer
1910d19eb083: Pulling fs layer
f0e05cd6bfcf: Pulling fs layer
a809beaf2ce5: Pulling fs layer
b7a362ffa81b: Pulling fs layer
460129753514: Pulling fs layer
a4f587681cd2: Waiting
d4f714e04836: Pulling fs layer
b654fe557977: Waiting
d70fe23c18cd: Pulling fs layer
0d07d7fef061: Pulling fs layer
07b50a5ff06e: Waiting
5623d083d3b3: Pulling fs layer
4f4fb700ef54: Pulling fs layer
ce6441b074a7: Pulling fs layer
2524e7100bda: Waiting
0fd2a08bcd56: Pulling fs layer
62a0e072f540: Waiting
f6068b2a147c: Pulling fs layer
e4d4efb28b71: Waiting
4c1a35052789: Pulling fs layer
4d22927afde6: Waiting
1910d19eb083: Waiting
b33abd038481: Pulling fs layer
350e9373a176: Pulling fs layer
f0e05cd6bfcf: Waiting
a7fc136663a0: Pulling fs layer
a809beaf2ce5: Waiting
d70fe23c18cd: Waiting
5703438fe18a: Pulling fs layer
0d07d7fef061: Waiting
b7a362ffa81b: Waiting
8833b155bad4: Pulling fs layer
98913bd67483: Pulling fs layer
5623d083d3b3: Waiting
460129753514: Waiting
331f50433f29: Pulling fs layer
4f4fb700ef54: Waiting
d4f714e04836: Waiting
c935b3ee9c7e: Pulling fs layer
ce6441b074a7: Waiting
22319c85fe85: Pulling fs layer
b7a9591fcacc: Pulling fs layer
0fd2a08bcd56: Waiting
4c1a35052789: Waiting
b33abd038481: Waiting
350e9373a176: Waiting
a7fc136663a0: Waiting
8833b155bad4: Waiting
5703438fe18a: Waiting
98913bd67483: Waiting
945c450a4d0f: Pulling fs layer
24e90ed45fcf: Pulling fs layer
331f50433f29: Waiting
f6068b2a147c: Waiting
8424e867ee77: Pulling fs layer
b7a9591fcacc: Waiting
22319c85fe85: Waiting
b85a58b4c2e9: Pulling fs layer
a9dae66123de: Pulling fs layer
945c450a4d0f: Waiting
49f1adc9c3a4: Pulling fs layer
a9a190666cb6: Pulling fs layer
c935b3ee9c7e: Waiting
b85a58b4c2e9: Waiting
8424e867ee77: Waiting
4afed0003f6a: Pulling fs layer
a9dae66123de: Waiting
49f1adc9c3a4: Waiting
a9a190666cb6: Waiting
24e90ed45fcf: Waiting
4afed0003f6a: Waiting
0c29b9b81895: Download complete
88fec4ee27fa: Verifying Checksum
88fec4ee27fa: Download complete
b654fe557977: Download complete
07b50a5ff06e: Download complete
e13a07a82ff2: Verifying Checksum
e13a07a82ff2: Download complete
2524e7100bda: Verifying Checksum
2524e7100bda: Download complete
62a0e072f540: Verifying Checksum
62a0e072f540: Download complete
e4d4efb28b71: Verifying Checksum
e4d4efb28b71: Download complete
1910d19eb083: Verifying Checksum
1910d19eb083: Download complete
88fec4ee27fa: Pull complete
0c29b9b81895: Pull complete
4d22927afde6: Verifying Checksum
4d22927afde6: Download complete
f0e05cd6bfcf: Verifying Checksum
f0e05cd6bfcf: Download complete
a809beaf2ce5: Verifying Checksum
a809beaf2ce5: Download complete
a4f587681cd2: Verifying Checksum
a4f587681cd2: Download complete
b7a362ffa81b: Verifying Checksum
b7a362ffa81b: Download complete
d70fe23c18cd: Download complete
d4f714e04836: Verifying Checksum
d4f714e04836: Download complete
460129753514: Verifying Checksum
460129753514: Download complete
0d07d7fef061: Download complete
5623d083d3b3: Verifying Checksum
5623d083d3b3: Download complete
4f4fb700ef54: Verifying Checksum
4f4fb700ef54: Download complete
ce6441b074a7: Verifying Checksum
ce6441b074a7: Download complete
0fd2a08bcd56: Verifying Checksum
0fd2a08bcd56: Download complete
f6068b2a147c: Download complete
4c1a35052789: Download complete
b33abd038481: Verifying Checksum
b33abd038481: Download complete
350e9373a176: Download complete
a7fc136663a0: Download complete
5703438fe18a: Download complete
8833b155bad4: Download complete
98913bd67483: Verifying Checksum
98913bd67483: Download complete
331f50433f29: Download complete
c935b3ee9c7e: Download complete
24e90ed45fcf: Download complete
8424e867ee77: Verifying Checksum
8424e867ee77: Download complete
e13a07a82ff2: Pull complete
b85a58b4c2e9: Verifying Checksum
b85a58b4c2e9: Download complete
22319c85fe85: Verifying Checksum
22319c85fe85: Download complete
49f1adc9c3a4: Verifying Checksum
49f1adc9c3a4: Download complete
a9a190666cb6: Download complete
a9dae66123de: Verifying Checksum
a9dae66123de: Download complete
4afed0003f6a: Verifying Checksum
4afed0003f6a: Download complete
945c450a4d0f: Verifying Checksum
945c450a4d0f: Download complete
a4f587681cd2: Pull complete
b654fe557977: Pull complete
07b50a5ff06e: Pull complete
2524e7100bda: Pull complete
62a0e072f540: Pull complete
e4d4efb28b71: Pull complete
4d22927afde6: Pull complete
1910d19eb083: Pull complete
f0e05cd6bfcf: Pull complete
a809beaf2ce5: Pull complete
b7a362ffa81b: Pull complete
460129753514: Pull complete
d4f714e04836: Pull complete
d70fe23c18cd: Pull complete
0d07d7fef061: Pull complete
5623d083d3b3: Pull complete
4f4fb700ef54: Pull complete
ce6441b074a7: Pull complete
0fd2a08bcd56: Pull complete
f6068b2a147c: Pull complete
4c1a35052789: Pull complete
b33abd038481: Pull complete
350e9373a176: Pull complete
a7fc136663a0: Pull complete
5703438fe18a: Pull complete
8833b155bad4: Pull complete
98913bd67483: Pull complete
331f50433f29: Pull complete
c935b3ee9c7e: Pull complete
22319c85fe85: Pull complete
b7a9591fcacc: Pull complete
945c450a4d0f: Pull complete
24e90ed45fcf: Pull complete
8424e867ee77: Pull complete
b85a58b4c2e9: Pull complete
a9dae66123de: Pull complete
49f1adc9c3a4: Pull complete
a9a190666cb6: Pull complete
4afed0003f6a: Pull complete
Digest: sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9
Status: Downloaded newer image for ocaml/opam@sha256:60a8739fab44bd4b7628c051b2fbd9e0a75ca74d607ca75de0534804db88c4c9
2026-03-18 10:18.17 ---> using "68ed99005e3b1166849df4c2b92fbf03bda7e3e0c16253fdd436444b5faeeb83" from cache


/: (comment opensuse-15.6-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-03-18 10:18.20 ---> using "758ad5028119e26afe45912468334b0f029cab532cd436055f6e6f1570003108" 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
Format upgrade done.


<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-03-18 10:18.20 ---> using "6399ed3111400fd8025fe761f3cfe64b0f0c53e0562e2d65231ba34b6bcd05c3" from cache


/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 6.8.0-94-generic
The OCaml toplevel, version 4.14.2
2.5.0
2026-03-18 10:18.33 ---> using "ab74ba4160a7ec3b94c64ef7ec5c69544220ca15897d1297e8784cf6a52391d5" from cache


/src: (workdir /src)


/src: (run (shell "sudo chown opam /src"))
2026-03-18 10:18.35 ---> using "e5cc5a7dca600d18a8dd8d955854bef56d6a65f98aa05633e3968a4b95ade98a" from cache


/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 31462e7d24da1419f9eb9099a0b60ea507d91ef6 || git fetch origin master) && git reset -q --hard 31462e7d24da1419f9eb9099a0b60ea507d91ef6 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch                  master     -> FETCH_HEAD
3109384a92..f2c5c4384d  master     -> origin/master
31462e7d24 Merge pull request #29451 from dra27/relocatable-package


<><> 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.5.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-03-18 10:18.47 ---> using "8380bb9ccf9f26438897acdf9269dc1699ec8fa4f033a4b894aff7dcfd876986" from cache


/src: (copy (src sherlodoc.opam odoc.opam odoc-parser.opam odoc-md.opam odoc-driver.opam odoc-bench.opam)
(dst ./))
Uncaught exception: Failure("\"rm\" \"-rf\" \"/var/cache/obuilder/merged/deacacd0909df9a5b4bd8c39f696534cf4a050c5555fb47d6f2ccd2d2cf7afb8\" \"/var/cache/obuilder/work/deacacd0909df9a5b4bd8c39f696534cf4a050c5555fb47d6f2ccd2d2cf7afb8\" failed with exit status 1")
2026-03-18 10:26.04: Job failed: Failed: Internal error