Organisationsrobur-coopmiragevpn74f05c (main)(lint-doc)

(lint-doc)

Link Copied
Code Copied

Logs

2026-04-29 00:34.06: New job: test robur-coop/miragevpn https://github.com/robur-coop/miragevpn.git#refs/heads/main (74f05c75a446601cb738661c7a545ec1a13792f1) (linux-x86_64:(lint-doc))
Base: ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9
Opam project lint documentation


To reproduce locally:


git clone --recursive "https://github.com/robur-coop/miragevpn.git" -b "main" && cd "miragevpn" && git reset --hard 74f05c75
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9
# alpine-3.23-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.2 /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 dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd || git fetch origin master) && git reset -q --hard dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 miragevpn.opam ./
RUN opam pin add -yn miragevpn.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="afl-persistent.1.4 alcotest.1.9.1 angstrom.0.16.1 arp.4.1.0 asn1-combinators.0.3.2 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bechamel.0.5.0 bechamel-notty.0.5.0 bigstringaf.0.10.0 bisect_ppx.2.8.3 bos.0.3.0 ca-certs.1.0.1 ca-certs-nss.3.121 checkseum.0.5.3 cmdliner.1.3.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 cstruct.6.2.0 cstruct-lwt.6.2.0 decompress.1.5.3 digestif.1.3.0 dns.10.2.5 dns-client.10.2.5 dns-client-lwt.10.2.5 dns-client-mirage.10.2.5 domain-name.0.5.0 dune.3.22.2 dune-configurator.3.22.2 duration.0.3.1 eqaf.0.10 ethernet.3.2.0 fmt.0.11.0 fpath.0.7.3 gmap.0.3.0 happy-eyeballs.2.0.1 happy-eyeballs-lwt.2.0.1 happy-eyeballs-mirage.2.0.1 hxd.0.4.0 ipaddr.5.6.2 ipaddr-cstruct.5.6.2 kdf.1.0.0 logs.0.10.0 lru.0.3.1 lwt.6.1.2 lwt-dllist.1.1.0 macaddr.5.6.2 macaddr-cstruct.5.6.2 metrics.0.5.0 mirage-crypto.2.1.0 mirage-crypto-ec.2.1.0 mirage-crypto-pk.2.1.0 mirage-crypto-rng.2.1.0 mirage-flow.5.0.0 mirage-kv.6.1.1 mirage-mtime.5.2.0 mirage-net.4.0.0 mirage-ptime.5.2.0 mirage-sleep.4.1.0 mtime.2.1.0 notty.0.2.3 ocaml.4.14.3 ocaml-base-compiler.4.14.3 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 optint.0.3.0 ppx_derivers.1.2.1 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 randomconv.0.2.0 re.1.14.0 rresult.0.7.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 tcpip.9.0.1 tls.2.0.4 tls-lwt.2.0.4 tls-mirage.2.0.4 topkg.1.1.1 tuntap.2.0.1 uutf.1.0.4 x509.1.0.6 zarith.1.14"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.2 --depext-only -y miragevpn.dev $DEPS
RUN opam install $DEPS
RUN opam install --yes dune 'odoc>=1.5.0'
COPY --chown=1000:1000 . /src/
RUN ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo "dune build @doc failed"; exit 2)


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


2026-04-29 00:34.06: Using cache hint "robur-coop/miragevpn-ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9-alpine-3.23-4.14_opam-2.5-587de8362a92a0e015ed4be1a8cd3a7e"
2026-04-29 00:34.06: Using OBuilder spec:
((from ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9)
(comment alpine-3.23-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.2 /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 dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd || git fetch origin master) && git reset -q --hard dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src miragevpn.opam) (dst ./))
(run (network host)
(shell "opam pin add -yn miragevpn.dev './'"))
(run (shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "afl-persistent.1.4 alcotest.1.9.1 angstrom.0.16.1 arp.4.1.0 asn1-combinators.0.3.2 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bechamel.0.5.0 bechamel-notty.0.5.0 bigstringaf.0.10.0 bisect_ppx.2.8.3 bos.0.3.0 ca-certs.1.0.1 ca-certs-nss.3.121 checkseum.0.5.3 cmdliner.1.3.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 cstruct.6.2.0 cstruct-lwt.6.2.0 decompress.1.5.3 digestif.1.3.0 dns.10.2.5 dns-client.10.2.5 dns-client-lwt.10.2.5 dns-client-mirage.10.2.5 domain-name.0.5.0 dune.3.22.2 dune-configurator.3.22.2 duration.0.3.1 eqaf.0.10 ethernet.3.2.0 fmt.0.11.0 fpath.0.7.3 gmap.0.3.0 happy-eyeballs.2.0.1 happy-eyeballs-lwt.2.0.1 happy-eyeballs-mirage.2.0.1 hxd.0.4.0 ipaddr.5.6.2 ipaddr-cstruct.5.6.2 kdf.1.0.0 logs.0.10.0 lru.0.3.1 lwt.6.1.2 lwt-dllist.1.1.0 macaddr.5.6.2 macaddr-cstruct.5.6.2 metrics.0.5.0 mirage-crypto.2.1.0 mirage-crypto-ec.2.1.0 mirage-crypto-pk.2.1.0 mirage-crypto-rng.2.1.0 mirage-flow.5.0.0 mirage-kv.6.1.1 mirage-mtime.5.2.0 mirage-net.4.0.0 mirage-ptime.5.2.0 mirage-sleep.4.1.0 mtime.2.1.0 notty.0.2.3 ocaml.4.14.3 ocaml-base-compiler.4.14.3 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 optint.0.3.0 ppx_derivers.1.2.1 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 randomconv.0.2.0 re.1.14.0 rresult.0.7.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 tcpip.9.0.1 tls.2.0.4 tls-lwt.2.0.4 tls-mirage.2.0.4 topkg.1.1.1 tuntap.2.0.1 uutf.1.0.4 x509.1.0.6 zarith.1.14")
(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.2 --depext-only -y miragevpn.dev $DEPS"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install $DEPS"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install --yes dune 'odoc>=1.5.0'"))
(copy (src .) (dst /src/))
(run (shell "ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo \"dune build @doc failed\"; exit 2)"))
)


2026-04-29 00:34.06: Waiting for resource in pool OCluster
2026-04-29 01:19.03: Waiting for worker…
2026-04-29 01:23.25: Got resource from pool OCluster
Building on doris.caelum.ci.dev
All commits already cached
HEAD is now at 74f05c7 Merge pull request #287 from robur-coop/mirage-410


(from ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9)
Unable to find image 'ocaml/opam:alpine-3.23-ocaml-4.14@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9' locally
docker.io/ocaml/opam@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9: Pulling from ocaml/opam
6a0ac1617861: Already exists
9630673831f3: Pulling fs layer
4cffb540229a: Pulling fs layer
aa3cee094119: Pulling fs layer
f2700202f619: Pulling fs layer
33135c7375d5: Pulling fs layer
1ea4b64ae955: Pulling fs layer
ca34ef70eda1: Pulling fs layer
d4998b6f8f35: Pulling fs layer
4a43cfe8648c: Pulling fs layer
453dd28eaace: Pulling fs layer
1ea4b64ae955: Waiting
a962f0379f0a: Pulling fs layer
f2700202f619: Waiting
ca34ef70eda1: Waiting
d4998b6f8f35: Waiting
4a43cfe8648c: Waiting
b68882dcbbd8: Pulling fs layer
453dd28eaace: Waiting
3f63b4eac828: Pulling fs layer
b68882dcbbd8: Waiting
33135c7375d5: Waiting
a962f0379f0a: Waiting
0720e1e1068a: Pulling fs layer
0676d4d6023a: Pulling fs layer
3f63b4eac828: Waiting
0720e1e1068a: Waiting
0ab690805f49: Pulling fs layer
fc0af979c0fe: Pulling fs layer
4f4fb700ef54: Pulling fs layer
0ab690805f49: Waiting
0676d4d6023a: Waiting
63f1d0bef8ae: Pulling fs layer
fc0af979c0fe: Waiting
4f4fb700ef54: Waiting
43fd6995d88f: Pulling fs layer
63f1d0bef8ae: Waiting
c775bfb331ab: Pulling fs layer
a7a9b5ed8780: Pulling fs layer
43fd6995d88f: Waiting
c775bfb331ab: Waiting
86ac791930d3: Pulling fs layer
a7a9b5ed8780: Waiting
2e34d70b785c: Pulling fs layer
56c554cb0baa: Pulling fs layer
86ac791930d3: Waiting
0109b7ea4beb: Pulling fs layer
2e34d70b785c: Waiting
56c554cb0baa: Waiting
a72aa581a14e: Pulling fs layer
0109b7ea4beb: Waiting
a72aa581a14e: Waiting
0b969b88b90b: Pulling fs layer
d1ae0e2bf910: Pulling fs layer
0b969b88b90b: Waiting
cfd8efe5a061: Pulling fs layer
a34595d6f491: Pulling fs layer
d1ae0e2bf910: Waiting
7333547f58a0: Pulling fs layer
cfd8efe5a061: Waiting
803cdf5f2902: Pulling fs layer
7333547f58a0: Waiting
a34595d6f491: Waiting
d74501489c54: Pulling fs layer
628aecb9cafb: Pulling fs layer
803cdf5f2902: Waiting
d74501489c54: Waiting
0c52f398a865: Pulling fs layer
c0458221ae1b: Pulling fs layer
0c52f398a865: Waiting
628aecb9cafb: Waiting
5f395ae7d7f2: Pulling fs layer
c0458221ae1b: Waiting
767edc63c5be: Pulling fs layer
5f395ae7d7f2: Waiting
f3eb2829860a: Pulling fs layer
767edc63c5be: Waiting
2cde0115c1f3: Pulling fs layer
f3eb2829860a: Waiting
2cde0115c1f3: Waiting
9630673831f3: Verifying Checksum
9630673831f3: Download complete
9630673831f3: Pull complete
4cffb540229a: Verifying Checksum
4cffb540229a: Download complete
4cffb540229a: Pull complete
33135c7375d5: Verifying Checksum
33135c7375d5: Download complete
aa3cee094119: Verifying Checksum
aa3cee094119: Download complete
f2700202f619: Verifying Checksum
f2700202f619: Download complete
1ea4b64ae955: Verifying Checksum
1ea4b64ae955: Download complete
ca34ef70eda1: Verifying Checksum
ca34ef70eda1: Download complete
d4998b6f8f35: Verifying Checksum
d4998b6f8f35: Download complete
4a43cfe8648c: Verifying Checksum
4a43cfe8648c: Download complete
453dd28eaace: Verifying Checksum
453dd28eaace: Download complete
a962f0379f0a: Verifying Checksum
a962f0379f0a: Download complete
b68882dcbbd8: Verifying Checksum
b68882dcbbd8: Download complete
3f63b4eac828: Verifying Checksum
3f63b4eac828: Download complete
0720e1e1068a: Verifying Checksum
0720e1e1068a: Download complete
0676d4d6023a: Download complete
0ab690805f49: Verifying Checksum
0ab690805f49: Download complete
fc0af979c0fe: Download complete
4f4fb700ef54: Verifying Checksum
4f4fb700ef54: Download complete
63f1d0bef8ae: Download complete
43fd6995d88f: Verifying Checksum
43fd6995d88f: Download complete
c775bfb331ab: Verifying Checksum
c775bfb331ab: Download complete
a7a9b5ed8780: Verifying Checksum
a7a9b5ed8780: Download complete
86ac791930d3: Verifying Checksum
86ac791930d3: Download complete
2e34d70b785c: Verifying Checksum
2e34d70b785c: Download complete
56c554cb0baa: Download complete
0109b7ea4beb: Download complete
a72aa581a14e: Download complete
0b969b88b90b: Verifying Checksum
0b969b88b90b: Download complete
d1ae0e2bf910: Verifying Checksum
d1ae0e2bf910: Download complete
cfd8efe5a061: Verifying Checksum
cfd8efe5a061: Download complete
7333547f58a0: Download complete
d74501489c54: Download complete
628aecb9cafb: Verifying Checksum
628aecb9cafb: Download complete
0c52f398a865: Download complete
aa3cee094119: Pull complete
f2700202f619: Pull complete
a34595d6f491: Verifying Checksum
a34595d6f491: Download complete
33135c7375d5: Pull complete
1ea4b64ae955: Pull complete
ca34ef70eda1: Pull complete
d4998b6f8f35: Pull complete
4a43cfe8648c: Pull complete
453dd28eaace: Pull complete
803cdf5f2902: Verifying Checksum
803cdf5f2902: Download complete
a962f0379f0a: Pull complete
b68882dcbbd8: Pull complete
3f63b4eac828: Pull complete
0720e1e1068a: Pull complete
0676d4d6023a: Pull complete
0ab690805f49: Pull complete
fc0af979c0fe: Pull complete
4f4fb700ef54: Pull complete
63f1d0bef8ae: Pull complete
43fd6995d88f: Pull complete
c775bfb331ab: Pull complete
a7a9b5ed8780: Pull complete
767edc63c5be: Verifying Checksum
767edc63c5be: Download complete
86ac791930d3: Pull complete
2e34d70b785c: Pull complete
56c554cb0baa: Pull complete
0109b7ea4beb: Pull complete
a72aa581a14e: Pull complete
0b969b88b90b: Pull complete
d1ae0e2bf910: Pull complete
cfd8efe5a061: Pull complete
f3eb2829860a: Verifying Checksum
f3eb2829860a: Download complete
2cde0115c1f3: Verifying Checksum
2cde0115c1f3: Download complete
c0458221ae1b: Verifying Checksum
c0458221ae1b: Download complete
5f395ae7d7f2: Verifying Checksum
5f395ae7d7f2: Download complete
a34595d6f491: Pull complete
7333547f58a0: Pull complete
803cdf5f2902: Pull complete
d74501489c54: Pull complete
628aecb9cafb: Pull complete
0c52f398a865: Pull complete
c0458221ae1b: Pull complete
5f395ae7d7f2: Pull complete
767edc63c5be: Pull complete
f3eb2829860a: Pull complete
2cde0115c1f3: Pull complete
Digest: sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9
Status: Downloaded newer image for ocaml/opam@sha256:c98c3afc38d39340ca2b1e9c3c1b8c127283806cba433dd4865c01d18c619ef9
2026-04-29 01:23.25 ---> using "8e65bc4d84a4bbc3f291f4c89c5f0411ea9740fc4228eddb2c11cbc44748b04d" from cache


/: (comment alpine-3.23-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.2 /usr/bin/opam"))
2026-04-29 01:23.25 ---> using "a94f933c2065f1331b71c9d3e0f08d7c877e02d1c25b554eec73dda9103c15f6" 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.


Continue? [y/n] y
This development 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.


Format upgrade done.


<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[ERROR] Could not update repository "ocaml-patches-overlay": "/usr/bin/git fetch -q" exited with code 128 "fatal: unable to access 'https://github.com/ocurrent/opam-repository/': Could not resolve host: github.com (Could not contact DNS servers)"
[default] Initialised
2026-04-29 01:23.25 ---> using "0678aa672a1705151eb4578727f122487bb660b3b643c09515818c4dbb12c0f6" from cache


/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 6.8.0-106-generic
The OCaml toplevel, version 4.14.3
2.2.1
2026-04-29 01:23.25 ---> using "df273397cca517dc161e28ee32665e29cb6793fc7fbc5bb6835668deef447115" from cache


/src: (workdir /src)


/src: (run (shell "sudo chown opam /src"))
2026-04-29 01:23.25 ---> using "33d1cd6aa27bee3bb7c0c5fb0e101a64b7f01d9760d7894b48dbbb6936f5a184" from cache


/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd || git fetch origin master) && git reset -q --hard dd592986d47d277a9eee2bf37e1c4aa3a0c3efbd && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch                  master     -> FETCH_HEAD
045748b2d8..dd592986d4  master     -> origin/master
dd592986d4 Merge pull request #29752 from raphael-proust/opam-publish-lwt.6.1.2


<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[ocaml-patches-overlay] no changes from git+https://github.com/ocurrent/opam-repository#patches
[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, which will ask permission to downgrade or uninstall the conflicting packages.
Nothing to do.
# Run eval $(opam env) to update the current shell environment
2026-04-29 01:23.25 ---> using "7d3adfe97371a16ee675db51698bd4b734df5d204e9b92fcf1d9744e12195857" from cache


/src: (copy (src miragevpn.opam) (dst ./))
2026-04-29 01:23.26 ---> saved as "844657e156a98f69c76e7e5504ed59bfdda92aba04bcbd3b135147b8edc87ff7"


/src: (run (network host)
(shell "opam pin add -yn miragevpn.dev './'"))
Package miragevpn does not exist, create as a NEW package? [y/n] y
[miragevpn.dev] synchronised (file:///src)
miragevpn is now pinned to file:///src (version dev)
2026-04-29 01:23.27 ---> saved as "f9268c538b6a421005eb8991f9bbd1642e514f9aece8851544a2f8f4fbd5d326"


/src: (run (shell "echo '(lang dune 3.0)' > './dune-project'"))
2026-04-29 01:23.27 ---> saved as "8d198fbbe50122ee54a87ad9e331348a32fc8cdaee5665f2520b69d5d562d30d"


/src: (env DEPS "afl-persistent.1.4 alcotest.1.9.1 angstrom.0.16.1 arp.4.1.0 asn1-combinators.0.3.2 astring.0.8.5 base-bigarray.base base-bytes.base base-threads.base base-unix.base base64.3.5.2 bechamel.0.5.0 bechamel-notty.0.5.0 bigstringaf.0.10.0 bisect_ppx.2.8.3 bos.0.3.0 ca-certs.1.0.1 ca-certs-nss.3.121 checkseum.0.5.3 cmdliner.1.3.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 cppo.1.8.0 crowbar.0.2.2 csexp.1.5.2 cstruct.6.2.0 cstruct-lwt.6.2.0 decompress.1.5.3 digestif.1.3.0 dns.10.2.5 dns-client.10.2.5 dns-client-lwt.10.2.5 dns-client-mirage.10.2.5 domain-name.0.5.0 dune.3.22.2 dune-configurator.3.22.2 duration.0.3.1 eqaf.0.10 ethernet.3.2.0 fmt.0.11.0 fpath.0.7.3 gmap.0.3.0 happy-eyeballs.2.0.1 happy-eyeballs-lwt.2.0.1 happy-eyeballs-mirage.2.0.1 hxd.0.4.0 ipaddr.5.6.2 ipaddr-cstruct.5.6.2 kdf.1.0.0 logs.0.10.0 lru.0.3.1 lwt.6.1.2 lwt-dllist.1.1.0 macaddr.5.6.2 macaddr-cstruct.5.6.2 metrics.0.5.0 mirage-crypto.2.1.0 mirage-crypto-ec.2.1.0 mirage-crypto-pk.2.1.0 mirage-crypto-rng.2.1.0 mirage-flow.5.0.0 mirage-kv.6.1.1 mirage-mtime.5.2.0 mirage-net.4.0.0 mirage-ptime.5.2.0 mirage-sleep.4.1.0 mtime.2.1.0 notty.0.2.3 ocaml.4.14.3 ocaml-base-compiler.4.14.3 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocamlbuild.0.16.1 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 optint.0.3.0 ppx_derivers.1.2.1 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 randomconv.0.2.0 re.1.14.0 rresult.0.7.0 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 tcpip.9.0.1 tls.2.0.4 tls-lwt.2.0.4 tls-mirage.2.0.4 topkg.1.1.1 tuntap.2.0.1 uutf.1.0.4 x509.1.0.6 zarith.1.14")


/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.2 --depext-only -y miragevpn.dev $DEPS"))
+ /usr/bin/sudo "apk" "update"
- v3.23.4-87-g1a6cf4ecc50 [https://dl-cdn.alpinelinux.org/alpine/v3.23/main]
- v3.23.4-87-g1a6cf4ecc50 [https://dl-cdn.alpinelinux.org/alpine/v3.23/community]
- v20260127-8640-gf3f2df533bb [https://dl-cdn.alpinelinux.org/alpine/edge/main]
- v20260127-8638-g4cfa8f7bcce [https://dl-cdn.alpinelinux.org/alpine/edge/community]
- v20260127-8639-gdef12764805 [https://dl-cdn.alpinelinux.org/alpine/edge/testing]
- OK: 62123 distinct packages available


<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[miragevpn.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.3).
[NOTE] Package ocaml is already installed (current version is 4.14.3).
[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 system packages will first need to be installed:
gmp-dev linux-headers


<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>


+ /usr/bin/sudo "apk" "add" "gmp-dev" "linux-headers"
- (1/3) Installing libgmpxx (6.3.0-r4)
- (2/3) Installing gmp-dev (6.3.0-r4)
- (3/3) Installing linux-headers (6.16.12-r0)
- OK: 344.5 MiB in 106 packages
2026-04-29 01:23.39 ---> saved as "9d24f489b9de7653fb5549d829adbfc9fd95e5fe822cd6df27e65212dabc81a6"


/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.3).
[NOTE] Package ocaml is already installed (current version is 4.14.3).
[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 92 packages
- install afl-persistent        1.4
- install alcotest              1.9.1
- install angstrom              0.16.1
- install arp                   4.1.0
- install asn1-combinators      0.3.2
- install astring               0.8.5
- install base-bytes            base
- install base64                3.5.2
- install bechamel              0.5.0
- install bechamel-notty        0.5.0
- install bigstringaf           0.10.0
- install bisect_ppx            2.8.3
- install bos                   0.3.0
- install ca-certs              1.0.1
- install ca-certs-nss          3.121
- install checkseum             0.5.3
- install cmdliner              1.3.0
- install conf-gmp              5
- install conf-gmp-powm-sec     4
- install conf-pkg-config       4
- install cppo                  1.8.0
- install crowbar               0.2.2
- install csexp                 1.5.2
- install cstruct               6.2.0
- install cstruct-lwt           6.2.0
- install decompress            1.5.3
- install digestif              1.3.0
- install dns                   10.2.5
- install dns-client            10.2.5
- install dns-client-lwt        10.2.5
- install dns-client-mirage     10.2.5
- install domain-name           0.5.0
- install dune                  3.22.2
- install dune-configurator     3.22.2
- install duration              0.3.1
- install eqaf                  0.10
- install ethernet              3.2.0
- install fmt                   0.11.0
- install fpath                 0.7.3
- install gmap                  0.3.0
- install happy-eyeballs        2.0.1
- install happy-eyeballs-lwt    2.0.1
- install happy-eyeballs-mirage 2.0.1
- install hxd                   0.4.0
- install ipaddr                5.6.2
- install ipaddr-cstruct        5.6.2
- install kdf                   1.0.0
- install logs                  0.10.0
- install lru                   0.3.1
- install lwt                   6.1.2
- install lwt-dllist            1.1.0
- install macaddr               5.6.2
- install macaddr-cstruct       5.6.2
- install metrics               0.5.0
- install mirage-crypto         2.1.0
- install mirage-crypto-ec      2.1.0
- install mirage-crypto-pk      2.1.0
- install mirage-crypto-rng     2.1.0
- install mirage-flow           5.0.0
- install mirage-kv             6.1.1
- install mirage-mtime          5.2.0
- install mirage-net            4.0.0
- install mirage-ptime          5.2.0
- install mirage-sleep          4.1.0
- install mtime                 2.1.0
- install notty                 0.2.3
- install ocaml-compiler-libs   v0.12.4
- install ocaml-syntax-shims    1.0.0
- install ocamlbuild            0.16.1
- install ocamlfind             1.9.8
- install ocplib-endian         1.2
- install ohex                  0.2.0
- install optint                0.3.0
- install ppx_derivers          1.2.1
- install ppxlib                0.35.0
- install psq                   0.2.1
- install ptime                 1.2.0
- install randomconv            0.2.0
- install re                    1.14.0
- install rresult               0.7.0
- install seq                   base
- install sexplib0              v0.17.0
- install stdlib-shims          0.3.0
- install tcpip                 9.0.1
- install tls                   2.0.4
- install tls-lwt               2.0.4
- install tls-mirage            2.0.4
- install topkg                 1.1.1
- install tuntap                2.0.1
- install uutf                  1.0.4
- install x509                  1.0.6
- install zarith                1.14


<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved afl-persistent.1.4  (cached)
-> retrieved arp.4.1.0  (cached)
-> retrieved angstrom.0.16.1  (cached)
-> retrieved asn1-combinators.0.3.2  (cached)
-> retrieved alcotest.1.9.1  (cached)
-> retrieved astring.0.8.5  (cached)
-> retrieved base64.3.5.2  (cached)
-> retrieved bechamel.0.5.0, bechamel-notty.0.5.0  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved bisect_ppx.2.8.3  (cached)
-> retrieved bos.0.3.0  (cached)
-> retrieved ca-certs.1.0.1  (cached)
-> retrieved checkseum.0.5.3  (cached)
-> retrieved conf-gmp.5  (cached)
-> retrieved conf-gmp-powm-sec.4  (cached)
-> retrieved cmdliner.1.3.0  (cached)
-> retrieved ca-certs-nss.3.121  (cached)
-> retrieved cppo.1.8.0  (cached)
-> installed conf-gmp.5
-> installed conf-pkg-config.4
-> retrieved crowbar.0.2.2  (cached)
-> retrieved csexp.1.5.2  (cached)
-> retrieved cstruct.6.2.0, cstruct-lwt.6.2.0  (cached)
-> installed conf-gmp-powm-sec.4
-> retrieved decompress.1.5.3  (cached)
-> retrieved domain-name.0.5.0  (cached)
-> retrieved dns.10.2.5, dns-client.10.2.5, dns-client-lwt.10.2.5, dns-client-mirage.10.2.5  (cached)
-> retrieved duration.0.3.1  (cached)
-> retrieved eqaf.0.10  (cached)
-> retrieved digestif.1.3.0  (cached)
-> retrieved ethernet.3.2.0  (cached)
-> retrieved fmt.0.11.0  (cached)
-> retrieved fpath.0.7.3  (cached)
-> retrieved gmap.0.3.0  (cached)
-> retrieved happy-eyeballs.2.0.1, happy-eyeballs-lwt.2.0.1, happy-eyeballs-mirage.2.0.1  (cached)
-> retrieved hxd.0.4.0  (cached)
-> retrieved ipaddr.5.6.2, ipaddr-cstruct.5.6.2, macaddr.5.6.2, macaddr-cstruct.5.6.2  (cached)
-> retrieved kdf.1.0.0  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lru.0.3.1  (cached)
-> retrieved lwt-dllist.1.1.0  (cached)
-> retrieved metrics.0.5.0  (cached)
-> retrieved lwt.6.1.2  (cached)
-> retrieved mirage-flow.5.0.0  (cached)
-> retrieved mirage-kv.6.1.1  (cached)
-> retrieved mirage-mtime.5.2.0  (cached)
-> retrieved mirage-net.4.0.0  (cached)
-> retrieved mirage-ptime.5.2.0  (cached)
-> retrieved mirage-sleep.4.1.0  (cached)
-> retrieved mtime.2.1.0  (cached)
-> retrieved notty.0.2.3  (cached)
-> retrieved ocaml-compiler-libs.v0.12.4  (cached)
-> retrieved ocaml-syntax-shims.1.0.0  (cached)
-> retrieved ocamlbuild.0.16.1  (cached)
-> retrieved ocamlfind.1.9.8  (cached)
-> retrieved ocplib-endian.1.2  (cached)
-> retrieved dune.3.22.2, dune-configurator.3.22.2  (cached)
-> retrieved mirage-crypto.2.1.0, mirage-crypto-ec.2.1.0, mirage-crypto-pk.2.1.0, mirage-crypto-rng.2.1.0  (cached)
-> retrieved ohex.0.2.0  (cached)
-> retrieved optint.0.3.0  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved psq.0.2.1  (cached)
-> retrieved randomconv.0.2.0  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved seq.base  (cached)
-> installed cmdliner.1.3.0
-> installed ocamlbuild.0.16.1
-> installed seq.base
-> retrieved ppxlib.0.35.0  (cached)
-> retrieved rresult.0.7.0  (cached)
-> retrieved sexplib0.v0.17.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved tcpip.9.0.1  (cached)
-> retrieved topkg.1.1.1  (cached)
-> retrieved tls.2.0.4, tls-lwt.2.0.4, tls-mirage.2.0.4  (cached)
-> retrieved tuntap.2.0.1  (cached)
-> retrieved uutf.1.0.4  (cached)
-> retrieved zarith.1.14  (cached)
-> retrieved x509.1.0.6  (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed topkg.1.1.1
-> installed zarith.1.14
-> installed rresult.0.7.0
-> installed uutf.1.0.4
-> installed fmt.0.11.0
-> installed mtime.2.1.0
-> installed ptime.1.2.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed dune.3.22.2
-> installed base64.3.5.2
-> installed lwt-dllist.1.1.0
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed bechamel.0.5.0
-> installed cppo.1.8.0
-> installed cstruct.6.2.0
-> installed domain-name.0.5.0
-> installed duration.0.3.1
-> installed eqaf.0.10
-> installed gmap.0.3.0
-> installed macaddr.5.6.2
-> installed metrics.0.5.0
-> installed mirage-mtime.5.2.0
-> installed mirage-ptime.5.2.0
-> installed ocaml-compiler-libs.v0.12.4
-> installed ocaml-syntax-shims.1.0.0
-> installed ohex.0.2.0
-> installed optint.0.3.0
-> installed ppx_derivers.1.2.1
-> installed psq.0.2.1
-> installed randomconv.0.2.0
-> installed re.1.14.0
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed ocplib-endian.1.2
-> installed macaddr-cstruct.5.6.2
-> installed lru.0.3.1
-> installed afl-persistent.1.4
-> installed ipaddr.5.6.2
-> installed ipaddr-cstruct.5.6.2
-> installed crowbar.0.2.2
-> installed digestif.1.3.0
-> installed tuntap.2.0.1
-> installed dune-configurator.3.22.2
-> installed alcotest.1.9.1
-> installed bigstringaf.0.10.0
-> installed checkseum.0.5.3
-> installed angstrom.0.16.1
-> installed decompress.1.5.3
-> installed mirage-crypto.2.1.0
-> installed lwt.6.1.2
-> installed mirage-net.4.0.0
-> installed mirage-flow.5.0.0
-> installed cstruct-lwt.6.2.0
-> installed mirage-kv.6.1.1
-> installed mirage-sleep.4.1.0
-> installed kdf.1.0.0
-> installed hxd.0.4.0
-> installed logs.0.10.0
-> installed notty.0.2.3
-> installed ethernet.3.2.0
-> installed happy-eyeballs.2.0.1
-> installed mirage-crypto-rng.2.1.0
-> installed arp.4.1.0
-> installed bechamel-notty.0.5.0
-> installed mirage-crypto-pk.2.1.0
-> installed dns.10.2.5
-> installed tcpip.9.0.1
-> installed happy-eyeballs-mirage.2.0.1
-> installed happy-eyeballs-lwt.2.0.1
-> installed dns-client.10.2.5
-> installed bos.0.3.0
-> installed mirage-crypto-ec.2.1.0
-> installed x509.1.0.6
-> installed ca-certs.1.0.1
-> installed ppxlib.0.35.0
-> installed ca-certs-nss.3.121
-> installed tls.2.0.4
-> installed tls-mirage.2.0.4
-> installed tls-lwt.2.0.4
-> installed dns-client-mirage.10.2.5
-> installed dns-client-lwt.10.2.5
-> installed bisect_ppx.2.8.3
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.3+afl ocaml-variants.4.14.3+options ocaml-option-afl
# Run eval $(opam env) to update the current shell environment
2026-04-29 01:24.33 ---> saved as "6e9f56adec181c22e9d4ed770d70f53bbf96e6408d643a2270e1a10b0285f033"


/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam install --yes dune 'odoc>=1.5.0'"))
[NOTE] Package dune is already installed (current version is 3.22.2).
The following actions will be performed:
=== install 5 packages
- install camlp-streams 5.0.1 [required by odoc-parser]
- install crunch        4.0.0 [required by odoc]
- install odoc          3.1.0
- install odoc-parser   3.1.0 [required by odoc]
- install tyxml         4.6.0 [required by odoc]


<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved camlp-streams.5.0.1  (cached)
-> retrieved crunch.4.0.0  (cached)
-> retrieved tyxml.4.6.0  (cached)
-> retrieved odoc.3.1.0, odoc-parser.3.1.0  (cached)
-> installed camlp-streams.5.0.1
-> installed crunch.4.0.0
-> installed odoc-parser.3.1.0
-> installed tyxml.4.6.0
-> installed odoc.3.1.0
Done.
# Run eval $(opam env) to update the current shell environment
2026-04-29 01:24.52 ---> saved as "38eb6788c175ab4761706dadb01e13a2d086fb9fa04c42179bf1a73443cfea0a"


/src: (copy (src .) (dst /src/))
2026-04-29 01:24.52 ---> saved as "e5145d396531e81319de6b8bf660eb85116ab2b0932768313378b71461d63761"


/src: (run (shell "ODOC_WARN_ERROR=false opam exec -- dune build @doc || (echo \"dune build @doc failed\"; exit 2)"))
2026-04-29 01:24.54 ---> saved as "7d889a91287a1895fca1b925181e2faf6b71c7b26aa7a8c31481308d4dde9963"
Job succeeded
2026-04-29 01:24.54: Job succeeded