Organisationsocaml-multicorepicosb3a6b2 (introduce-per_thread-cache)opensuse-15.6-5.3_opam-2.3

opensuse-15.6-5.3_opam-2.3

Logs

Steps to Reproduce
git clone --recursive "https://github.com/ocaml-multicore/picos.git" -b "introduce-per_thread-cache" && cd "picos" && git reset --hard b3a6b280
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85
# opensuse-15.6-5.3_opam-2.3
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
WORKDIR /src
RUN sudo ln -f /usr/bin/opam-2.3 /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 cf5182fecd136e84d8ca14d9c0774986a77f5209 || git fetch origin master) && git reset -q --hard cf5182fecd136e84d8ca14d9c0774986a77f5209 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam ./
RUN opam pin add -yn picos_std.dev './' && \
opam pin add -yn picos_mux.dev './' && \
opam pin add -yn picos_meta.dev './' && \
opam pin add -yn picos_lwt.dev './' && \
opam pin add -yn picos_io_cohttp.dev './' && \
opam pin add -yn picos_io.dev './' && \
opam pin add -yn picos_aux.dev './' && \
opam pin add -yn picos.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="alcotest.1.8.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.17.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.0 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.0.0 cohttp-lwt.6.0.0 cohttp-lwt-unix.6.0.0 conduit.7.1.0 conduit-lwt.7.1.0 conduit-lwt-unix.7.1.0 conf-gmp.4 conf-gmp-powm-sec.3 conf-npm.1 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.2.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.17.2 dune-configurator.3.17.2 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.9.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.0.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.7.0 lwt.5.9.0 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.3.7.3 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.15.0 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 psq.0.2.1 ptime.1.2.0 qcheck-core.0.23 qcheck-multicoretests-util.0.7 qcheck-stm.0.7 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.3 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.7 tsort.2.1.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.3 x509.1.0.5 yojson.2.2.2 zarith.1.14"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.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 .
2025-02-18 13:52.30: New job: test ocaml-multicore/picos https://github.com/ocaml-multicore/picos.git#refs/heads/introduce-per_thread-cache (b3a6b280d7cdfe5a2e78cd53ebd5df561bb367ab) (linux-x86_64:opensuse-15.6-5.3_opam-2.3)
Base: ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85
Opam project build


To reproduce locally:


git clone --recursive "https://github.com/ocaml-multicore/picos.git" -b "introduce-per_thread-cache" && cd "picos" && git reset --hard b3a6b280
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85
# opensuse-15.6-5.3_opam-2.3
USER 1000:1000
ENV CLICOLOR_FORCE="1"
ENV OPAMCOLOR="always"
WORKDIR /src
RUN sudo ln -f /usr/bin/opam-2.3 /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 cf5182fecd136e84d8ca14d9c0774986a77f5209 || git fetch origin master) && git reset -q --hard cf5182fecd136e84d8ca14d9c0774986a77f5209 && git log --no-decorate -n1 --oneline && opam update -u
COPY --chown=1000:1000 picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam ./
RUN opam pin add -yn picos_std.dev './' && \
opam pin add -yn picos_mux.dev './' && \
opam pin add -yn picos_meta.dev './' && \
opam pin add -yn picos_lwt.dev './' && \
opam pin add -yn picos_io_cohttp.dev './' && \
opam pin add -yn picos_io.dev './' && \
opam pin add -yn picos_aux.dev './' && \
opam pin add -yn picos.dev './'
RUN echo '(lang dune 3.0)' > './dune-project'
ENV DEPS="alcotest.1.8.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.17.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.0 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.0.0 cohttp-lwt.6.0.0 cohttp-lwt-unix.6.0.0 conduit.7.1.0 conduit-lwt.7.1.0 conduit-lwt-unix.7.1.0 conf-gmp.4 conf-gmp-powm-sec.3 conf-npm.1 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.2.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.17.2 dune-configurator.3.17.2 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.9.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.0.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.7.0 lwt.5.9.0 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.3.7.3 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.15.0 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 psq.0.2.1 ptime.1.2.0 qcheck-core.0.23 qcheck-multicoretests-util.0.7 qcheck-stm.0.7 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.3 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.7 tsort.2.1.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.3 x509.1.0.5 yojson.2.2.2 zarith.1.14"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.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-02-18 13:52.30: Using cache hint "ocaml-multicore/picos-ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85-opensuse-15.6-5.3_opam-2.3-093c942912877c645c1b225a23f1a0cf"
2025-02-18 13:52.30: Using OBuilder spec:
((from ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85)
(comment opensuse-15.6-5.3_opam-2.3)
(user (uid 1000) (gid 1000))
(env CLICOLOR_FORCE 1)
(env OPAMCOLOR always)
(workdir /src)
(run (shell "sudo ln -f /usr/bin/opam-2.3 /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 cf5182fecd136e84d8ca14d9c0774986a77f5209 || git fetch origin master) && git reset -q --hard cf5182fecd136e84d8ca14d9c0774986a77f5209 && git log --no-decorate -n1 --oneline && opam update -u"))
(copy (src picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam)
(dst ./))
(run (network host)
(shell  "opam pin add -yn picos_std.dev './' && \
\nopam pin add -yn picos_mux.dev './' && \
\nopam pin add -yn picos_meta.dev './' && \
\nopam pin add -yn picos_lwt.dev './' && \
\nopam pin add -yn picos_io_cohttp.dev './' && \
\nopam pin add -yn picos_io.dev './' && \
\nopam pin add -yn picos_aux.dev './' && \
\nopam pin add -yn picos.dev './'"))
(run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
(env DEPS "alcotest.1.8.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.17.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.0 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.0.0 cohttp-lwt.6.0.0 cohttp-lwt-unix.6.0.0 conduit.7.1.0 conduit-lwt.7.1.0 conduit-lwt-unix.7.1.0 conf-gmp.4 conf-gmp-powm-sec.3 conf-npm.1 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.2.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.17.2 dune-configurator.3.17.2 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.9.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.0.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.7.0 lwt.5.9.0 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.3.7.3 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.15.0 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 psq.0.2.1 ptime.1.2.0 qcheck-core.0.23 qcheck-multicoretests-util.0.7 qcheck-stm.0.7 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.3 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.7 tsort.2.1.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.3 x509.1.0.5 yojson.2.2.2 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.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.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-02-18 13:52.30: Waiting for resource in pool OCluster
2025-02-18 18:20.22: Waiting for worker…
2025-02-18 18:27.22: Got resource from pool OCluster
Building on x86-bm-c3.sw.ocaml.org
All commits already cached
HEAD is now at b3a6b28 Introduce `Per_thread` cache


(from ocaml/opam:opensuse-15.6-ocaml-5.3@sha256:a7236a7ecea5493597309d4dfb0921efb6f22c774d113d8b1d867a2fafbd0e85)
2025-02-18 18:27.23 ---> using "01480b8d375178d58fb0ed99cc807a8272a29b3c89004466992274f3d0f7aebf" from cache


/: (comment opensuse-15.6-5.3_opam-2.3)


/: (user (uid 1000) (gid 1000))


/: (env CLICOLOR_FORCE 1)


/: (env OPAMCOLOR always)


/: (workdir /src)


/src: (run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-02-18 18:27.23 ---> using "8526c461f19d2d65ec20c8906fc7669eb961c05ebbdae44127fb55abe6651738" 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.
[NOTE] The 'jobs' option was reset, its value was 71 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
opam option jobs=71 --global


<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[ERROR] Could not update repository "opam-repository-archive": "/usr/bin/git fetch -q" exited with code 128 "fatal: unable to access 'https://github.com/ocaml/opam-repository-archive/': Could not resolve host: github.com"
[default] synchronised from file:///home/opam/opam-repository
2025-02-18 18:27.23 ---> using "f3d6b6709409d28b390c678c2becb71c6eb6d39b7e56205b09ca32a8972c1239" from cache


/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.15.0-130-generic
The OCaml toplevel, version 5.3.0
2.3.0
2025-02-18 18:27.23 ---> using "be45bc429d56468b28e0fae0dcfe058b794fdf9c4d2381bc5c90a28f2c919d0c" from cache


/src: (workdir /src)


/src: (run (shell "sudo chown opam /src"))
2025-02-18 18:27.23 ---> using "0b6e7a7ebd566d32327dd0dea5f63b63a61951f4dec5d6d69f3cd312a425bd50" from cache


/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e cf5182fecd136e84d8ca14d9c0774986a77f5209 || git fetch origin master) && git reset -q --hard cf5182fecd136e84d8ca14d9c0774986a77f5209 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch                  master     -> FETCH_HEAD
d87296a7b6..717e57b54b  master     -> origin/master
cf5182fecd Merge pull request #27465 from hannesm/release-domain-name-v0.4.1


<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[opam-repository-archive] synchronised from git+https://github.com/ocaml/opam-repository-archive
[default] synchronised from 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.
# To update the current shell environment, run: eval $(opam env)
2025-02-18 18:27.23 ---> using "5adb2f9870900351c67f3f073346b35b5b4f008a788393bff7db4dd220970a81" from cache


/src: (copy (src picos_std.opam picos_mux.opam picos_meta.opam picos_lwt.opam picos_io_cohttp.opam picos_io.opam picos_aux.opam picos.opam)
(dst ./))
2025-02-18 18:27.23 ---> using "6a318039f0fbfdfe499a5efca8e0cf80b379a1aef42a9d3210c334ee3cd70c01" from cache


/src: (run (network host)
(shell  "opam pin add -yn picos_std.dev './' && \
\nopam pin add -yn picos_mux.dev './' && \
\nopam pin add -yn picos_meta.dev './' && \
\nopam pin add -yn picos_lwt.dev './' && \
\nopam pin add -yn picos_io_cohttp.dev './' && \
\nopam pin add -yn picos_io.dev './' && \
\nopam pin add -yn picos_aux.dev './' && \
\nopam pin add -yn picos.dev './'"))
[picos_std.dev] synchronised (file:///src)
picos_std is now pinned to file:///src (version dev)
[picos_mux.dev] synchronised (file:///src)
picos_mux is now pinned to file:///src (version dev)
[picos_meta.dev] synchronised (file:///src)
picos_meta is now pinned to file:///src (version dev)
[picos_lwt.dev] synchronised (file:///src)
picos_lwt is now pinned to file:///src (version dev)
[picos_io_cohttp.dev] synchronised (file:///src)
picos_io_cohttp is now pinned to file:///src (version dev)
[picos_io.dev] synchronised (file:///src)
picos_io is now pinned to file:///src (version dev)
[picos_aux.dev] synchronised (file:///src)
picos_aux is now pinned to file:///src (version dev)
[picos.dev] synchronised (file:///src)
picos is now pinned to file:///src (version dev)
2025-02-18 18:27.23 ---> using "be9ab4deb5f40ec07025a9afedc559aa17646cd2264925bfebf4f0387afd9992" from cache


/src: (run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
2025-02-18 18:27.23 ---> using "cc9f93382cbf5a2896636b85a650934098ff4ee716ad980f9a5ab785178f847f" from cache


/src: (env DEPS "alcotest.1.8.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.17.1 base-bigarray.base base-bytes.base base-domains.base base-effects.base base-nnp.base base-threads.base base-unix.base base64.3.5.1 bigstringaf.0.10.0 bos.0.2.1 ca-certs.1.0.0 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.0.0 cohttp-lwt.6.0.0 cohttp-lwt-unix.6.0.0 conduit.7.1.0 conduit-lwt.7.1.0 conduit-lwt-unix.7.1.0 conf-gmp.4 conf-gmp-powm-sec.3 conf-npm.1 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.2.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.17.2 dune-configurator.3.17.2 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.9.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.0.0 ipaddr.5.6.0 ipaddr-sexp.5.6.0 js_of_ocaml.6.0.1 js_of_ocaml-compiler.6.0.1 kdf.1.0.0 logs.0.7.0 lwt.5.9.0 macaddr.5.6.0 magic-mime.1.3.1 mdx.2.5.0 menhir.20240715 menhirCST.20240715 menhirLib.20240715 menhirSdk.20240715 mirage-crypto.2.0.0 mirage-crypto-ec.2.0.0 mirage-crypto-pk.2.0.0 mirage-crypto-rng.2.0.0 mtime.2.1.0 multicore-bench.0.1.7 multicore-magic.2.3.1 multicore-magic-dscheck.2.3.1 ocaml.5.3.0 ocaml-base-compiler.5.3.0 ocaml-compiler.5.3.0 ocaml-compiler-libs.v0.17.0 ocaml-config.3 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.3.7.3 ocaml_intrinsics_kernel.v0.17.1 ocamlbuild.0.15.0 ocamlfind.1.9.8 ocplib-endian.1.2 ohex.0.2.0 oseq.0.5.1 ppx_derivers.1.2.1 ppx_sexp_conv.v0.17.0 ppxlib.0.35.0 ppxlib_jane.v0.17.2 psq.0.2.1 ptime.1.2.0 qcheck-core.0.23 qcheck-multicoretests-util.0.7 qcheck-stm.0.7 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.3 seq.base sexplib0.v0.17.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.7 tsort.2.1.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.3 x509.1.0.5 yojson.2.2.2 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.3 --depext-only -y picos_std.dev picos_mux.dev picos_meta.dev picos_lwt.dev picos_io_cohttp.dev picos_io.dev picos_aux.dev picos.dev $DEPS"))
+ /usr/bin/sudo "zypper" "--non-interactive" "refresh"
- Retrieving repository 'Update repository of openSUSE Backports' metadata [..........
- .done]
- Building repository 'Update repository of openSUSE Backports' cache [....done]
- Retrieving repository 'Update repository with updates from SUSE Linux Enterprise 15' metadata [......
- ..........
- .........
- .........
- ........
- .........
- .........
- ........
- ........
- ........
- .........
- .done]
- Building repository 'Update repository with updates from SUSE Linux Enterprise 15' cache [..
- ..done]
- Repository 'Main Update Repository' is up to date.
- Repository 'Update Repository (Non-Oss)' is up to date.
- Repository 'Non-OSS Repository' is up to date.
- Repository 'Main Repository' is up to date.
- All repositories have been refreshed.


<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[picos.dev] synchronised (file:///src)
[picos_aux.dev] synchronised (file:///src)
[picos_io.dev] synchronised (file:///src)
[picos_io_cohttp.dev] synchronised (file:///src)
[picos_lwt.dev] synchronised (file:///src)
[picos_meta.dev] synchronised (file:///src)
[picos_mux.dev] synchronised (file:///src)
[picos_std.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 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[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-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains 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-devel npm-default


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


+ /usr/bin/sudo "zypper" "--non-interactive" "install" "gmp-devel" "npm-default"
- Loading repository data...
- Reading installed packages...
- Resolving package dependencies...
- 
- The following 10 NEW packages are going to be installed:
-   gmp-devel libcares2 libgmpxx4 libicu73_2 libicu73_2-ledata nodejs-common nodejs-default nodejs20 npm-default npm20
- 
- 10 new packages to install.
- 
- Package download size:    23.3 MiB
- 
- Package install size change:
-               |      93.0 MiB  required by packages that will be installed
-     93.0 MiB  |  -      0 B    released by packages that will be removed
- 
- Backend:  classic_rpmtrans
- Continue? [y/n/v/...? shows all options] (y): y
- Retrieving: libcares2-1.19.1-150000.3.26.1.x86_64 (Main Repository) (1/10),  61.2 KiB
- Retrieving: libcares2-1.19.1-150000.3.26.1.x86_64.rpm [.done]
- Retrieving: libgmpxx4-6.1.2-4.9.1.x86_64 (Main Repository) (2/10),  17.1 KiB
- Retrieving: libgmpxx4-6.1.2-4.9.1.x86_64.rpm [.done]
- Retrieving: libicu73_2-ledata-73.2-150000.1.7.1.noarch (Main Repository) (3/10),   7.3 MiB
- Retrieving: libicu73_2-ledata-73.2-150000.1.7.1.noarch.rpm [...done (7.6 MiB/s)]
- Retrieving: gmp-devel-6.1.2-4.9.1.x86_64 (Main Repository) (4/10),   2.2 MiB
- Retrieving: gmp-devel-6.1.2-4.9.1.x86_64.rpm [..done (1.6 MiB/s)]
- Retrieving: libicu73_2-73.2-150000.1.7.1.x86_64 (Main Repository) (5/10),   1.8 MiB
- Retrieving: libicu73_2-73.2-150000.1.7.1.x86_64.rpm [..
- done]
- Retrieving: nodejs-common-6.0-150600.1.5.x86_64 (Main Repository) (6/10),  14.5 KiB
- Retrieving: nodejs-common-6.0-150600.1.5.x86_64.rpm [.done]
- Retrieving: nodejs20-20.18.2-150600.3.9.1.x86_64 (Update repository with updates from SUSE Linux Enterprise 15) (7/10),  10.1 MiB
- Retrieving: nodejs20-20.18.2-150600.3.9.1.x86_64.rpm [.....done (31.3 MiB/s)]
- Retrieving: nodejs-default-6.0-150600.1.5.x86_64 (Main Repository) (8/10),   9.8 KiB
- Retrieving: nodejs-default-6.0-150600.1.5.x86_64.rpm [.done]
- Retrieving: npm20-20.18.2-150600.3.9.1.x86_64 (Update repository with updates from SUSE Linux Enterprise 15) (9/10),   1.8 MiB
- Retrieving: npm20-20.18.2-150600.3.9.1.x86_64.rpm [..done (45.2 MiB/s)]
- Retrieving: npm-default-6.0-150600.1.5.x86_64 (Main Repository) (10/10),   9.8 KiB
- Retrieving: npm-default-6.0-150600.1.5.x86_64.rpm [.done]
- 
- Checking for file conflicts: [..
- .done]
- ( 1/10) Installing: libcares2-1.19.1-150000.3.26.1.x86_64 [..done]
- ( 2/10) Installing: libgmpxx4-6.1.2-4.9.1.x86_64 [..done]
- ( 3/10) Installing: libicu73_2-ledata-73.2-150000.1.7.1.noarch [.........
- ..done]
- ( 4/10) Installing: gmp-devel-6.1.2-4.9.1.x86_64 [....done]
- ( 5/10) Installing: libicu73_2-73.2-150000.1.7.1.x86_64 [....done]
- ( 6/10) Installing: nodejs-common-6.0-150600.1.5.x86_64 [..done]
- ( 7/10) Installing: nodejs20-20.18.2-150600.3.9.1.x86_64 [...
- ..........
- .
- update-alternatives: using /usr/bin/node20 to provide /usr/bin/node-default (node-default) in auto mode
- done]
- ( 8/10) Installing: nodejs-default-6.0-150600.1.5.x86_64 [..done]
- ( 9/10) Installing: npm20-20.18.2-150600.3.9.1.x86_64 [.....
- update-alternatives: using /usr/bin/npm20 to provide /usr/bin/npm-default (npm-default) in auto mode
- update-alternatives: using /usr/bin/npx20 to provide /usr/bin/npx-default (npx-default) in auto mode
- done]
- (10/10) Installing: npm-default-6.0-150600.1.5.x86_64 [..done]
2025-02-18 18:27.23 ---> using "6556c2347d7c299d61355a34c9190c1fe09e6286a9f3945109bafbc62343af30" from cache


/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 3).
[NOTE] Package ocaml-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml-base-compiler is already installed (current version is 5.3.0).
[NOTE] Package ocaml is already installed (current version is 5.3.0).
[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-nnp is already installed (current version is base).
[NOTE] Package base-effects is already installed (current version is base).
[NOTE] Package base-domains 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 99 packages
- install alcotest                   1.8.0
- install angstrom                   0.16.1
- install asn1-combinators           0.3.2
- install astring                    0.8.5
- install backoff                    0.1.1
- install base                       v0.17.1
- install base-bytes                 base
- install base64                     3.5.1
- install bigstringaf                0.10.0
- install bos                        0.2.1
- install ca-certs                   1.0.0
- install camlp-streams              5.0.1
- install cmdliner                   1.3.0
- install cohttp                     6.0.0
- install cohttp-lwt                 6.0.0
- install cohttp-lwt-unix            6.0.0
- install conduit                    7.1.0
- install conduit-lwt                7.1.0
- install conduit-lwt-unix           7.1.0
- install conf-gmp                   4
- install conf-gmp-powm-sec          3
- install conf-npm                   1
- install conf-pkg-config            4
- install containers                 3.15
- install cppo                       1.8.0
- install csexp                      1.5.2
- install digestif                   1.2.0
- install domain-local-await         1.0.1
- install domain-name                0.4.1
- install domain_shims               0.1.0
- install dscheck                    0.5.0
- install dune                       3.17.2
- install dune-configurator          3.17.2
- install duration                   0.2.1
- install either                     1.0.0
- install eqaf                       0.10
- install fmt                        0.9.0
- install fpath                      0.7.3
- install gen                        1.1
- install gmap                       0.3.0
- install http                       6.0.0
- install ipaddr                     5.6.0
- install ipaddr-sexp                5.6.0
- install js_of_ocaml                6.0.1
- install js_of_ocaml-compiler       6.0.1
- install kdf                        1.0.0
- install logs                       0.7.0
- install lwt                        5.9.0
- install macaddr                    5.6.0
- install magic-mime                 1.3.1
- install mdx                        2.5.0
- install menhir                     20240715
- install menhirCST                  20240715
- install menhirLib                  20240715
- install menhirSdk                  20240715
- install mirage-crypto              2.0.0
- install mirage-crypto-ec           2.0.0
- install mirage-crypto-pk           2.0.0
- install mirage-crypto-rng          2.0.0
- install mtime                      2.1.0
- install multicore-bench            0.1.7
- install multicore-magic            2.3.1
- install multicore-magic-dscheck    2.3.1
- install ocaml-compiler-libs        v0.17.0
- install ocaml-syntax-shims         1.0.0
- install ocaml-version              3.7.3
- install ocaml_intrinsics_kernel    v0.17.1
- install ocamlbuild                 0.15.0
- install ocamlfind                  1.9.8
- install ocplib-endian              1.2
- install ohex                       0.2.0
- install oseq                       0.5.1
- install ppx_derivers               1.2.1
- install ppx_sexp_conv              v0.17.0
- install ppxlib                     0.35.0
- install ppxlib_jane                v0.17.2
- install psq                        0.2.1
- install ptime                      1.2.0
- install qcheck-core                0.23
- install qcheck-multicoretests-util 0.7
- install qcheck-stm                 0.7
- install re                         1.12.0
- install result                     1.5
- install rresult                    0.7.0
- install sedlex                     3.3
- install seq                        base
- install sexplib0                   v0.17.0
- install stdlib-shims               0.3.0
- install stringext                  1.6.0
- install thread-local-storage       0.2
- install thread-table               1.0.0
- install topkg                      1.0.7
- install tsort                      2.1.0
- install uri                        4.4.0
- install uri-sexp                   4.4.0
- install uutf                       1.0.3
- install x509                       1.0.5
- install yojson                     2.2.2
- install zarith                     1.14


<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved asn1-combinators.0.3.2  (cached)
-> retrieved angstrom.0.16.1  (cached)
-> retrieved astring.0.8.5  (cached)
-> retrieved backoff.0.1.1  (cached)
-> retrieved alcotest.1.8.0  (cached)
-> retrieved base.v0.17.1  (cached)
-> retrieved base64.3.5.1  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved ca-certs.1.0.0  (cached)
-> retrieved bos.0.2.1  (cached)
-> retrieved camlp-streams.5.0.1  (cached)
-> retrieved cmdliner.1.3.0  (cached)
-> retrieved conf-gmp.4  (cached)
-> retrieved conf-gmp-powm-sec.3  (cached)
-> retrieved cohttp.6.0.0, cohttp-lwt.6.0.0, cohttp-lwt-unix.6.0.0, http.6.0.0  (cached)
-> retrieved conduit.7.1.0, conduit-lwt.7.1.0, conduit-lwt-unix.7.1.0  (cached)
-> retrieved containers.3.15  (cached)
-> installed conf-gmp.4
-> installed conf-npm.1
-> installed conf-pkg-config.4
-> retrieved cppo.1.8.0  (cached)
-> retrieved csexp.1.5.2  (cached)
-> retrieved domain-local-await.1.0.1  (cached)
-> installed conf-gmp-powm-sec.3
-> retrieved domain-name.0.4.1  (cached)
-> retrieved domain_shims.0.1.0  (cached)
-> retrieved dscheck.0.5.0  (cached)
-> retrieved duration.0.2.1  (cached)
-> retrieved either.1.0.0  (cached)
-> retrieved eqaf.0.10  (cached)
-> retrieved fmt.0.9.0  (cached)
-> retrieved fpath.0.7.3  (cached)
-> retrieved gen.1.1  (cached)
-> retrieved gmap.0.3.0  (cached)
-> retrieved ipaddr.5.6.0, ipaddr-sexp.5.6.0, macaddr.5.6.0  (cached)
-> retrieved digestif.1.2.0  (cached)
-> retrieved kdf.1.0.0  (cached)
-> retrieved logs.0.7.0  (cached)
-> retrieved lwt.5.9.0  (cached)
-> retrieved magic-mime.1.3.1  (cached)
-> retrieved mdx.2.5.0  (cached)
-> retrieved dune.3.17.2, dune-configurator.3.17.2  (cached)
-> retrieved js_of_ocaml.6.0.1, js_of_ocaml-compiler.6.0.1  (cached)
-> retrieved menhir.20240715, menhirCST.20240715, menhirLib.20240715, menhirSdk.20240715  (cached)
-> retrieved mirage-crypto.2.0.0, mirage-crypto-ec.2.0.0, mirage-crypto-pk.2.0.0, mirage-crypto-rng.2.0.0  (cached)
-> retrieved mtime.2.1.0  (cached)
-> retrieved multicore-bench.0.1.7  (cached)
-> retrieved multicore-magic.2.3.1, multicore-magic-dscheck.2.3.1  (cached)
-> retrieved ocaml-compiler-libs.v0.17.0  (cached)
-> installed cmdliner.1.3.0
-> retrieved ocaml-syntax-shims.1.0.0  (cached)
-> retrieved ocaml-version.3.7.3  (cached)
-> retrieved ocaml_intrinsics_kernel.v0.17.1  (cached)
-> retrieved ocamlbuild.0.15.0  (cached)
-> retrieved ocamlfind.1.9.8  (cached)
-> retrieved ocplib-endian.1.2  (cached)
-> retrieved ohex.0.2.0  (cached)
-> retrieved oseq.0.5.1  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppx_sexp_conv.v0.17.0  (cached)
-> retrieved ppxlib_jane.v0.17.2  (cached)
-> retrieved psq.0.2.1  (cached)
-> retrieved ptime.1.2.0  (cached)
-> retrieved qcheck-core.0.23  (cached)
-> retrieved qcheck-multicoretests-util.0.7, qcheck-stm.0.7  (cached)
-> retrieved re.1.12.0  (cached)
-> retrieved ppxlib.0.35.0  (cached)
-> retrieved result.1.5  (cached)
-> retrieved seq.base  (cached)
-> installed seq.base
-> retrieved rresult.0.7.0  (cached)
-> retrieved sedlex.3.3  (cached)
-> retrieved sexplib0.v0.17.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved stringext.1.6.0  (cached)
-> retrieved thread-local-storage.0.2  (cached)
-> retrieved thread-table.1.0.0  (cached)
-> retrieved topkg.1.0.7  (cached)
-> retrieved tsort.2.1.0  (cached)
-> retrieved uutf.1.0.3  (cached)
-> retrieved yojson.2.2.2  (cached)
-> retrieved uri.4.4.0, uri-sexp.4.4.0  (cached)
-> retrieved x509.1.0.5  (cached)
-> retrieved zarith.1.14  (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed ocamlbuild.0.15.0
-> installed zarith.1.14
-> installed topkg.1.0.7
-> installed rresult.0.7.0
-> installed mtime.2.1.0
-> installed uutf.1.0.3
-> installed fmt.0.9.0
-> installed ptime.1.2.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed dune.3.17.2
-> installed backoff.0.1.1
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed base64.3.5.1
-> installed camlp-streams.5.0.1
-> installed cppo.1.8.0
-> installed domain-name.0.4.1
-> installed domain_shims.0.1.0
-> installed duration.0.2.1
-> installed either.1.0.0
-> installed eqaf.0.10
-> installed gen.1.1
-> installed gmap.0.3.0
-> installed http.6.0.0
-> installed macaddr.5.6.0
-> installed magic-mime.1.3.1
-> installed menhirCST.20240715
-> installed menhirLib.20240715
-> installed menhirSdk.20240715
-> installed multicore-magic.2.3.1
-> installed ocaml-compiler-libs.v0.17.0
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml-version.3.7.3
-> installed ocaml_intrinsics_kernel.v0.17.1
-> installed ohex.0.2.0
-> installed oseq.0.5.1
-> installed ppx_derivers.1.2.1
-> installed psq.0.2.1
-> installed re.1.12.0
-> installed result.1.5
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed qcheck-core.0.23
-> installed thread-local-storage.0.2
-> installed thread-table.1.0.0
-> installed tsort.2.1.0
-> installed yojson.2.2.2
-> installed ocplib-endian.1.2
-> installed ipaddr.5.6.0
-> installed digestif.1.2.0
-> installed domain-local-await.1.0.1
-> installed qcheck-multicoretests-util.0.7
-> installed alcotest.1.8.0
-> installed multicore-bench.0.1.7
-> installed qcheck-stm.0.7
-> installed dune-configurator.3.17.2
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed mirage-crypto.2.0.0
-> installed kdf.1.0.0
-> installed containers.3.15
-> installed dscheck.0.5.0
-> installed multicore-magic-dscheck.2.3.1
-> installed uri.4.4.0
-> installed lwt.5.9.0
-> installed base.v0.17.1
-> installed menhir.20240715
-> installed ppxlib.0.35.0
-> installed ppxlib_jane.v0.17.2
-> installed sedlex.3.3
-> installed ppx_sexp_conv.v0.17.0
-> installed ipaddr-sexp.5.6.0
-> installed uri-sexp.4.4.0
-> installed js_of_ocaml-compiler.6.0.1
-> installed js_of_ocaml.6.0.1
-> installed logs.0.7.0
-> installed mirage-crypto-rng.2.0.0
-> installed mirage-crypto-pk.2.0.0
-> installed conduit.7.1.0
-> installed cohttp.6.0.0
-> installed mdx.2.5.0
-> installed bos.0.2.1
-> installed conduit-lwt.7.1.0
-> installed cohttp-lwt.6.0.0
-> installed mirage-crypto-ec.2.0.0
-> installed x509.1.0.5
-> installed ca-certs.1.0.0
-> installed conduit-lwt-unix.7.1.0
-> installed cohttp-lwt-unix.6.0.0
Done.
# To update the current shell environment, run: eval $(opam env)
2025-02-18 18:27.23 ---> using "2ba2c6e639dcc097674e68d05e9699dcb9bf95e3bf694aa03191bfae284061ff" from cache


/src: (copy (src .) (dst /src))
2025-02-18 18:27.23 ---> saved as "770730775094c1f02f4333ae70b1b0a5a8d4774aab36e73894f74e17fa4f91b2"


/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
(cd _build/default/test && ./test_server_and_client.exe)
Using blocking sockets and fibers on OCaml 5:
Looping server running
Client B running
Server listening
Server accepting
Client A running
Client A connected
Client A wrote 100
Server accepted client
Client B connected
Client B wrote 100
Server accepting
Server accepted client
Server accepting
Server read 100
Server wrote 50
Client B read 50
Server read 100
Server wrote 50
Client A read 50
Server and Client test: OK
(cd _build/default/test && ./test_lwt_unix.exe)
Testing `Picos_lwt'.
This run has ID `0J7WHETI'.


[OK]          Basics          0


Full test results in `/src/_build/default/test/_build/_tests/Picos_lwt'.
Test Successful in 0.051s. 1 test run.
(cd _build/default/test && ./test_finally.exe)
Testing `Picos_finally'.
This run has ID `JBNOGC1A'.


[OK]          move            0   is lazy.
[OK]          borrow          0   returns resource.


Full test results in `/src/_build/default/test/_build/_tests/Picos_finally'.
Test Successful in 0.013s. 2 tests run.
(cd _build/default/test && ./test_io.exe)
Testing `Picos_io'.
This run has ID `UI5447YS'.


[OK]          Unix          0   openfile and read.
[OK]          Unix          1   sleepf.
[OK]          Unix          2   select empty timeout.
[OK]          Unix          3   select empty ∞.
[OK]          Unix          4   select.
[OK]          Unix          5   system.


Full test results in `/src/_build/default/test/_build/_tests/Picos_io'.
Test Successful in 0.644s. 6 tests run.
(cd _build/default/test && ./test_sync.exe -- Event 0)
Testing `Picos_sync'.
This run has ID `NJL73T2M'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[OK]          Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.120s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- Lazy 0)
Testing `Picos_sync'.
This run has ID `ENRUSKGU'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[OK]          Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.035s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- Lazy 1)
Testing `Picos_sync'.
This run has ID `FQ3OV60N'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[OK]          Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.026s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- Semaphore 0)
Testing `Picos_sync'.
This run has ID `ZSJUCW04'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[OK]          Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.044s. 1 test run.
(cd _build/default/test && ./test_io_with_lwt.exe)
Testing `Picos_io_with_lwt'.
This run has ID `81TSQNFZ'.


[OK]          Unix          0   system.


Full test results in `/src/_build/default/test/_build/_tests/Picos_io_with_lwt'.
Test Successful in 2.109s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- Semaphore 1)
Testing `Picos_sync'.
This run has ID `GR7DJBM6'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[OK]          Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.403s. 1 test run.
(cd _build/default/test && ./test_select.exe)
Testing `Picos_select'.
This run has ID `52T3JHIC'.


[OK]          Intr          0


Full test results in `/src/_build/default/test/_build/_tests/Picos_select'.
Test Successful in 3.414s. 1 test run.
(cd _build/default/test && ./test_structured.exe)
Testing `Picos_structured'.
This run has ID `3I9HVU9E'.


[OK]          Bundle          0   fork after terminate.
[OK]          Bundle          1   fork after escape.
[OK]          Bundle          2   exception in child terminates.
[OK]          Bundle          3   cancelation awaits children.
[OK]          Bundle          4   block raises when forbidden.
[OK]          Bundle          5   block raises Sys_error when fiber finishes.
[OK]          Bundle          6   termination nests.
[OK]          Bundle          7   promise cancelation does not terminate.
[OK]          Bundle          8   error in promise terminates.
[OK]          Bundle          9   can wait promises.
[OK]          Bundle         10   can select promises.
[OK]          Run             0   any and all errors.
[OK]          Run             1   any and all returns.
[OK]          Run             2   race any.


Full test results in `/src/_build/default/test/_build/_tests/Picos_structured'.
Test Successful in 1.356s. 14 tests run.
(cd _build/default/test && ./test_sync.exe -- 'Non-cancelable ops' 0)
Testing `Picos_sync'.
This run has ID `CKP136IC'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[OK]          Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.091s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- 'Mutex and Condition' 0)
Testing `Picos_sync'.
This run has ID `ZC3H5TN7'.


[OK]          Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.003s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- 'Mutex and Condition' 1)
Testing `Picos_sync'.
This run has ID `DRSNL69D'.


[SKIP]        Mutex and Condition          0   basics.
[OK]          Mutex and Condition          1   errors.
[SKIP]        Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.071s. 1 test run.
(cd _build/default/test && ./test_io_cohttp.exe)
Uri: //127.0.0.1:48561/hello-io-cohttp
Method: POST


host: 127.0.0.1:48561
user-agent: ocaml-cohttp/v6.0.0
content-length: 17


Body: It's-a-Me, Picos!
(cd _build/default/test && ./test_picos_lwt_unix_with_cohttp.exe)
Uri: //127.0.0.1:8000/hello-lwt
Method: GET


host: 127.0.0.1:8000
user-agent: ocaml-cohttp/v6.0.0
content-length: 0


Body:
(cd _build/default/test && ./test_picos_dscheck.exe)
Testing `Picos DSCheck'.
This run has ID `IKO277YP'.


[OK]          Trigger              0   basic contract.
[OK]          Computation          0   basic contract.
[OK]          Computation          1   removes triggers.


Full test results in `/src/_build/default/test/_build/_tests/Picos DSCheck'.
Test Successful in 4.423s. 3 tests run.
(cd _build/default/test && ./test_sync.exe -- 'Mutex and Condition' 2)
Testing `Picos_sync'.
This run has ID `T4Q153AM'.


[SKIP]        Mutex and Condition          0   basics.
[SKIP]        Mutex and Condition          1   errors.
[OK]          Mutex and Condition          2   cancelation.
[SKIP]        Semaphore                    0   basics.
[SKIP]        Semaphore                    1   stress.
[SKIP]        Lazy                         0   basics.
[SKIP]        Lazy                         1   cancelation.
[SKIP]        Event                        0   basics.
[SKIP]        Non-cancelable ops           0   are not canceled.


Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 9.276s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Picos Computation')
Picos Computation:
attach detach pairs over time/1 worker:
0.62 M/s
attach detach pairs over time/2 workers:
1.08 M/s
attach detach pairs over time/4 workers:
0.87 M/s
attach detach pairs over time/trivial:
0.84 M/s
time per attach detach pair/1 worker:
1613.65 ns
time per attach detach pair/2 workers:
1852.10 ns
time per attach detach pair/4 workers:
4610.14 ns
time per attach detach pair/trivial:
1184.98 ns
(cd _build/default/test && ./test_mpmcq_dscheck.exe)
Testing `Picos_mpmcq DSCheck'.
This run has ID `88CUGZRZ'.


[OK]          Multiple pushes and pops          0


Full test results in `/src/_build/default/test/_build/_tests/Picos_mpmcq DSCheck'.
Test Successful in 12.288s. 1 test run.
(cd _build/default/test && /usr/bin/node test_js_of_ocaml.bc.js)
Hello, from js_of_ocaml with Picos!
(cd _build/default/bench && ./main.exe -brief 'Picos Current')
Picos Current:
ops over time/1 worker:
46.99 M/s
ops over time/2 workers:
31.90 M/s
ops over time/4 workers:
19.57 M/s
time per op/1 worker:
21.28 ns
time per op/2 workers:
62.70 ns
time per op/4 workers:
204.36 ns
(cd _build/default/bench && ./main.exe -brief 'Picos FLS (excluding Current)')
Picos FLS (excluding Current):
gets over time/1 worker:
122.30 M/s
gets over time/2 workers:
237.60 M/s
gets over time/4 workers:
90.59 M/s
sets over time/1 worker:
26.25 M/s
sets over time/2 workers:
82.41 M/s
sets over time/4 workers:
105.48 M/s
time per get/1 worker:
8.18 ns
time per get/2 workers:
8.42 ns
time per get/4 workers:
44.15 ns
time per set/1 worker:
38.10 ns
time per set/2 workers:
24.27 ns
time per set/4 workers:
37.92 ns
(cd _build/default/bench && ./main.exe -brief 'Picos TLS')
Picos TLS:
gets over time/1 worker:
16.23 M/s
gets over time/2 workers:
24.98 M/s
gets over time/4 workers:
59.97 M/s
sets over time/1 worker:
10.03 M/s
sets over time/2 workers:
35.76 M/s
sets over time/4 workers:
104.16 M/s
time per get/1 worker:
61.62 ns
time per get/2 workers:
80.06 ns
time per get/4 workers:
66.70 ns
time per set/1 worker:
99.71 ns
time per set/2 workers:
55.93 ns
time per set/4 workers:
38.40 ns
(cd _build/default/test && ./test_schedulers.exe)
Testing `Picos schedulers'.
This run has ID `ZQKJZ4HY'.


[OK]          Trivial main returns                          0
[OK]          Scheduler completes main computation          0
[OK]          Current                                       0
[OK]          Cancel_after                                  0   basic.
[OK]          Cancel_after                                  1   long timeout.
[OK]          Operation on canceled fiber raises            0
[OK]          Cross scheduler wakeup                        0
[OK]          Fatal exception terminates scheduler          0


Full test results in `/src/_build/default/test/_build/_tests/Picos schedulers'.
Test Successful in 36.612s. 8 tests run.
(cd _build/default/bench && ./main.exe -brief 'Picos DLS')
Picos DLS:
gets over time/1 worker:
75.14 M/s
gets over time/2 workers:
122.82 M/s
gets over time/4 workers:
307.40 M/s
sets over time/1 worker:
55.43 M/s
sets over time/2 workers:
97.87 M/s
sets over time/4 workers:
119.53 M/s
time per get/1 worker:
13.31 ns
time per get/2 workers:
16.28 ns
time per get/4 workers:
13.01 ns
time per set/1 worker:
18.04 ns
time per set/2 workers:
20.44 ns
time per set/4 workers:
33.46 ns
(cd _build/default/bench && ./main.exe -brief 'Picos Mutex')
Picos Mutex:
locked yields over time/1024 fibers:
0.84 M/s
locked yields over time/1 fiber:
2.65 M/s
locked yields over time/256 fibers:
0.36 M/s
locked yields over time/2 domains:
1.29 M/s
locked yields over time/2 fibers:
1.06 M/s
locked yields over time/4 domains:
0.30 M/s
locked yields over time/4 fibers:
0.29 M/s
locked yields over time/512 fibers:
0.79 M/s
locked yields over time/8 domains:
0.40 M/s
locked yields over time/8 fibers:
0.55 M/s
time per locked yield/1024 fibers:
1184.67 ns
time per locked yield/1 fiber:
377.95 ns
time per locked yield/256 fibers:
2770.30 ns
time per locked yield/2 domains:
1554.38 ns
time per locked yield/2 fibers:
942.50 ns
time per locked yield/4 domains:
13304.59 ns
time per locked yield/4 fibers:
3480.41 ns
time per locked yield/512 fibers:
1273.31 ns
time per locked yield/8 domains:
20040.55 ns
time per locked yield/8 fibers:
1827.47 ns
(cd _build/default/test && ./test_picos.exe)
Testing `Picos'.
This run has ID `EG3DCEQD'.


[OK]          Trigger               0   basics.
[OK]          Computation           0   basics.
[OK]          Computation           1   tx.
[OK]          Computation           2   signals in order.
[OK]          Fiber.FLS             0   basics.
[OK]          Cancel                0
[OK]          Cancel after          0


Full test results in `/src/_build/default/test/_build/_tests/Picos'.
Test Successful in 41.037s. 7 tests run.
(cd _build/default/bench && ./main.exe -brief 'Picos Semaphore')
Picos Semaphore:
acquired yields over time/4 domains, 1 resource:
0.53 M/s
acquired yields over time/4 domains, 2 resources:
0.91 M/s
acquired yields over time/4 domains, 3 resources:
2.94 M/s
acquired yields over time/4 domains, 4 resources:
5.13 M/s
acquired yields over time/4 fibers, 1 resource:
0.34 M/s
acquired yields over time/4 fibers, 2 resources:
0.58 M/s
acquired yields over time/4 fibers, 3 resources:
0.85 M/s
acquired yields over time/4 fibers, 4 resources:
2.66 M/s
time per acquired yield/4 domains, 1 resource:
7515.40 ns
time per acquired yield/4 domains, 2 resources:
4387.14 ns
time per acquired yield/4 domains, 3 resources:
1360.74 ns
time per acquired yield/4 domains, 4 resources:
779.77 ns
time per acquired yield/4 fibers, 1 resource:
2971.44 ns
time per acquired yield/4 fibers, 2 resources:
1735.86 ns
time per acquired yield/4 fibers, 3 resources:
1174.35 ns
time per acquired yield/4 fibers, 4 resources:
376.23 ns
(cd _build/default/bench && ./main.exe -brief 'Picos Spawn')
Picos Spawn:
spawns over time/with packed computation:
4.56 M/s
time per spawn/with packed computation:
219.45 ns
(cd _build/default/bench && ./main.exe -brief 'Picos Yield')
Picos Yield:
time per yield/10000 fibers:
528.82 ns
time per yield/1000 fibers:
121.99 ns
time per yield/100 fibers:
108.10 ns
time per yield/10 fibers:
171.16 ns
time per yield/1 fiber:
187.62 ns
yields over time/10000 fibers:
1.89 M/s
yields over time/1000 fibers:
8.20 M/s
yields over time/100 fibers:
9.25 M/s
yields over time/10 fibers:
5.84 M/s
yields over time/1 fiber:
5.33 M/s
(cd _build/default/bench && ./main.exe -brief 'Picos Cancel_after with Picos_select')
Picos Cancel_after with Picos_select:
async round-trips over time/1 worker:
0.07 M/s
async round-trips over time/2 workers:
0.17 M/s
async round-trips over time/4 workers:
0.87 M/s
round-trips over time/1 worker:
0.04 M/s
round-trips over time/2 workers:
0.08 M/s
round-trips over time/4 workers:
0.17 M/s
time per async round-trip/1 worker:
14160.02 ns
time per async round-trip/2 workers:
11658.25 ns
time per async round-trip/4 workers:
4597.92 ns
time per round-trip/1 worker:
23871.55 ns
time per round-trip/2 workers:
25164.79 ns
time per round-trip/4 workers:
23545.35 ns
(cd _build/default/bench && ./main.exe -brief 'Ref with Picos_sync.Mutex')
Ref with Picos_sync.Mutex:
ops over time/cas int (checked):
5.04 M/s
ops over time/cas int (unchecked):
17.29 M/s
ops over time/get (checked):
6.84 M/s
ops over time/get (unchecked):
15.41 M/s
ops over time/incr (checked):
5.99 M/s
ops over time/incr (unchecked):
14.87 M/s
ops over time/push & pop (checked):
6.42 M/s
ops over time/push & pop (unchecked):
12.36 M/s
ops over time/swap (checked):
5.48 M/s
ops over time/swap (unchecked):
14.15 M/s
ops over time/xchg int (checked):
5.57 M/s
ops over time/xchg int (unchecked):
16.25 M/s
time per op/cas int (checked):
198.34 ns
time per op/cas int (unchecked):
57.83 ns
time per op/get (checked):
146.27 ns
time per op/get (unchecked):
64.91 ns
time per op/incr (checked):
166.88 ns
time per op/incr (unchecked):
67.26 ns
time per op/push & pop (checked):
155.70 ns
time per op/push & pop (unchecked):
80.94 ns
time per op/swap (checked):
182.58 ns
time per op/swap (unchecked):
70.68 ns
time per op/xchg int (checked):
179.45 ns
time per op/xchg int (unchecked):
61.54 ns
(cd _build/default/bench && ./main.exe -brief Picos_mpmcq)
Picos_mpmcq:
messages over time/1 nb adder, 1 nb taker:
10.89 M/s
messages over time/1 nb adder, 2 nb takers:
18.84 M/s
messages over time/1 nb adder, 4 nb takers:
13.19 M/s
messages over time/2 nb adders, 1 nb taker:
24.27 M/s
messages over time/2 nb adders, 2 nb takers:
22.53 M/s
messages over time/2 nb adders, 4 nb takers:
18.22 M/s
messages over time/4 nb adders, 1 nb taker:
14.81 M/s
messages over time/4 nb adders, 2 nb takers:
20.84 M/s
messages over time/4 nb adders, 4 nb takers:
15.85 M/s
messages over time/one domain:
15.17 M/s
time per message/1 nb adder, 1 nb taker:
183.74 ns
time per message/1 nb adder, 2 nb takers:
159.21 ns
time per message/1 nb adder, 4 nb takers:
379.06 ns
time per message/2 nb adders, 1 nb taker:
123.61 ns
time per message/2 nb adders, 2 nb takers:
177.55 ns
time per message/2 nb adders, 4 nb takers:
329.39 ns
time per message/4 nb adders, 1 nb taker:
337.71 ns
time per message/4 nb adders, 2 nb takers:
287.85 ns
time per message/4 nb adders, 4 nb takers:
504.69 ns
time per message/one domain:
65.93 ns
(cd _build/default/bench && ./main.exe -brief Picos_mpscq)
Picos_mpscq:
messages over time/1 nb adder, 1 nb taker:
21.42 M/s
messages over time/2 nb adders, 1 nb taker:
21.93 M/s
messages over time/4 nb adders, 1 nb taker:
23.27 M/s
messages over time/one domain:
14.68 M/s
time per message/1 nb adder, 1 nb taker:
93.37 ns
time per message/2 nb adders, 1 nb taker:
136.78 ns
time per message/4 nb adders, 1 nb taker:
214.83 ns
time per message/one domain:
68.13 ns
(cd _build/default/test && ./test_mpmcq.exe)
random seed: 1717895523977965760
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential (generating)
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    1    0    0    1 /   32     0.9s Mpmcq parallel
[ ]    2    0    0    2 /   32     1.8s Mpmcq parallel
[ ]    3    0    0    3 /   32     4.0s Mpmcq parallel
[ ]    4    0    0    4 /   32     4.9s Mpmcq parallel
[ ]    5    0    0    5 /   32     8.2s Mpmcq parallel
[ ]    6    0    0    6 /   32     9.3s Mpmcq parallel
[ ]    7    0    0    7 /   32    10.4s Mpmcq parallel
[ ]    8    0    0    8 /   32    11.7s Mpmcq parallel
[ ]    9    0    0    9 /   32    12.6s Mpmcq parallel
[ ]   10    0    0   10 /   32    13.6s Mpmcq parallel
[ ]   11    0    0   11 /   32    14.5s Mpmcq parallel
[ ]   12    0    0   12 /   32    15.4s Mpmcq parallel
[ ]   13    0    0   13 /   32    17.2s Mpmcq parallel
[ ]   14    0    0   14 /   32    19.2s Mpmcq parallel
[ ]   15    0    0   15 /   32    19.9s Mpmcq parallel
[ ]   16    0    0   16 /   32    20.9s Mpmcq parallel
[ ]   17    0    0   17 /   32    21.9s Mpmcq parallel
[ ]   18    0    0   18 /   32    22.7s Mpmcq parallel
[ ]   19    0    0   19 /   32    23.7s Mpmcq parallel
[ ]   20    0    0   20 /   32    24.4s Mpmcq parallel
[ ]   21    0    0   21 /   32    25.2s Mpmcq parallel
[ ]   22    0    0   22 /   32    27.0s Mpmcq parallel
[ ]   23    0    0   23 /   32    27.7s Mpmcq parallel
[ ]   24    0    0   24 /   32    28.2s Mpmcq parallel
[ ]   25    0    0   25 /   32    28.9s Mpmcq parallel
[ ]   26    0    0   26 /   32    29.8s Mpmcq parallel
[ ]   27    0    0   27 /   32    30.6s Mpmcq parallel
[ ]   28    0    0   28 /   32    31.1s Mpmcq parallel
[ ]   29    0    0   29 /   32    31.6s Mpmcq parallel
[ ]   30    0    0   30 /   32    32.1s Mpmcq parallel
[ ]   31    0    0   31 /   32    32.4s Mpmcq parallel
[ ]   32    0    0   32 /   32    33.0s Mpmcq parallel
[✓]   32    0    0   32 /   32    33.0s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 4591050381924814293
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    1    0    0    1 /   32     0.7s Mpmcq parallel
[ ]    2    0    0    2 /   32     1.2s Mpmcq parallel
[ ]    3    0    0    3 /   32     1.7s Mpmcq parallel
[ ]    4    0    0    4 /   32     2.1s Mpmcq parallel
[ ]    5    0    0    5 /   32     2.2s Mpmcq parallel
[ ]    6    0    0    6 /   32     2.6s Mpmcq parallel
[ ]    7    0    0    7 /   32     2.9s Mpmcq parallel
[ ]    8    0    0    8 /   32     3.1s Mpmcq parallel
[ ]    9    0    0    9 /   32     3.6s Mpmcq parallel
[ ]   10    0    0   10 /   32     4.1s Mpmcq parallel
[ ]   11    0    0   11 /   32     4.6s Mpmcq parallel
[ ]   12    0    0   12 /   32     5.3s Mpmcq parallel
[ ]   13    0    0   13 /   32     5.5s Mpmcq parallel
[ ]   14    0    0   14 /   32     5.6s Mpmcq parallel
[ ]   15    0    0   15 /   32     6.2s Mpmcq parallel
[ ]   17    0    0   17 /   32     6.3s Mpmcq parallel
[ ]   18    0    0   18 /   32     6.7s Mpmcq parallel
[ ]   19    0    0   19 /   32     6.9s Mpmcq parallel
[ ]   21    0    0   21 /   32     7.0s Mpmcq parallel
[ ]   29    0    0   29 /   32     7.1s Mpmcq parallel
[✓]   32    0    0   32 /   32     7.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 1490960468398572243
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    1    0    0    1 /   32     0.0s Mpmcq parallel
[ ]    2    0    0    2 /   32     0.3s Mpmcq parallel
[ ]    6    0    0    6 /   32     0.6s Mpmcq parallel
[ ]    8    0    0    8 /   32     0.9s Mpmcq parallel
[ ]    9    0    0    9 /   32     1.0s Mpmcq parallel
[ ]   11    0    0   11 /   32     1.2s Mpmcq parallel
[ ]   12    0    0   12 /   32     1.4s Mpmcq parallel
[ ]   14    0    0   14 /   32     1.5s Mpmcq parallel
[ ]   17    0    0   17 /   32     1.6s Mpmcq parallel
[ ]   18    0    0   18 /   32     1.7s Mpmcq parallel
[ ]   23    0    0   23 /   32     1.9s Mpmcq parallel
[ ]   24    0    0   24 /   32     2.4s Mpmcq parallel
[ ]   25    0    0   25 /   32     2.7s Mpmcq parallel
[ ]   27    0    0   27 /   32     3.1s Mpmcq parallel
[ ]   30    0    0   30 /   32     3.2s Mpmcq parallel
[✓]   32    0    0   32 /   32     3.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 940995831259119455
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   36     0.0s Mpmcq sequential
[✓]   36    0    0   36 /   36     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   36     0.0s Mpmcq parallel
[ ]    1    0    0    1 /   36     0.3s Mpmcq parallel
[ ]    2    0    0    2 /   36     0.8s Mpmcq parallel
[ ]    5    0    0    5 /   36     0.9s Mpmcq parallel
[ ]   11    0    0   11 /   36     1.5s Mpmcq parallel
[ ]   24    0    0   24 /   36     1.6s Mpmcq parallel
[ ]   27    0    0   27 /   36     2.2s Mpmcq parallel
[ ]   33    0    0   33 /   36     2.4s Mpmcq parallel
[✓]   36    0    0   36 /   36     2.4s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 4603206396380511504
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   40     0.0s Mpmcq sequential
[✓]   40    0    0   40 /   40     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   40     0.0s Mpmcq parallel
[ ]    5    0    0    5 /   40     0.1s Mpmcq parallel
[ ]    7    0    0    7 /   40     0.3s Mpmcq parallel
[ ]   13    0    0   13 /   40     0.4s Mpmcq parallel
[ ]   14    0    0   14 /   40     0.7s Mpmcq parallel
[ ]   22    0    0   22 /   40     0.8s Mpmcq parallel
[ ]   27    0    0   27 /   40     0.9s Mpmcq parallel
[ ]   35    0    0   35 /   40     1.0s Mpmcq parallel
[ ]   36    0    0   36 /   40     1.5s Mpmcq parallel
[ ]   40    0    0   40 /   40     1.7s Mpmcq parallel
[✓]   40    0    0   40 /   40     1.7s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 4516529161988561486
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   44     0.0s Mpmcq sequential
[✓]   44    0    0   44 /   44     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   44     0.0s Mpmcq parallel
[ ]    3    0    0    3 /   44     0.3s Mpmcq parallel
[ ]    5    0    0    5 /   44     0.4s Mpmcq parallel
[ ]    6    0    0    6 /   44     0.6s Mpmcq parallel
[ ]    8    0    0    8 /   44     0.9s Mpmcq parallel
[ ]   10    0    0   10 /   44     1.7s Mpmcq parallel
[ ]   14    0    0   14 /   44     2.5s Mpmcq parallel
[ ]   15    0    0   15 /   44     3.0s Mpmcq parallel
[ ]   16    0    0   16 /   44     3.2s Mpmcq parallel
[ ]   17    0    0   17 /   44     3.4s Mpmcq parallel
[ ]   19    0    0   19 /   44     3.6s Mpmcq parallel
[ ]   21    0    0   21 /   44     3.8s Mpmcq parallel
[ ]   23    0    0   23 /   44     3.9s Mpmcq parallel
[ ]   24    0    0   24 /   44     4.4s Mpmcq parallel
[ ]   25    0    0   25 /   44     4.6s Mpmcq parallel
[ ]   34    0    0   34 /   44     5.1s Mpmcq parallel
[ ]   38    0    0   38 /   44     5.3s Mpmcq parallel
[✓]   44    0    0   44 /   44     5.3s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 4505139149285977698
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    6    0    0    6 /   32     0.5s Mpmcq parallel
[ ]   14    0    0   14 /   32     1.1s Mpmcq parallel
[ ]   15    0    0   15 /   32     1.2s Mpmcq parallel
[ ]   21    0    0   21 /   32     1.5s Mpmcq parallel
[ ]   25    0    0   25 /   32     2.1s Mpmcq parallel
[ ]   30    0    0   30 /   32     2.2s Mpmcq parallel
[✓]   32    0    0   32 /   32     2.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 4397043812920779257
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    5    0    0    5 /   32     0.1s Mpmcq parallel
[ ]   11    0    0   11 /   32     0.3s Mpmcq parallel
[ ]   16    0    0   16 /   32     0.4s Mpmcq parallel
[ ]   24    0    0   24 /   32     0.6s Mpmcq parallel
[ ]   25    0    0   25 /   32     0.8s Mpmcq parallel
[✓]   32    0    0   32 /   32     0.9s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 3059231896548557758
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    7    0    0    7 /   32     0.0s Mpmcq parallel
[ ]   12    0    0   12 /   32     0.2s Mpmcq parallel
[ ]   18    0    0   18 /   32     0.3s Mpmcq parallel
[ ]   21    0    0   21 /   32     0.5s Mpmcq parallel
[ ]   24    0    0   24 /   32     0.8s Mpmcq parallel
[✓]   32    0    0   32 /   32     0.9s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 2381940218116565303
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpmcq sequential
[✓]   32    0    0   32 /   32     0.0s Mpmcq sequential
[ ]    0    0    0    0 /   32     0.0s Mpmcq parallel
[ ]    2    0    0    2 /   32     0.0s Mpmcq parallel
[ ]    7    0    0    7 /   32     0.5s Mpmcq parallel
[ ]    8    0    0    8 /   32     0.8s Mpmcq parallel
[ ]   11    0    0   11 /   32     0.9s Mpmcq parallel
[ ]   13    0    0   13 /   32     1.4s Mpmcq parallel
[ ]   15    0    0   15 /   32     1.5s Mpmcq parallel
[ ]   16    0    0   16 /   32     1.9s Mpmcq parallel
[ ]   24    0    0   24 /   32     2.4s Mpmcq parallel
[ ]   26    0    0   26 /   32     2.5s Mpmcq parallel
[ ]   30    0    0   30 /   32     2.8s Mpmcq parallel
[ ]   31    0    0   31 /   32     3.2s Mpmcq parallel
[✓]   32    0    0   32 /   32     3.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_mpscq.exe)
random seed: 582843630948375563
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential (generating)
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    1    0    0    1 /   32     2.1s Mpscq parallel
[ ]    2    0    0    2 /   32     4.1s Mpscq parallel
[ ]    3    0    0    3 /   32     5.7s Mpscq parallel
[ ]    4    0    0    4 /   32     7.2s Mpscq parallel
[ ]    5    0    0    5 /   32    11.6s Mpscq parallel
[ ]    6    0    0    6 /   32    12.7s Mpscq parallel
[ ]    7    0    0    7 /   32    13.9s Mpscq parallel
[ ]    8    0    0    8 /   32    15.3s Mpscq parallel
[ ]    9    0    0    9 /   32    16.7s Mpscq parallel
[ ]   10    0    0   10 /   32    17.4s Mpscq parallel
[ ]   11    0    0   11 /   32    18.3s Mpscq parallel
[ ]   12    0    0   12 /   32    20.2s Mpscq parallel
[ ]   13    0    0   13 /   32    21.4s Mpscq parallel
[ ]   14    0    0   14 /   32    22.5s Mpscq parallel
[ ]   15    0    0   15 /   32    23.5s Mpscq parallel
[ ]   16    0    0   16 /   32    25.0s Mpscq parallel
[ ]   17    0    0   17 /   32    26.5s Mpscq parallel
[ ]   18    0    0   18 /   32    28.3s Mpscq parallel
[ ]   19    0    0   19 /   32    29.2s Mpscq parallel
[ ]   20    0    0   20 /   32    30.3s Mpscq parallel
[ ]   21    0    0   21 /   32    31.9s Mpscq parallel
[ ]   22    0    0   22 /   32    32.8s Mpscq parallel
[ ]   23    0    0   23 /   32    33.8s Mpscq parallel
[ ]   24    0    0   24 /   32    34.5s Mpscq parallel
[ ]   25    0    0   25 /   32    35.1s Mpscq parallel
[ ]   26    0    0   26 /   32    35.9s Mpscq parallel
[ ]   27    0    0   27 /   32    36.4s Mpscq parallel
[ ]   28    0    0   28 /   32    36.7s Mpscq parallel
[ ]   29    0    0   29 /   32    36.9s Mpscq parallel
[ ]   31    0    0   31 /   32    37.6s Mpscq parallel
[✓]   32    0    0   32 /   32    37.7s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 658296462140430814
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    2    0    0    2 /   32     0.2s Mpscq parallel
[ ]    4    0    0    4 /   32     0.5s Mpscq parallel
[ ]    5    0    0    5 /   32     0.7s Mpscq parallel
[ ]    7    0    0    7 /   32     0.8s Mpscq parallel
[ ]    9    0    0    9 /   32     1.3s Mpscq parallel
[ ]   10    0    0   10 /   32     1.5s Mpscq parallel
[ ]   12    0    0   12 /   32     1.9s Mpscq parallel
[ ]   14    0    0   14 /   32     2.2s Mpscq parallel
[ ]   15    0    0   15 /   32     2.3s Mpscq parallel
[ ]   17    0    0   17 /   32     2.5s Mpscq parallel
[ ]   18    0    0   18 /   32     2.8s Mpscq parallel
[ ]   22    0    0   22 /   32     2.9s Mpscq parallel
[ ]   24    0    0   24 /   32     3.9s Mpscq parallel
[ ]   25    0    0   25 /   32     4.1s Mpscq parallel
[ ]   27    0    0   27 /   32     4.2s Mpscq parallel
[ ]   28    0    0   28 /   32     4.4s Mpscq parallel
[ ]   29    0    0   29 /   32     4.6s Mpscq parallel
[✓]   32    0    0   32 /   32     4.7s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 2548251082802911223
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    2    0    0    2 /   32     0.0s Mpscq parallel
[ ]    4    0    0    4 /   32     0.2s Mpscq parallel
[ ]    5    0    0    5 /   32     0.3s Mpscq parallel
[ ]    9    0    0    9 /   32     0.5s Mpscq parallel
[ ]   13    0    0   13 /   32     1.0s Mpscq parallel
[ ]   17    0    0   17 /   32     1.1s Mpscq parallel
[ ]   21    0    0   21 /   32     1.5s Mpscq parallel
[ ]   25    0    0   25 /   32     1.7s Mpscq parallel
[ ]   28    0    0   28 /   32     1.8s Mpscq parallel
[ ]   31    0    0   31 /   32     2.0s Mpscq parallel
[✓]   32    0    0   32 /   32     2.1s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 4597222128224718683
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   33     0.0s Mpscq sequential
[✓]   33    0    0   33 /   33     0.0s Mpscq sequential
[ ]    0    0    0    0 /   33     0.0s Mpscq parallel
[ ]    1    0    0    1 /   33     0.1s Mpscq parallel
[ ]    4    0    0    4 /   33     0.3s Mpscq parallel
[ ]    9    0    0    9 /   33     0.4s Mpscq parallel
[ ]   13    0    0   13 /   33     0.5s Mpscq parallel
[ ]   16    0    0   16 /   33     0.6s Mpscq parallel
[ ]   18    0    0   18 /   33     1.5s Mpscq parallel
[ ]   25    0    0   25 /   33     1.7s Mpscq parallel
[ ]   31    0    0   31 /   33     1.8s Mpscq parallel
[ ]   33    0    0   33 /   33     2.0s Mpscq parallel
[✓]   33    0    0   33 /   33     2.0s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 1738193879097489783
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   37     0.0s Mpscq sequential
[✓]   37    0    0   37 /   37     0.0s Mpscq sequential
[ ]    0    0    0    0 /   37     0.0s Mpscq parallel
[ ]    3    0    0    3 /   37     0.1s Mpscq parallel
[ ]    6    0    0    6 /   37     0.2s Mpscq parallel
[ ]    7    0    0    7 /   37     0.6s Mpscq parallel
[ ]   11    0    0   11 /   37     1.0s Mpscq parallel
[ ]   12    0    0   12 /   37     1.9s Mpscq parallel
[ ]   13    0    0   13 /   37     2.4s Mpscq parallel
[ ]   14    0    0   14 /   37     2.6s Mpscq parallel
[ ]   18    0    0   18 /   37     3.1s Mpscq parallel
[ ]   19    0    0   19 /   37     3.2s Mpscq parallel
[ ]   20    0    0   20 /   37     3.7s Mpscq parallel
[ ]   23    0    0   23 /   37     4.1s Mpscq parallel
[ ]   30    0    0   30 /   37     4.2s Mpscq parallel
[✓]   37    0    0   37 /   37     4.3s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 2800456817568438858
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    3    0    0    3 /   32     0.1s Mpscq parallel
[ ]   11    0    0   11 /   32     0.2s Mpscq parallel
[ ]   14    0    0   14 /   32     0.4s Mpscq parallel
[ ]   18    0    0   18 /   32     0.7s Mpscq parallel
[ ]   23    0    0   23 /   32     0.9s Mpscq parallel
[✓]   32    0    0   32 /   32     1.0s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 2401525447816271932
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    1    0    0    1 /   32     0.5s Mpscq parallel
[ ]    5    0    0    5 /   32     0.8s Mpscq parallel
[ ]    7    0    0    7 /   32     0.9s Mpscq parallel
[ ]   14    0    0   14 /   32     1.0s Mpscq parallel
[ ]   18    0    0   18 /   32     1.2s Mpscq parallel
[ ]   22    0    0   22 /   32     1.5s Mpscq parallel
[ ]   25    0    0   25 /   32     2.1s Mpscq parallel
[ ]   30    0    0   30 /   32     2.7s Mpscq parallel
[ ]   31    0    0   31 /   32     3.1s Mpscq parallel
[✓]   32    0    0   32 /   32     3.1s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 452627960357301642
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    7    0    0    7 /   32     0.1s Mpscq parallel
[ ]   13    0    0   13 /   32     0.2s Mpscq parallel
[ ]   18    0    0   18 /   32     0.7s Mpscq parallel
[ ]   21    0    0   21 /   32     0.8s Mpscq parallel
[ ]   27    0    0   27 /   32     1.0s Mpscq parallel
[✓]   32    0    0   32 /   32     1.0s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 1790894179407989071
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    6    0    0    6 /   32     0.1s Mpscq parallel
[ ]   12    0    0   12 /   32     0.3s Mpscq parallel
[ ]   17    0    0   17 /   32     1.0s Mpscq parallel
[ ]   21    0    0   21 /   32     1.2s Mpscq parallel
[ ]   23    0    0   23 /   32     1.5s Mpscq parallel
[ ]   28    0    0   28 /   32     1.6s Mpscq parallel
[ ]   30    0    0   30 /   32     1.9s Mpscq parallel
[✓]   32    0    0   32 /   32     1.9s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 117850688287600186
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    4    0    0    4 /   32     0.3s Mpscq parallel
[ ]    6    0    0    6 /   32     0.4s Mpscq parallel
[ ]    7    0    0    7 /   32     0.6s Mpscq parallel
[ ]   11    0    0   11 /   32     0.7s Mpscq parallel
[ ]   20    0    0   20 /   32     0.8s Mpscq parallel
[ ]   23    0    0   23 /   32     1.0s Mpscq parallel
[ ]   27    0    0   27 /   32     1.1s Mpscq parallel
[ ]   30    0    0   30 /   32     1.5s Mpscq parallel
[✓]   32    0    0   32 /   32     1.5s Mpscq parallel
================================================================================
success (ran 2 tests)
random seed: 1905075320367801537
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Mpscq sequential
[✓]   32    0    0   32 /   32     0.0s Mpscq sequential
[ ]    0    0    0    0 /   32     0.0s Mpscq parallel
[ ]    5    0    0    5 /   32     0.4s Mpscq parallel
[ ]    6    0    0    6 /   32     0.6s Mpscq parallel
[ ]    8    0    0    8 /   32     1.3s Mpscq parallel
[ ]   11    0    0   11 /   32     1.4s Mpscq parallel
[ ]   15    0    0   15 /   32     1.8s Mpscq parallel
[ ]   16    0    0   16 /   32     2.3s Mpscq parallel
[ ]   24    0    0   24 /   32     2.4s Mpscq parallel
[ ]   25    0    0   25 /   32     3.0s Mpscq parallel
[ ]   27    0    0   27 /   32     3.1s Mpscq parallel
[ ]   28    0    0   28 /   32     3.7s Mpscq parallel
[ ]   29    0    0   29 /   32     3.8s Mpscq parallel
[✓]   32    0    0   32 /   32     3.9s Mpscq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/bench && ./main.exe -brief Picos_htbl)
Picos_htbl:
operations over time/1 worker, 10% reads:
9.90 M/s
operations over time/1 worker, 50% reads:
10.06 M/s
operations over time/1 worker, 90% reads:
15.08 M/s
operations over time/2 workers, 10% reads:
18.88 M/s
operations over time/2 workers, 50% reads:
19.35 M/s
operations over time/2 workers, 90% reads:
26.08 M/s
operations over time/4 workers, 10% reads:
28.22 M/s
operations over time/4 workers, 50% reads:
29.12 M/s
operations over time/4 workers, 90% reads:
44.59 M/s
operations over time/8 workers, 10% reads:
46.12 M/s
operations over time/8 workers, 50% reads:
57.26 M/s
operations over time/8 workers, 90% reads:
83.22 M/s
time per operation/1 worker, 10% reads:
101.04 ns
time per operation/1 worker, 50% reads:
99.38 ns
time per operation/1 worker, 90% reads:
66.33 ns
time per operation/2 workers, 10% reads:
105.93 ns
time per operation/2 workers, 50% reads:
103.37 ns
time per operation/2 workers, 90% reads:
76.68 ns
time per operation/4 workers, 10% reads:
141.73 ns
time per operation/4 workers, 50% reads:
137.35 ns
time per operation/4 workers, 90% reads:
89.72 ns
time per operation/8 workers, 10% reads:
173.46 ns
time per operation/8 workers, 50% reads:
139.72 ns
time per operation/8 workers, 90% reads:
96.13 ns
(cd _build/default/test && ./test_htbl.exe)
random seed: 3485720792843872682
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl sequential (generating)
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    1    0    0    1 /   32     1.1s Htbl parallel
[ ]    2    0    0    2 /   32     2.3s Htbl parallel
[ ]    3    0    0    3 /   32     3.4s Htbl parallel
[ ]    4    0    0    4 /   32     4.2s Htbl parallel
[ ]    5    0    0    5 /   32     5.0s Htbl parallel
[ ]    6    0    0    6 /   32     5.8s Htbl parallel
[ ]    7    0    0    7 /   32     6.8s Htbl parallel
[ ]    8    0    0    8 /   32     7.5s Htbl parallel
[ ]    9    0    0    9 /   32     8.3s Htbl parallel
[ ]   10    0    0   10 /   32     9.0s Htbl parallel
[ ]   11    0    0   11 /   32     9.7s Htbl parallel
[ ]   12    0    0   12 /   32    10.5s Htbl parallel
[ ]   13    0    0   13 /   32    11.2s Htbl parallel
[ ]   14    0    0   14 /   32    11.7s Htbl parallel
[ ]   15    0    0   15 /   32    12.5s Htbl parallel
[ ]   16    0    0   16 /   32    13.3s Htbl parallel
[ ]   17    0    0   17 /   32    14.2s Htbl parallel
[ ]   18    0    0   18 /   32    15.2s Htbl parallel
[ ]   19    0    0   19 /   32    16.0s Htbl parallel
[ ]   20    0    0   20 /   32    17.6s Htbl parallel
[ ]   21    0    0   21 /   32    18.6s Htbl parallel
[ ]   22    0    0   22 /   32    19.9s Htbl parallel
[ ]   23    0    0   23 /   32    20.8s Htbl parallel
[ ]   24    0    0   24 /   32    21.7s Htbl parallel
[ ]   25    0    0   25 /   32    22.5s Htbl parallel
[ ]   26    0    0   26 /   32    23.4s Htbl parallel
[ ]   27    0    0   27 /   32    24.2s Htbl parallel
[ ]   28    0    0   28 /   32    25.1s Htbl parallel
[ ]   29    0    0   29 /   32    25.9s Htbl parallel
[ ]   30    0    0   30 /   32    27.2s Htbl parallel
[ ]   31    0    0   31 /   32    27.9s Htbl parallel
[ ]   32    0    0   32 /   32    28.6s Htbl parallel
[✓]   32    0    0   32 /   32    28.6s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3647778691711782909
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   35     0.0s Htbl sequential
[✓]   35    0    0   35 /   35     0.0s Htbl sequential
[ ]    0    0    0    0 /   35     0.0s Htbl parallel
[ ]    1    0    0    1 /   35     0.7s Htbl parallel
[ ]    2    0    0    2 /   35     1.3s Htbl parallel
[ ]    3    0    0    3 /   35     1.9s Htbl parallel
[ ]    4    0    0    4 /   35     2.4s Htbl parallel
[ ]    5    0    0    5 /   35     3.1s Htbl parallel
[ ]    6    0    0    6 /   35     4.2s Htbl parallel
[ ]    7    0    0    7 /   35     4.5s Htbl parallel
[ ]    8    0    0    8 /   35     5.3s Htbl parallel
[ ]   10    0    0   10 /   35     5.8s Htbl parallel
[ ]   11    0    0   11 /   35     6.3s Htbl parallel
[ ]   12    0    0   12 /   35     6.7s Htbl parallel
[ ]   13    0    0   13 /   35     7.2s Htbl parallel
[ ]   14    0    0   14 /   35     8.0s Htbl parallel
[ ]   15    0    0   15 /   35     8.5s Htbl parallel
[ ]   18    0    0   18 /   35     8.9s Htbl parallel
[ ]   22    0    0   22 /   35     9.2s Htbl parallel
[ ]   24    0    0   24 /   35     9.6s Htbl parallel
[ ]   28    0    0   28 /   35    10.0s Htbl parallel
[ ]   29    0    0   29 /   35    10.1s Htbl parallel
[ ]   32    0    0   32 /   35    10.4s Htbl parallel
[ ]   33    0    0   33 /   35    10.5s Htbl parallel
[ ]   35    0    0   35 /   35    10.7s Htbl parallel
[✓]   35    0    0   35 /   35    10.7s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 1541728862238590025
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   35     0.0s Htbl sequential
[✓]   35    0    0   35 /   35     0.0s Htbl sequential
[ ]    0    0    0    0 /   35     0.0s Htbl parallel
[ ]    4    0    0    4 /   35     0.1s Htbl parallel
[ ]   10    0    0   10 /   35     1.0s Htbl parallel
[ ]   14    0    0   14 /   35     1.6s Htbl parallel
[ ]   19    0    0   19 /   35     2.5s Htbl parallel
[ ]   22    0    0   22 /   35     2.9s Htbl parallel
[ ]   28    0    0   28 /   35     3.0s Htbl parallel
[ ]   29    0    0   29 /   35     3.1s Htbl parallel
[ ]   34    0    0   34 /   35     3.5s Htbl parallel
[✓]   35    0    0   35 /   35     3.5s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 1744082284421354547
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   41     0.0s Htbl sequential
[✓]   41    0    0   41 /   41     0.0s Htbl sequential
[ ]    0    0    0    0 /   41     0.0s Htbl parallel
[ ]    7    0    0    7 /   41     0.1s Htbl parallel
[ ]    9    0    0    9 /   41     0.2s Htbl parallel
[ ]   13    0    0   13 /   41     0.7s Htbl parallel
[ ]   16    0    0   16 /   41     0.9s Htbl parallel
[ ]   18    0    0   18 /   41     1.1s Htbl parallel
[ ]   19    0    0   19 /   41     1.3s Htbl parallel
[ ]   25    0    0   25 /   41     1.4s Htbl parallel
[ ]   33    0    0   33 /   41     1.6s Htbl parallel
[ ]   39    0    0   39 /   41     2.3s Htbl parallel
[ ]   40    0    0   40 /   41     2.5s Htbl parallel
[✓]   41    0    0   41 /   41     2.5s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3066704846551687536
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   46     0.0s Htbl sequential
[✓]   46    0    0   46 /   46     0.0s Htbl sequential
[ ]    0    0    0    0 /   46     0.0s Htbl parallel
[ ]    5    0    0    5 /   46     0.2s Htbl parallel
[ ]    6    0    0    6 /   46     0.3s Htbl parallel
[ ]    8    0    0    8 /   46     0.4s Htbl parallel
[ ]   10    0    0   10 /   46     0.6s Htbl parallel
[ ]   11    0    0   11 /   46     0.9s Htbl parallel
[ ]   12    0    0   12 /   46     1.2s Htbl parallel
[ ]   13    0    0   13 /   46     1.6s Htbl parallel
[ ]   16    0    0   16 /   46     1.7s Htbl parallel
[ ]   21    0    0   21 /   46     2.3s Htbl parallel
[ ]   22    0    0   22 /   46     2.8s Htbl parallel
[ ]   23    0    0   23 /   46     3.1s Htbl parallel
[ ]   24    0    0   24 /   46     3.3s Htbl parallel
[ ]   26    0    0   26 /   46     3.5s Htbl parallel
[ ]   28    0    0   28 /   46     3.6s Htbl parallel
[ ]   29    0    0   29 /   46     3.7s Htbl parallel
[ ]   31    0    0   31 /   46     3.9s Htbl parallel
[ ]   38    0    0   38 /   46     4.0s Htbl parallel
[ ]   44    0    0   44 /   46     4.3s Htbl parallel
[ ]   46    0    0   46 /   46     4.5s Htbl parallel
[✓]   46    0    0   46 /   46     4.5s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3982632802120011310
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   39     0.0s Htbl sequential
[✓]   39    0    0   39 /   39     0.0s Htbl sequential
[ ]    0    0    0    0 /   39     0.0s Htbl parallel
[ ]    2    0    0    2 /   39     0.1s Htbl parallel
[ ]   11    0    0   11 /   39     0.4s Htbl parallel
[ ]   13    0    0   13 /   39     1.0s Htbl parallel
[ ]   14    0    0   14 /   39     1.2s Htbl parallel
[ ]   15    0    0   15 /   39     1.7s Htbl parallel
[ ]   16    0    0   16 /   39     1.9s Htbl parallel
[ ]   19    0    0   19 /   39     2.2s Htbl parallel
[ ]   24    0    0   24 /   39     2.4s Htbl parallel
[ ]   26    0    0   26 /   39     2.5s Htbl parallel
[ ]   31    0    0   31 /   39     2.8s Htbl parallel
[✓]   39    0    0   39 /   39     2.9s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 1398564521129772044
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    1    0    0    1 /   32     0.0s Htbl parallel
[ ]    3    0    0    3 /   32     0.4s Htbl parallel
[ ]   11    0    0   11 /   32     0.5s Htbl parallel
[ ]   15    0    0   15 /   32     0.7s Htbl parallel
[ ]   16    0    0   16 /   32     0.8s Htbl parallel
[ ]   29    0    0   29 /   32     1.4s Htbl parallel
[✓]   32    0    0   32 /   32     1.4s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3578472251567952583
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    2    0    0    2 /   32     0.1s Htbl parallel
[ ]    3    0    0    3 /   32     0.5s Htbl parallel
[ ]    9    0    0    9 /   32     0.6s Htbl parallel
[ ]   18    0    0   18 /   32     0.7s Htbl parallel
[ ]   24    0    0   24 /   32     0.8s Htbl parallel
[ ]   32    0    0   32 /   32     1.1s Htbl parallel
[✓]   32    0    0   32 /   32     1.1s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3943814971057715467
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    3    0    0    3 /   32     0.1s Htbl parallel
[ ]    8    0    0    8 /   32     0.5s Htbl parallel
[ ]    9    0    0    9 /   32     0.6s Htbl parallel
[ ]   13    0    0   13 /   32     0.7s Htbl parallel
[ ]   16    0    0   16 /   32     0.8s Htbl parallel
[ ]   17    0    0   17 /   32     1.3s Htbl parallel
[ ]   21    0    0   21 /   32     1.6s Htbl parallel
[ ]   23    0    0   23 /   32     1.8s Htbl parallel
[ ]   24    0    0   24 /   32     2.1s Htbl parallel
[ ]   28    0    0   28 /   32     2.2s Htbl parallel
[ ]   32    0    0   32 /   32     2.3s Htbl parallel
[✓]   32    0    0   32 /   32     2.3s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 3015397488786706785
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    8    0    0    8 /   32     0.3s Htbl parallel
[ ]   17    0    0   17 /   32     0.9s Htbl parallel
[ ]   24    0    0   24 /   32     1.0s Htbl parallel
[ ]   25    0    0   25 /   32     1.2s Htbl parallel
[ ]   26    0    0   26 /   32     1.4s Htbl parallel
[ ]   27    0    0   27 /   32     1.6s Htbl parallel
[ ]   29    0    0   29 /   32     1.7s Htbl parallel
[✓]   32    0    0   32 /   32     1.7s Htbl parallel
================================================================================
success (ran 2 tests)
random seed: 4583070807672849099
generated error fail pass / total     time test name
[ ]    0    0    0    0 /   32     0.0s Htbl sequential
[✓]   32    0    0   32 /   32     0.0s Htbl sequential
[ ]    0    0    0    0 /   32     0.0s Htbl parallel
[ ]    4    0    0    4 /   32     0.0s Htbl parallel
[ ]   10    0    0   10 /   32     0.4s Htbl parallel
[ ]   13    0    0   13 /   32     1.2s Htbl parallel
[ ]   15    0    0   15 /   32     2.2s Htbl parallel
[ ]   17    0    0   17 /   32     2.4s Htbl parallel
[ ]   18    018 /   32     2.5s Htbl parallel
[ ]   20    0    0   20 /   32     3.1s Htbl parallel
[ ]   25    0    0   25 /   32     3.6s Htbl parallel
[ ]   31    0    0   31 /   32     3.7s Htbl parallel
[✓]   32    0    0   32 /   32     3.7s Htbl parallel
================================================================================
success (ran 2 tests)
(cd _build/default/bench && ./main.exe -brief Picos_stdio)
Picos_stdio:
blocking reads over time/1 worker:
0.04 M/s
blocking reads over time/2 workers:
0.12 M/s
blocking reads over time/4 workers:
0.12 M/s
non-blocking reads over time/1 worker:
0.87 M/s
non-blocking reads over time/2 workers:
1.78 M/s
non-blocking reads over time/4 workers:
3.38 M/s
time per blocking read/1 worker:
26785.92 ns
time per blocking read/2 workers:
17017.24 ns
time per blocking read/4 workers:
32276.99 ns
time per non-blocking read/1 worker:
1144.91 ns
time per non-blocking read/2 workers:
1121.70 ns
time per non-blocking read/4 workers:
1184.49 ns
(cd _build/default/bench && ./main.exe -brief 'Picos_sync Stream')
Picos_sync Stream:
messages over time/1 nb pusher, 1 nb reader:
5.40 M/s
messages over time/2 nb pushers, 1 nb reader:
6.09 M/s
messages over time/4 nb pushers, 1 nb reader:
6.40 M/s
messages over time/one domain:
7.01 M/s
time per message/1 nb pusher, 1 nb reader:
370.49 ns
time per message/2 nb pushers, 1 nb reader:
492.37 ns
time per message/4 nb pushers, 1 nb reader:
781.80 ns
time per message/one domain:
142.76 ns
(cd _build/default/bench && ./main.exe -brief Fib)
Fib:
spawns over time/1 mfifo, fib 20:
0.85 M/s
spawns over time/1 rando, fib 20:
0.43 M/s
spawns over time/2 mfifos, fib 20:
2.04 M/s
spawns over time/2 randos, fib 20:
0.75 M/s
spawns over time/4 mfifos, fib 20:
5.26 M/s
spawns over time/4 randos, fib 20:
1.40 M/s
spawns over time/8 mfifos, fib 20:
7.69 M/s
spawns over time/8 randos, fib 20:
1.98 M/s
time per spawn/1 mfifo, fib 20:
1173.17 ns
time per spawn/1 rando, fib 20:
2343.83 ns
time per spawn/2 mfifos, fib 20:
982.44 ns
time per spawn/2 randos, fib 20:
2661.08 ns
time per spawn/4 mfifos, fib 20:
759.80 ns
time per spawn/4 randos, fib 20:
2852.25 ns
time per spawn/8 mfifos, fib 20:
1040.51 ns
time per spawn/8 randos, fib 20:
4046.31 ns
(cd _build/default/bench && ./main.exe -brief 'Picos binaries')
Picos binaries:
binary size/picos:
95.79 kB
binary size/picos.domain:
5.04 kB
binary size/picos.thread:
4.47 kB
binary size/picos_aux.htbl:
53.32 kB
binary size/picos_aux.mpmcq:
17.04 kB
binary size/picos_aux.mpscq:
20.44 kB
binary size/picos_aux.rc:
19.85 kB
binary size/picos_io:
115.89 kB
binary size/picos_io.fd:
10.69 kB
binary size/picos_io.select:
65.07 kB
binary size/picos_io_cohttp:
48.52 kB
binary size/picos_lwt:
29.74 kB
binary size/picos_lwt.unix:
16.06 kB
binary size/picos_mux.fifo:
30.23 kB
binary size/picos_mux.multififo:
64.82 kB
binary size/picos_mux.random:
51.14 kB
binary size/picos_mux.thread:
26.27 kB
binary size/picos_std.awaitable:
35.91 kB
binary size/picos_std.event:
25.92 kB
binary size/picos_std.finally:
20.75 kB
binary size/picos_std.structured:
89.70 kB
binary size/picos_std.sync:
123.75 kB
(cd _build/default/bench && ./main.exe -brief 'Bounded_q with Picos_sync')
Bounded_q with Picos_sync:
messages over time/1 adder, 1 taker:
3.14 M/s
messages over time/1 adder, 2 takers:
6.04 M/s
messages over time/1 adder, 4 takers:
0.16 M/s
messages over time/2 adders, 1 taker:
0.75 M/s
messages over time/2 adders, 2 takers:
0.51 M/s
messages over time/2 adders, 4 takers:
0.34 M/s
messages over time/4 adders, 1 taker:
0.79 M/s
messages over time/4 adders, 2 takers:
0.60 M/s
messages over time/4 adders, 4 takers:
0.41 M/s
messages over time/one domain:
7.57 M/s
time per message/1 adder, 1 taker:
639.36 ns
time per message/1 adder, 2 takers:
496.91 ns
time per message/1 adder, 4 takers:
31813.83 ns
time per message/2 adders, 1 taker:
3994.70 ns
time per message/2 adders, 2 takers:
7866.79 ns
time per message/2 adders, 4 takers:
17672.25 ns
time per message/4 adders, 1 taker:
6329.88 ns
time per message/4 adders, 2 takers:
10045.66 ns
time per message/4 adders, 4 takers:
19632.42 ns
time per message/one domain:
132.13 ns
(cd _build/default/bench && ./main.exe -brief 'Memory usage')
Memory usage:
stack and heap used/Fun.protect:
80.00 B
stack and heap used/fiber in a bundle:
232.00 B
stack and heap used/fiber in a flock:
248.00 B
stack and heap used/fiber with shared computation & latch:
232.00 B
stack and heap used/finally:
40.00 B
stack and heap used/instantiate:
96.00 B
stack and heap used/join_after bundle:
280.00 B
stack and heap used/join_after flock:
280.00 B
stack and heap used/lastly:
32.00 B
stack and heap used/promise in a bundle:
352.00 B
stack and heap used/promise in a flock:
368.00 B
2025-02-18 18:28.44 ---> saved as "0756272c7bd4a28d332145a09b8c5a452510ff63656df6c50dd9396fda8c866f"
Job succeeded
2025-02-18 18:28.44: Job succeeded