2025-10-16 02:59.39: New job: test jeffa5/ocaml-grpc https://github.com/jeffa5/ocaml-grpc.git#refs/heads/master (efd6dbfc2d044fef97b122f831a8c162d9d46625) (linux-riscv64:debian-13-4.14_riscv64_opam-2.4)
Base: ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/jeffa5/ocaml-grpc.git" -b "master" && cd "ocaml-grpc" && git reset --hard efd6dbfc
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4
# debian-13-4.14_riscv64_opam-2.4
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
WORKDIR /src
RUN sudo ln -f /usr/bin/opam-2.4 /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 209109366a444d7ea71a56ee6cb8f608cdc6ced0 || git fetch origin master) && git reset -q --hard 209109366a444d7ea71a56ee6cb8f608cdc6ced0 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 grpc.opam grpc-lwt.opam ./
RUN opam pin add -yn grpc.dev './' && \
opam pin add -yn grpc-lwt.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="angstrom.0.16.1 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bigstringaf.0.10.0 cppo.1.8.0 csexp.1.5.2 dune.3.20.2 dune-configurator.3.20.2 faraday.0.8.2 h2.dev hpack.0.13.0 httpaf.0.7.1 lwt.5.9.2 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocaml-protoc.3.1.1 ocaml-syntax-shims.1.0.0 ocamlfind.1.9.8 ocplib-endian.1.2 pbrt.3.1.1 psq.0.2.1 result.1.5 seq.base stdlib-shims.0.3.0 stringext.1.6.0 uri.4.4.0"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.4 --depext-only -y grpc.dev grpc-lwt.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
2025-10-16 02:59.39: Using cache hint "jeffa5/ocaml-grpc-ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4-debian-13-4.14_riscv64_opam-2.4-605c31d89b237055ba3b66ee33f0bb88"
2025-10-16 02:59.39: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4)
(comment debian-13-4.14_riscv64_opam-2.4)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(workdir /src)
(run (shell "sudo ln -f /usr/bin/opam-2.4 /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 209109366a444d7ea71a56ee6cb8f608cdc6ced0 || git fetch origin master) && git reset -q --hard 209109366a444d7ea71a56ee6cb8f608cdc6ced0 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src grpc.opam grpc-lwt.opam) (dst ./))
(run (network host)
(shell "opam pin add -yn grpc.dev './' && \
\nopam pin add -yn grpc-lwt.dev './'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "angstrom.0.16.1 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bigstringaf.0.10.0 cppo.1.8.0 csexp.1.5.2 dune.3.20.2 dune-configurator.3.20.2 faraday.0.8.2 h2.dev hpack.0.13.0 httpaf.0.7.1 lwt.5.9.2 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocaml-protoc.3.1.1 ocaml-syntax-shims.1.0.0 ocamlfind.1.9.8 ocplib-endian.1.2 pbrt.3.1.1 psq.0.2.1 result.1.5 seq.base stdlib-shims.0.3.0 stringext.1.6.0 uri.4.4.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.4 --depext-only -y grpc.dev grpc-lwt.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"))
)
2025-10-16 02:59.39: Waiting for resource in pool OCluster
2025-10-16 12:25.32: Waiting for worker…
2025-10-17 01:41.55: Got resource from pool OCluster
Building on riscv-bm-02.sw.ci.dev
All commits already cached
HEAD is now at efd6dbf Update h2 src
(from ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4)
Unable to find image 'ocaml/opam:debian-13-ocaml-4.14@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4' locally
docker.io/ocaml/opam@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4: Pulling from ocaml/opam
913254a25f5e: Already exists
d4181e0c64b1: Already exists
60067d417858: Already exists
85acc1d96727: Already exists
3ed6ed890bcc: Already exists
2dbf4e493c82: Already exists
2392a1c0faf2: Already exists
a887790579d0: Already exists
6bf6091e80a7: Already exists
8335ff7d796a: Already exists
a5cf80048a8d: Already exists
11557f96dff6: Already exists
5ffa47544a64: Already exists
b92bc0bdd77f: Already exists
11bee46e736c: Already exists
6cdee63da433: Already exists
bd6b847c6301: Already exists
ef94452a17d0: Already exists
bd4498e2bf68: Already exists
cae9012f5512: Already exists
97e1a82ddbc1: Already exists
4f4fb700ef54: Already exists
a36b4f4c3856: Already exists
ba5c5eee93b2: Already exists
ccef58c1ec23: Already exists
f58caa225e78: Already exists
e5b816875ec7: Already exists
637cd996e729: Already exists
4798bd4315ce: Already exists
1a9d0398727f: Already exists
87a13479d21f: Already exists
826d12795d2a: Already exists
ec3c50c293a6: Already exists
75873b00ea39: Already exists
2dc1ede51ef9: Already exists
e521104f43f2: Already exists
5adb34782261: Already exists
3902e7196407: Already exists
58655837ed1a: Already exists
48f0059e882a: Already exists
f295b5eefcb4: Pulling fs layer
edce86b5f8fb: Pulling fs layer
bb5db9673a61: Pulling fs layer
05ea7405a998: Pulling fs layer
05ea7405a998: Waiting
edce86b5f8fb: Verifying Checksum
edce86b5f8fb: Download complete
bb5db9673a61: Verifying Checksum
bb5db9673a61: Download complete
05ea7405a998: Verifying Checksum
05ea7405a998: Download complete
f295b5eefcb4: Verifying Checksum
f295b5eefcb4: Download complete
f295b5eefcb4: Pull complete
edce86b5f8fb: Pull complete
bb5db9673a61: Pull complete
05ea7405a998: Pull complete
Digest: sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4
Status: Downloaded newer image for ocaml/opam@sha256:2ec3acb358ede65444e2c01012b8324279d362d1b5a123d68f479f6dd50c48f4
2025-10-17 01:41.55 ---> using "55ae748f998e54835d3967fc6571b603b5ee1c5ff4e316d4c116f7c103a9c488" from cache
/: (comment debian-13-4.14_riscv64_opam-2.4)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (workdir /src)
/src: (run (shell "sudo ln -f /usr/bin/opam-2.4 /usr/bin/opam"))
2025-10-17 01:41.55 ---> using "c00b7fb0f14ee1c4f7d61067bbfa694b3be6391e35e49cc0aaf32d7c4e3d53f8" 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
2025-10-17 01:41.55 ---> using "855a2ad17f6bcf2293c394a91ad81b4660f67f6158dd85f342100a047bf5312e" from cache
/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.10.113-scw1
The OCaml toplevel, version 4.14.2
2.4.1
2025-10-17 01:41.55 ---> using "a4ce8f05afc8d1524197ee77c40d77385ba3c1dd7324a7828030078cefe93e49" from cache
/src: (workdir /src)
/src: (run (shell "sudo chown opam /src"))
2025-10-17 01:41.55 ---> using "b44f2387602157265122ccd9b42a9e7ae7bea0745aff65db47cf7ea002fcfa4d" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 209109366a444d7ea71a56ee6cb8f608cdc6ced0 || git fetch origin master) && git reset -q --hard 209109366a444d7ea71a56ee6cb8f608cdc6ced0 && git log --no-decorate -n1 --oneline && opam update -u"))
209109366a Merge pull request #28553 from dinosaure/release-base64-v3.5.2
<><> 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.3.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)
2025-10-17 01:43.17 ---> saved as "90ee6abaec2438b965215840d1d011ff7bc1f48fe62523f7e950d7b8c21f4056"
/src: (copy (src grpc.opam grpc-lwt.opam) (dst ./))
2025-10-17 01:43.18 ---> saved as "95e7f14db8cd04893fe21b131a95d6e20e59fa7543db2397050e7407908c6a31"
/src: (run (network host)
(shell "opam pin add -yn grpc.dev './' && \
\nopam pin add -yn grpc-lwt.dev './'"))
[grpc.dev] synchronised (file:///src)
grpc is now pinned to file:///src (version dev)
[grpc-lwt.dev] synchronised (file:///src)
The following additional pinnings are required by grpc-lwt.dev:
- h2.dev at git+https://github.com/anmonteiro/ocaml-h2#7df18604ae389e3151f79e2be5dfd4278d4377fb
Pin and install them? [Y/n] y
[h2.dev] synchronised (no changes)
h2 is now pinned to git+https://github.com/anmonteiro/ocaml-h2#7df18604ae389e3151f79e2be5dfd4278d4377fb (version dev)
grpc-lwt is now pinned to file:///src (version dev)
2025-10-17 01:43.47 ---> saved as "a2880de8bc0f16f21626687cb2decaf2386f5b92fe499f9e2d2917ef755dad5a"
/src: (run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
2025-10-17 01:43.47 ---> saved as "b4560b9203a9788ad1e961d59a045385d03cea958afc5d398933d039bb7d119d"
/src: (env DEPS "angstrom.0.16.1 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bigstringaf.0.10.0 cppo.1.8.0 csexp.1.5.2 dune.3.20.2 dune-configurator.3.20.2 faraday.0.8.2 h2.dev hpack.0.13.0 httpaf.0.7.1 lwt.5.9.2 ocaml.4.14.2 ocaml-base-compiler.4.14.2 ocaml-config.2 ocaml-options-vanilla.1 ocaml-protoc.3.1.1 ocaml-syntax-shims.1.0.0 ocamlfind.1.9.8 ocplib-endian.1.2 pbrt.3.1.1 psq.0.2.1 result.1.5 seq.base stdlib-shims.0.3.0 stringext.1.6.0 uri.4.4.0")
/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.4 --depext-only -y grpc.dev grpc-lwt.dev $DEPS"))
+ /usr/bin/sudo "apt-get" "update"
- Hit:1 http://deb.debian.org/debian trixie InRelease
- 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-security trixie-security/main riscv64 Packages [49.5 kB]
- Fetched 140 kB in 0s (314 kB/s)
- Reading package lists...
-
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[grpc.dev] synchronised (file:///src)
[grpc-lwt.dev] synchronised (file:///src)
[h2.dev] synchronised (no changes)
[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).
2025-10-17 01:44.32 ---> saved as "e72fead2c2a5d54f239b07d3f163e534e54888731db6e90fea71336a537be392"
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[h2.dev] synchronised (no changes)
[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 24 packages
- install angstrom 0.16.1
- install base-bytes base
- install base64 3.5.2
- install bigstringaf 0.10.0
- install cppo 1.8.0
- install csexp 1.5.2
- install dune 3.20.2
- install dune-configurator 3.20.2
- install faraday 0.8.2
- install h2 dev (pinned)
- install hpack 0.13.0
- install httpaf 0.7.1
- install lwt 5.9.2
- install ocaml-protoc 3.1.1
- install ocaml-syntax-shims 1.0.0
- install ocamlfind 1.9.8
- install ocplib-endian 1.2
- install pbrt 3.1.1
- install psq 0.2.1
- install result 1.5
- install seq base
- install stdlib-shims 0.3.0
- install stringext 1.6.0
- install uri 4.4.0
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.16.1 (cached)
-> retrieved base64.3.5.2 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved cppo.1.8.0 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved faraday.0.8.2 (cached)
-> retrieved hpack.0.13.0 (cached)
-> retrieved httpaf.0.7.1 (cached)
-> retrieved lwt.5.9.2 (cached)
-> retrieved ocaml-protoc.3.1.1, pbrt.3.1.1 (cached)
-> retrieved h2.dev (no changes)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocplib-endian.1.2 (cached)
-> retrieved ocamlfind.1.9.8 (cached)
-> retrieved psq.0.2.1 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved result.1.5 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved stringext.1.6.0 (cached)
-> retrieved uri.4.4.0 (cached)
-> retrieved dune.3.20.2, dune-configurator.3.20.2 (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed dune.3.20.2
-> installed base64.3.5.2
-> installed csexp.1.5.2
-> installed psq.0.2.1
-> installed cppo.1.8.0
-> installed ocaml-syntax-shims.1.0.0
-> installed result.1.5
-> installed stdlib-shims.0.3.0
-> installed ocplib-endian.1.2
-> installed stringext.1.6.0
-> installed pbrt.3.1.1
-> installed dune-configurator.3.20.2
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed faraday.0.8.2
-> installed ocaml-protoc.3.1.1
-> installed hpack.0.13.0
-> installed httpaf.0.7.1
-> installed uri.4.4.0
-> installed h2.dev
-> installed lwt.5.9.2
Done.
# To update the current shell environment, run: eval $(opam env)
2025-10-17 01:50.04 ---> saved as "0e75703395b4bf05f05d99458178e28d47d043fcfb6492e57694c933c1405ac0"
/src: (copy (src .) (dst /src))
2025-10-17 01:50.04 ---> saved as "c5b7869d0a978808d2bb77e1fec3fb079d47575944859ac2272dbca4d024ff0c"
/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
File "examples/greeter/dune", lines 5-10, characters 0-203:
5 | (rule
6 | (targets greeter_pb.ml greeter_pb.mli greeter_pp.ml greeter_pp.mli
7 | greeter_types.ml greeter_types.mli)
8 | (action
9 | (run ocaml-protoc -binary -pp -ml_out ./ greeter.proto))
10 | (deps greeter.proto))
(cd _build/default/examples/greeter && /home/opam/.opam/4.14/bin/ocaml-protoc -binary -pp -ml_out ./ greeter.proto)
/home/opam/.opam/4.14/bin/ocaml-protoc: unknown option '-binary'.
ocaml-protoc -ml_out <output_directory> <file_name>.proto
--yojson generate yojson encoding
--bs generate BuckleScript encoding
--binary generate binary encoding
--pp generate pretty print functions
--dump_type_repr generate comments with internal representation on generated OCaml types (useful for debugging ocaml-protoc itself)
--services generate code for services (requires json+binary)
-I include directories
--ml_out output directory
--debug print logs on stderr
--unsigned tag uint32 and uint64 types with `unsigned
--make generate `make` functions
--int32_type int32_type file option
--int64_type int64_type file option
--ocaml_file_ppx ocaml_file_ppx file option
--ocaml_all_types_ppx ocaml_all_types_ppx file option
-help Display this list of options
--help Display this list of options
File "examples/greeter-server-lwt/dune", line 3, characters 63-74:
3 | (libraries grpc grpc-lwt ocaml-protoc lwt lwt.unix greeter h2 h2-lwt-unix))
^^^^^^^^^^^
Error: Library "h2-lwt-unix" not found.
-> required by
_build/default/examples/greeter-server-lwt/.greeter_server_lwt.eobjs/byte/dune__exe__Greeter_server_lwt.cmi
-> required by alias examples/greeter-server-lwt/check
"/usr/bin/env" "bash" "-c" "opam exec -- dune build @install @check @runtest && rm -rf _build" failed with exit status 1
2025-10-17 01:50.08: Job failed: Failed: Build failed