2025-05-01 17:53.38: New job: test ocaml-multicore/picos https://github.com/ocaml-multicore/picos.git#refs/heads/awaitable-stack (39ffc276181fd55328f3726120c1706547e4d10b) (linux-x86_64:debian-12-5.3_x86_32_opam-2.3)
Base: ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ocaml-multicore/picos.git" -b "awaitable-stack" && cd "picos" && git reset --hard 39ffc276
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10
# debian-12-5.3_x86_32_opam-2.3
USER 1000:1000
SHELL [ "/usr/bin/linux32", "/bin/sh", "-c" ]
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 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && 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.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 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.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.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.8.0 lwt.5.9.1 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-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 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.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 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-05-01 17:53.38: Using cache hint "ocaml-multicore/picos-ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10-debian-12-5.3_x86_32_opam-2.3-bc53c192e60a4d891cfbf9f20e86f876"
2025-05-01 17:53.38: Using OBuilder spec:
((from ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10)
(comment debian-12-5.3_x86_32_opam-2.3)
(user (uid 1000) (gid 1000))
(shell /usr/bin/linux32 /bin/sh -c)
(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 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && 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.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 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.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.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.8.0 lwt.5.9.1 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-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 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.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 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-05-01 17:53.38: Waiting for resource in pool OCluster
2025-05-01 17:53.39: Waiting for worker…
2025-05-01 17:53.39: Got resource from pool OCluster
Building on x86-bm-c3.sw.ocaml.org
All commits already cached
HEAD is now at 39ffc27 Add bounded blocking `Stack`
(from ocaml/opam:debian-12-ocaml-5.3@sha256:dfbc0286df3aa6620a4ebe6da5880bf4b8724c225056efc48622b39f10920a10)
WARNING: The requested image's platform (linux/386) does not match the detected host platform (linux/amd64) and no specific platform was requested
2025-05-01 17:53.39 ---> using "b8e2c67a48f21f6b588dbd3c84402e21f46800f10cf95f4f261f434a6291fdbb" from cache
/: (comment debian-12-5.3_x86_32_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (shell /usr/bin/linux32 /bin/sh -c)
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (workdir /src)
/src: (run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2025-05-01 17:53.39 ---> using "dbddeba6b94881d7b9e20e18f9a790b97f859b309d9a15754e761cfc21febe07" from cache
/src: (run (shell "opam init --reinit -ni"))
Configuring from /home/opam/.opamrc and then from built-in defaults.
Checking for available remotes: rsync and local, git.
- you won't be able to use mercurial repositories unless you install the hg command on your system.
- you won't be able to use darcs repositories unless you install the darcs command on your system.
This 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.
Continue? [y/n] y
Format upgrade done.
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2025-05-01 17:53.39 ---> using "6d4e3c82c6a9d252ed847e874a886a16b449e7669a8b1f1b119f3bbe00d69cf1" from cache
/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.15.0-134-generic
The OCaml toplevel, version 5.3.0
2.3.0
2025-05-01 17:53.39 ---> using "2aafa5118b96adfea99fa63311b6c7a323cc5b186ecb4fcee7464018f41cf437" from cache
/src: (workdir /src)
/src: (run (shell "sudo chown opam /src"))
2025-05-01 17:53.39 ---> using "1fb5da2713e27d7ae14ee3de7540f6a80fd3394e513af3cb01ce174b04304c72" from cache
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 6bf1d7b4b789bbbf1388886ea336653bace6fde7 || git fetch origin master) && git reset -q --hard 6bf1d7b4b789bbbf1388886ea336653bace6fde7 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
da74d7829f..b90fd8709a master -> origin/master
6bf1d7b4b7 Merge pull request #27809 from kit-ty-kate/misc-conf-altlinux
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from git+file:///home/opam/opam-repository
Everything as up-to-date as possible (run with --verbose to show unavailable upgrades).
However, you may "opam upgrade" these packages explicitly, 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-05-01 17:53.39 ---> using "0d4e0af1012787d34c728c5638c75214fa508d886d373de4e174d097ad950188" 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-05-01 17:53.39 ---> using "fd1f345f262d69282eb1bfe1898ddb848736f4e50dc30861412c7d64b6c21b3d" 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-05-01 17:53.39 ---> using "5b7120563ce1164bd6c9198df59bda1bf26ccfcfdffc9e4ca0cd3426340148c8" from cache
/src: (run (network host)
(shell "echo '(lang dune 3.0)' > './dune-project'"))
2025-05-01 17:53.39 ---> using "674146e6a2e83d4de5784b72ca1b52cf0d563264d7967f8d86991acce01e6426" from cache
/src: (env DEPS "alcotest.1.9.0 angstrom.0.16.1 asn1-combinators.0.3.2 astring.0.8.5 backoff.0.1.1 base.v0.16.4 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.1 camlp-streams.5.0.1 cmdliner.1.3.0 cohttp.6.1.0 cohttp-lwt.6.1.0 cohttp-lwt-unix.6.1.0 conduit.8.0.0 conduit-lwt.8.0.0 conduit-lwt-unix.8.0.0 conf-gmp.5 conf-gmp-powm-sec.4 conf-pkg-config.4 containers.3.15 cppo.1.8.0 csexp.1.5.2 digestif.1.3.0 domain-local-await.1.0.1 domain-name.0.4.1 domain_shims.0.1.0 dscheck.0.5.0 dune.3.18.1 dune-configurator.3.18.1 duration.0.2.1 either.1.0.0 eqaf.0.10 fmt.0.10.0 fpath.0.7.3 gen.1.1 gmap.0.3.0 http.6.1.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.8.0 lwt.5.9.1 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-option-bytecode-only.1 ocaml-options-vanilla.1 ocaml-syntax-shims.1.0.0 ocaml-version.4.0.0 ocamlbuild.0.16.1 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.16.0 ppxlib.0.35.0 psq.0.2.1 ptime.1.2.0 qcheck-core.0.25 qcheck-multicoretests-util.0.8 qcheck-stm.0.8 re.1.12.0 result.1.5 rresult.0.7.0 sedlex.3.4 seq.base sexplib0.v0.16.0 stdlib-shims.0.3.0 stringext.1.6.0 thread-local-storage.0.2 thread-table.1.0.0 topkg.1.0.8 tsort.2.2.0 uri.4.4.0 uri-sexp.4.4.0 uutf.1.0.4 x509.1.0.6 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 "apt-get" "update"
- Hit:1 http://deb.debian.org/debian bookworm InRelease
- Get:2 http://deb.debian.org/debian bookworm-updates InRelease [55.4 kB]
- Get:3 http://deb.debian.org/debian-security bookworm-security InRelease [48.0 kB]
- Get:4 http://deb.debian.org/debian-security bookworm-security/main i386 Packages [251 kB]
- Fetched 354 kB in 0s (1053 kB/s)
- Reading package lists...
-
<><> 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-option-bytecode-only 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:
libgmp-dev pkg-config
<><> Handling external dependencies <><><><><><><><><><><><><><><><><><><><><><>
+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "libgmp-dev" "pkg-config"
- debconf: delaying package configuration, since apt-utils is not installed
- Selecting previously unselected package libgmpxx4ldbl:i386.
- (Reading database ...
(Reading database ... 5%
(Reading database ... 10%
(Reading database ... 15%
(Reading database ... 20%
(Reading database ... 25%
(Reading database ... 30%
(Reading database ... 35%
(Reading database ... 40%
(Reading database ... 45%
(Reading database ... 50%
(Reading database ... 55%
(Reading database ... 60%
(Reading database ... 65%
(Reading database ... 70%
(Reading database ... 75%
(Reading database ... 80%
(Reading database ... 85%
(Reading database ... 90%
(Reading database ... 95%
(Reading database ... 100%
(Reading database ... 18763 files and directories currently installed.)
- Preparing to unpack .../0-libgmpxx4ldbl_2%3a6.2.1+dfsg1-1.1_i386.deb ...
- Unpacking libgmpxx4ldbl:i386 (2:6.2.1+dfsg1-1.1) ...
- Selecting previously unselected package libgmp-dev:i386.
- Preparing to unpack .../1-libgmp-dev_2%3a6.2.1+dfsg1-1.1_i386.deb ...
- Unpacking libgmp-dev:i386 (2:6.2.1+dfsg1-1.1) ...
- Selecting previously unselected package libpkgconf3:i386.
- Preparing to unpack .../2-libpkgconf3_1.8.1-1_i386.deb ...
- Unpacking libpkgconf3:i386 (1.8.1-1) ...
- Selecting previously unselected package pkgconf-bin.
- Preparing to unpack .../3-pkgconf-bin_1.8.1-1_i386.deb ...
- Unpacking pkgconf-bin (1.8.1-1) ...
- Selecting previously unselected package pkgconf:i386.
- Preparing to unpack .../4-pkgconf_1.8.1-1_i386.deb ...
- Unpacking pkgconf:i386 (1.8.1-1) ...
- Selecting previously unselected package pkg-config:i386.
- Preparing to unpack .../5-pkg-config_1.8.1-1_i386.deb ...
- Unpacking pkg-config:i386 (1.8.1-1) ...
- Setting up libpkgconf3:i386 (1.8.1-1) ...
- Setting up libgmpxx4ldbl:i386 (2:6.2.1+dfsg1-1.1) ...
- Setting up pkgconf-bin (1.8.1-1) ...
- Setting up libgmp-dev:i386 (2:6.2.1+dfsg1-1.1) ...
- Setting up pkgconf:i386 (1.8.1-1) ...
- Setting up pkg-config:i386 (1.8.1-1) ...
- Processing triggers for libc-bin (2.36-9+deb12u10) ...
2025-05-01 17:53.39 ---> using "ba578d019c85edec570dc0224e3ed0f7479c740033e7c9773917901b7dcd4c82" 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-option-bytecode-only 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 96 packages
- install alcotest 1.9.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.16.4
- install base-bytes base
- install base64 3.5.1
- install bigstringaf 0.10.0
- install bos 0.2.1
- install ca-certs 1.0.1
- install camlp-streams 5.0.1
- install cmdliner 1.3.0
- install cohttp 6.1.0
- install cohttp-lwt 6.1.0
- install cohttp-lwt-unix 6.1.0
- install conduit 8.0.0
- install conduit-lwt 8.0.0
- install conduit-lwt-unix 8.0.0
- install conf-gmp 5
- install conf-gmp-powm-sec 4
- install conf-pkg-config 4
- install containers 3.15
- install cppo 1.8.0
- install csexp 1.5.2
- install digestif 1.3.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.18.1
- install dune-configurator 3.18.1
- install duration 0.2.1
- install either 1.0.0
- install eqaf 0.10
- install fmt 0.10.0
- install fpath 0.7.3
- install gen 1.1
- install gmap 0.3.0
- install http 6.1.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.8.0
- install lwt 5.9.1
- 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 4.0.0
- install ocamlbuild 0.16.1
- 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.16.0
- install ppxlib 0.35.0
- install psq 0.2.1
- install ptime 1.2.0
- install qcheck-core 0.25
- install qcheck-multicoretests-util 0.8
- install qcheck-stm 0.8
- install re 1.12.0
- install result 1.5
- install rresult 0.7.0
- install sedlex 3.4
- install seq base
- install sexplib0 v0.16.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.8
- install tsort 2.2.0
- install uri 4.4.0
- install uri-sexp 4.4.0
- install uutf 1.0.4
- install x509 1.0.6
- 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 alcotest.1.9.0 (cached)
-> retrieved backoff.0.1.1 (cached)
-> retrieved base.v0.16.4 (cached)
-> retrieved base64.3.5.1 (cached)
-> retrieved bigstringaf.0.10.0 (cached)
-> retrieved ca-certs.1.0.1 (cached)
-> retrieved bos.0.2.1 (cached)
-> retrieved camlp-streams.5.0.1 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> retrieved conf-gmp.5 (cached)
-> retrieved conf-gmp-powm-sec.4 (cached)
-> retrieved conduit.8.0.0, conduit-lwt.8.0.0, conduit-lwt-unix.8.0.0 (cached)
-> retrieved cohttp.6.1.0, cohttp-lwt.6.1.0, cohttp-lwt-unix.6.1.0, http.6.1.0 (cached)
-> retrieved containers.3.15 (cached)
-> installed conf-gmp.5
-> installed conf-pkg-config.4
-> retrieved cppo.1.8.0 (cached)
-> retrieved csexp.1.5.2 (cached)
-> installed conf-gmp-powm-sec.4
-> retrieved domain-local-await.1.0.1 (cached)
-> 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.10.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.3.0 (cached)
-> retrieved kdf.1.0.0 (cached)
-> retrieved logs.0.8.0 (cached)
-> retrieved lwt.5.9.1 (cached)
-> retrieved magic-mime.1.3.1 (cached)
-> retrieved mdx.2.5.0 (cached)
-> retrieved dune.3.18.1, dune-configurator.3.18.1 (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)
-> installed cmdliner.1.3.0
-> retrieved ocaml-compiler-libs.v0.17.0 (cached)
-> retrieved ocaml-syntax-shims.1.0.0 (cached)
-> retrieved ocaml-version.4.0.0 (cached)
-> retrieved ocplib-endian.1.2 (cached)
-> retrieved ocamlbuild.0.16.1 (cached)
-> retrieved ocamlfind.1.9.8 (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.16.0 (cached)
-> retrieved psq.0.2.1 (cached)
-> retrieved ptime.1.2.0 (cached)
-> retrieved qcheck-core.0.25 (cached)
-> retrieved qcheck-multicoretests-util.0.8, qcheck-stm.0.8 (cached)
-> retrieved ppxlib.0.35.0 (cached)
-> retrieved re.1.12.0 (cached)
-> retrieved result.1.5 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved rresult.0.7.0 (cached)
-> retrieved sedlex.3.4 (cached)
-> retrieved sexplib0.v0.16.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 tsort.2.2.0 (cached)
-> retrieved uutf.1.0.4 (cached)
-> retrieved topkg.1.0.8 (cached)
-> retrieved uri.4.4.0, uri-sexp.4.4.0 (cached)
-> retrieved x509.1.0.6 (cached)
-> retrieved yojson.2.2.2 (cached)
-> retrieved zarith.1.14 (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed zarith.1.14
-> installed ocamlbuild.0.16.1
-> installed topkg.1.0.8
-> installed rresult.0.7.0
-> installed mtime.2.1.0
-> installed ptime.1.2.0
-> installed uutf.1.0.4
-> installed fmt.0.10.0
-> installed astring.0.8.5
-> installed fpath.0.7.3
-> installed dune.3.18.1
-> installed backoff.0.1.1
-> installed camlp-streams.5.0.1
-> installed csexp.1.5.2
-> installed asn1-combinators.0.3.2
-> installed base64.3.5.1
-> 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.1.0
-> installed macaddr.5.6.0
-> installed menhirCST.20240715
-> installed menhirSdk.20240715
-> installed multicore-magic.2.3.1
-> installed ocaml-version.4.0.0
-> 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.16.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed thread-local-storage.0.2
-> installed thread-table.1.0.0
-> installed tsort.2.2.0
-> installed menhirLib.20240715
-> installed domain-local-await.1.0.1
-> installed qcheck-core.0.25
-> installed ipaddr.5.6.0
-> installed cppo.1.8.0
-> installed qcheck-multicoretests-util.0.8
-> installed ocplib-endian.1.2
-> installed yojson.2.2.2
-> installed digestif.1.3.0
-> installed qcheck-stm.0.8
-> installed magic-mime.1.3.1
-> installed multicore-bench.0.1.7
-> installed dune-configurator.3.18.1
-> installed bigstringaf.0.10.0
-> installed ocaml-syntax-shims.1.0.0
-> installed ocaml-compiler-libs.v0.17.0
-> installed angstrom.0.16.1
-> installed alcotest.1.9.0
-> installed mirage-crypto.2.0.0
-> installed containers.3.15
-> installed kdf.1.0.0
-> installed dscheck.0.5.0
-> installed multicore-magic-dscheck.2.3.1
-> installed lwt.5.9.1
-> installed uri.4.4.0
-> installed base.v0.16.4
-> installed menhir.20240715
-> installed ppxlib.0.35.0
-> installed ppx_sexp_conv.v0.16.0
-> installed sedlex.3.4
-> installed uri-sexp.4.4.0
-> installed ipaddr-sexp.5.6.0
-> installed js_of_ocaml-compiler.6.0.1
-> installed logs.0.8.0
-> installed mirage-crypto-rng.2.0.0
-> installed mirage-crypto-pk.2.0.0
-> installed bos.0.2.1
-> installed mdx.2.5.0
-> installed conduit.8.0.0
-> installed cohttp.6.1.0
-> installed conduit-lwt.8.0.0
-> installed cohttp-lwt.6.1.0
-> installed mirage-crypto-ec.2.0.0
-> installed x509.1.0.6
-> installed ca-certs.1.0.1
-> installed conduit-lwt-unix.8.0.0
-> installed cohttp-lwt-unix.6.1.0
-> installed js_of_ocaml.6.0.1
Done.
# To update the current shell environment, run: eval $(opam env)
2025-05-01 18:02.27 ---> saved as "b7b85bec5f5c39780cc41b532d4296f94c642b20c32aa42be41b3b126d7e404e"
/src: (copy (src .) (dst /src))
2025-05-01 18:02.28 ---> saved as "98a1fe3f91e894702dc707f77f835dc79085aa16d3716c044a6818d90f8ff074"
/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
(cd _build/default/test && ./test_server_and_client.exe)
Using non-blocking sockets and fibers on OCaml 5:
Recursive server running
Server listening
Server accepting
Client B running
Client A running
Client B connected
Client B wrote 100
Client A connected
Client A wrote 100
Server accepted client
Server read 100
Server wrote 50
Client B read 50
Server accepting
Server accepted client
Server read 100
Server wrote 50
Client A read 50
Server accepting
Server and Client test: OK
(cd _build/default/test && ./test_lwt_unix.exe)
Testing `Picos_lwt'.
This run has ID `0QNU0QJ7'.
[OK] Basics 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_lwt'.
Test Successful in 0.052s. 1 test run.
(cd _build/default/test && ./test_finally.exe)
Testing `Picos_finally'.
This run has ID `TTCNSJSM'.
[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.023s. 2 tests run.
(cd _build/default/bench && ./main.exe -brief 'Picos Computation')
Picos Computation:
attach detach pairs over time/1 worker:
0.13 M/s
attach detach pairs over time/2 workers:
0.39 M/s
attach detach pairs over time/4 workers:
0.05 M/s
attach detach pairs over time/trivial:
0.44 M/s
time per attach detach pair/1 worker:
7620.78 ns
time per attach detach pair/2 workers:
5091.17 ns
time per attach detach pair/4 workers:
83667.16 ns
time per attach detach pair/trivial:
2298.38 ns
(cd _build/default/test && ./test_io.exe)
Testing `Picos_io'.
This run has ID `0F84ZYTS'.
[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.708s. 6 tests run.
(cd _build/default/test && ./test_io_with_lwt.exe)
Testing `Picos_io_with_lwt'.
This run has ID `09LFHP9R'.
[OK] Unix 0 system.
Full test results in `/src/_build/default/test/_build/_tests/Picos_io_with_lwt'.
Test Successful in 2.194s. 1 test run.
(cd _build/default/test && ./test_structured.exe)
Testing `Picos_structured'.
This run has ID `ALD56JUZ'.
[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.158s. 14 tests run.
(cd _build/default/bench && ./main.exe -brief 'Picos Current')
Picos Current:
ops over time/1 worker:
1.73 M/s
ops over time/2 workers:
3.43 M/s
ops over time/4 workers:
0.47 M/s
time per op/1 worker:
576.57 ns
time per op/2 workers:
583.13 ns
time per op/4 workers:
8584.84 ns
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 0)
Testing `Picos_sync'.
This run has ID `4FRJ0E0F'.
[OK] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.040s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 1)
Testing `Picos_sync'.
This run has ID `JRIBX6DZ'.
[SKIP] Mutex and Condition 0 basics.
[OK] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.087s. 1 test run.
(cd _build/default/test && ./test_io_cohttp.exe)
Uri: //127.0.0.1:53297/hello-io-cohttp
Method: POST
host: 127.0.0.1:53297
user-agent: ocaml-cohttp/v6.1.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.1.0
content-length: 0
Body:
(cd _build/default/test && ./test_select.exe)
Testing `Picos_select'.
This run has ID `B69G3EP5'.
[OK] Intr 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_select'.
Test Successful in 12.762s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Mutex and Condition$' 2)
Testing `Picos_sync'.
This run has ID `GG337DD1'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[OK] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 5.370s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 0)
Testing `Picos_sync'.
This run has ID `3WF2IQSB'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[OK] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.067s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Picos FLS (excluding Current)')
Picos FLS (excluding Current):
gets over time/1 worker:
5.73 M/s
gets over time/2 workers:
11.29 M/s
gets over time/4 workers:
1.95 M/s
sets over time/1 worker:
6.65 M/s
sets over time/2 workers:
12.94 M/s
sets over time/4 workers:
1.27 M/s
time per get/1 worker:
174.65 ns
time per get/2 workers:
177.21 ns
time per get/4 workers:
2048.52 ns
time per set/1 worker:
150.44 ns
time per set/2 workers:
154.59 ns
time per set/4 workers:
3157.75 ns
(cd _build/default/bench && ./main.exe -brief 'Picos TLS')
Picos TLS:
gets over time/1 worker:
3.16 M/s
gets over time/2 workers:
6.09 M/s
gets over time/4 workers:
1.49 M/s
sets over time/1 worker:
3.14 M/s
sets over time/2 workers:
6.05 M/s
sets over time/4 workers:
1.05 M/s
time per get/1 worker:
316.60 ns
time per get/2 workers:
328.45 ns
time per get/4 workers:
2687.00 ns
time per set/1 worker:
318.70 ns
time per set/2 workers:
330.78 ns
time per set/4 workers:
3811.82 ns
(cd _build/default/bench && ./main.exe -brief 'Picos DLS')
Picos DLS:
gets over time/1 worker:
2.85 M/s
gets over time/2 workers:
1.53 M/s
gets over time/4 workers:
1.60 M/s
sets over time/1 worker:
3.57 M/s
sets over time/2 workers:
7.30 M/s
sets over time/4 workers:
2.27 M/s
time per get/1 worker:
351.36 ns
time per get/2 workers:
1305.28 ns
time per get/4 workers:
2494.20 ns
time per set/1 worker:
279.81 ns
time per set/2 workers:
273.82 ns
time per set/4 workers:
1761.55 ns
(cd _build/default/test && ./test_picos_dscheck.exe)
Testing `Picos DSCheck'.
This run has ID `X76SXQRH'.
[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 33.390s. 3 tests run.
(cd _build/default/example && ./guards.exe)
Testing with scheduler: randos ~n_domains:16
Ran guarded case statement examples.
(cd _build/default/bench && ./main.exe -brief 'Yield with Picos_std_sync')
Yield with Picos_std_sync:
locked yields over time/1024 fibers with Lock:
0.01 M/s
locked yields over time/1024 fibers with Rwlock:
0.01 M/s
locked yields over time/1024 fibers with Sem:
0.01 M/s
locked yields over time/1024 fibers with Sem 2:
0.02 M/s
locked yields over time/1024 fibers with Sem 3:
0.01 M/s
locked yields over time/1024 fibers with Sem 4:
0.02 M/s
locked yields over time/1 fiber with Lock:
0.32 M/s
locked yields over time/1 fiber with Rwlock:
0.33 M/s
locked yields over time/1 fiber with Sem:
0.05 M/s
locked yields over time/1 fiber with Sem 2:
0.04 M/s
locked yields over time/1 fiber with Sem 3:
0.31 M/s
locked yields over time/1 fiber with Sem 4:
0.31 M/s
locked yields over time/256 fibers with Lock:
0.02 M/s
locked yields over time/256 fibers with Rwlock:
0.01 M/s
locked yields over time/256 fibers with Sem:
0.03 M/s
locked yields over time/256 fibers with Sem 2:
0.05 M/s
locked yields over time/256 fibers with Sem 3:
0.03 M/s
locked yields over time/256 fibers with Sem 4:
0.05 M/s
locked yields over time/2 domains with Lock:
0.10 M/s
locked yields over time/2 domains with Rwlock:
0.01 M/s
locked yields over time/2 domains with Sem:
0.11 M/s
locked yields over time/2 domains with Sem 2:
0.02 M/s
locked yields over time/2 domains with Sem 3:
0.33 M/s
locked yields over time/2 domains with Sem 4:
0.34 M/s
locked yields over time/2 fibers with Lock:
0.32 M/s
locked yields over time/2 fibers with Rwlock:
0.33 M/s
locked yields over time/2 fibers with Sem:
0.32 M/s
locked yields over time/2 fibers with Sem 2:
0.32 M/s
locked yields over time/2 fibers with Sem 3:
0.31 M/s
locked yields over time/2 fibers with Sem 4:
0.31 M/s
locked yields over time/3 domains with Lock:
0.02 M/s
locked yields over time/3 domains with Rwlock:
0.02 M/s
locked yields over time/3 domains with Sem:
0.11 M/s
locked yields over time/3 domains with Sem 2:
0.01 M/s
locked yields over time/3 domains with Sem 3:
0.02 M/s
locked yields over time/3 domains with Sem 4:
0.01 M/s
locked yields over time/3 fibers with Lock:
0.32 M/s
locked yields over time/3 fibers with Rwlock:
0.32 M/s
locked yields over time/3 fibers with Sem:
0.32 M/s
locked yields over time/3 fibers with Sem 2:
0.31 M/s
locked yields over time/3 fibers with Sem 3:
0.07 M/s
locked yields over time/3 fibers with Sem 4:
0.31 M/s
locked yields over time/4 domains with Lock:
0.01 M/s
locked yields over time/4 domains with Rwlock:
0.01 M/s
locked yields over time/4 domains with Sem:
0.03 M/s
locked yields over time/4 domains with Sem 2:
0.01 M/s
locked yields over time/4 domains with Sem 3:
0.01 M/s
locked yields over time/4 domains with Sem 4:
0.01 M/s
locked yields over time/4 fibers with Lock:
0.32 M/s
locked yields over time/4 fibers with Rwlock:
0.31 M/s
locked yields over time/4 fibers with Sem:
0.31 M/s
locked yields over time/4 fibers with Sem 2:
0.31 M/s
locked yields over time/4 fibers with Sem 3:
0.31 M/s
locked yields over time/4 fibers with Sem 4:
0.31 M/s
locked yields over time/512 fibers with Lock:
0.03 M/s
locked yields over time/512 fibers with Rwlock:
0.02 M/s
locked yields over time/512 fibers with Sem:
0.03 M/s
locked yields over time/512 fibers with Sem 2:
0.03 M/s
locked yields over time/512 fibers with Sem 3:
0.03 M/s
locked yields over time/512 fibers with Sem 4:
0.03 M/s
locked yields over time/8 domains with Lock:
0.01 M/s
locked yields over time/8 domains with Rwlock:
0.01 M/s
locked yields over time/8 domains with Sem:
0.01 M/s
locked yields over time/8 domains with Sem 2:
0.01 M/s
locked yields over time/8 domains with Sem 3:
0.01 M/s
locked yields over time/8 domains with Sem 4:
0.01 M/s
locked yields over time/8 fibers with Lock:
0.31 M/s
locked yields over time/8 fibers with Rwlock:
0.32 M/s
locked yields over time/8 fibers with Sem:
0.31 M/s
locked yields over time/8 fibers with Sem 2:
0.31 M/s
locked yields over time/8 fibers with Sem 3:
0.31 M/s
locked yields over time/8 fibers with Sem 4:
0.31 M/s
time per locked yield/1024 fibers with Lock:
91299.75 ns
time per locked yield/1024 fibers with Rwlock:
71487.41 ns
time per locked yield/1024 fibers with Sem:
104293.77 ns
time per locked yield/1024 fibers with Sem 2:
48451.22 ns
time per locked yield/1024 fibers with Sem 3:
68385.31 ns
time per locked yield/1024 fibers with Sem 4:
47231.17 ns
time per locked yield/1 fiber with Lock:
3094.77 ns
time per locked yield/1 fiber with Rwlock:
3057.92 ns
time per locked yield/1 fiber with Sem:
19179.38 ns
time per locked yield/1 fiber with Sem 2:
27238.84 ns
time per locked yield/1 fiber with Sem 3:
3241.80 ns
time per locked yield/1 fiber with Sem 4:
3214.41 ns
time per locked yield/256 fibers with Lock:
45824.34 ns
time per locked yield/256 fibers with Rwlock:
78011.89 ns
time per locked yield/256 fibers with Sem:
29755.68 ns
time per locked yield/256 fibers with Sem 2:
19860.18 ns
time per locked yield/256 fibers with Sem 3:
34808.28 ns
time per locked yield/256 fibers with Sem 4:
21392.99 ns
time per locked yield/2 domains with Lock:
19433.47 ns
time per locked yield/2 domains with Rwlock:
173680.49 ns
time per locked yield/2 domains with Sem:
18842.19 ns
time per locked yield/2 domains with Sem 2:
108776.11 ns
time per locked yield/2 domains with Sem 3:
6071.10 ns
time per locked yield/2 domains with Sem 4:
5885.31 ns
time per locked yield/2 fibers with Lock:
3108.56 ns
time per locked yield/2 fibers with Rwlock:
3048.74 ns
time per locked yield/2 fibers with Sem:
3158.26 ns
time per locked yield/2 fibers with Sem 2:
3104.85 ns
time per locked yield/2 fibers with Sem 3:
3238.87 ns
time per locked yield/2 fibers with Sem 4:
3223.85 ns
time per locked yield/3 domains with Lock:
136281.95 ns
time per locked yield/3 domains with Rwlock:
167556.12 ns
time per locked yield/3 domains with Sem:
28077.67 ns
time per locked yield/3 domains with Sem 2:
318410.50 ns
time per locked yield/3 domains with Sem 3:
136062.65 ns
time per locked yield/3 domains with Sem 4:
204399.50 ns
time per locked yield/3 fibers with Lock:
3100.51 ns
time per locked yield/3 fibers with Rwlock:
3089.92 ns
time per locked yield/3 fibers with Sem:
3157.80 ns
time per locked yield/3 fibers with Sem 2:
3186.09 ns
time per locked yield/3 fibers with Sem 3:
15285.68 ns
time per locked yield/3 fibers with Sem 4:
3242.52 ns
time per locked yield/4 domains with Lock:
277589.39 ns
time per locked yield/4 domains with Rwlock:
461225.13 ns
time per locked yield/4 domains with Sem:
140968.55 ns
time per locked yield/4 domains with Sem 2:
447321.19 ns
time per locked yield/4 domains with Sem 3:
666177.69 ns
time per locked yield/4 domains with Sem 4:
725288.33 ns
time per locked yield/4 fibers with Lock:
3097.27 ns
time per locked yield/4 fibers with Rwlock:
3276.30 ns
time per locked yield/4 fibers with Sem:
3178.09 ns
time per locked yield/4 fibers with Sem 2:
3192.51 ns
time per locked yield/4 fibers with Sem 3:
3211.40 ns
time per locked yield/4 fibers with Sem 4:
3261.93 ns
time per locked yield/512 fibers with Lock:
31278.57 ns
time per locked yield/512 fibers with Rwlock:
43793.47 ns
time per locked yield/512 fibers with Sem:
31503.97 ns
time per locked yield/512 fibers with Sem 2:
28995.77 ns
time per locked yield/512 fibers with Sem 3:
32666.78 ns
time per locked yield/512 fibers with Sem 4:
35287.86 ns
time per locked yield/8 domains with Lock:
799417.43 ns
time per locked yield/8 domains with Rwlock:
861784.06 ns
time per locked yield/8 domains with Sem:
903700.21 ns
time per locked yield/8 domains with Sem 2:
810641.73 ns
time per locked yield/8 domains with Sem 3:
1289648.66 ns
time per locked yield/8 domains with Sem 4:
607908.22 ns
time per locked yield/8 fibers with Lock:
3178.43 ns
time per locked yield/8 fibers with Rwlock:
3148.26 ns
time per locked yield/8 fibers with Sem:
3224.93 ns
time per locked yield/8 fibers with Sem 2:
3265.46 ns
time per locked yield/8 fibers with Sem 3:
3243.04 ns
time per locked yield/8 fibers with Sem 4:
3238.19 ns
(cd _build/default/bench && ./main.exe -brief 'Picos Spawn')
Picos Spawn:
(cd _build/default/bench && ./main.exe -brief 'Picos Yield')
Picos Yield:
time per yield/100 fibers:
5867.91 ns
time per yield/10 fibers:
3804.56 ns
time per yield/1 fiber:
3156.83 ns
yields over time/100 fibers:
0.17 M/s
yields over time/10 fibers:
0.26 M/s
yields over time/1 fiber:
0.32 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.04 M/s
async round-trips over time/2 workers:
0.03 M/s
async round-trips over time/4 workers:
0.03 M/s
round-trips over time/1 worker:
0.00 M/s
round-trips over time/2 workers:
0.07 M/s
round-trips over time/4 workers:
0.01 M/s
time per async round-trip/1 worker:
25773.49 ns
time per async round-trip/2 workers:
75126.79 ns
time per async round-trip/4 workers:
140286.43 ns
time per round-trip/1 worker:
293433.90 ns
time per round-trip/2 workers:
30632.78 ns
time per round-trip/4 workers:
379228.00 ns
(cd _build/default/test && ./test_sem.exe)
random seed: 746460899
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Sem sequential
[ ] 0 0 0 0 / 32 0.0s Sem sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Sem sequential
[ ] 0 0 0 0 / 32 0.0s Sem parallel
[ ] 1 0 0 1 / 32 1.4s Sem parallel
[ ] 2 0 0 2 / 32 2.4s Sem parallel
[ ] 3 0 0 3 / 32 3.4s Sem parallel
[ ] 4 0 0 4 / 32 4.6s Sem parallel
[ ] 5 0 0 5 / 32 5.4s Sem parallel
[ ] 6 0 0 6 / 32 6.6s Sem parallel
[ ] 7 0 0 7 / 32 7.6s Sem parallel
[ ] 8 0 0 8 / 32 9.5s Sem parallel
[ ] 9 0 0 9 / 32 10.2s Sem parallel
[ ] 10 0 0 10 / 32 17.8s Sem parallel
[ ] 11 0 0 11 / 32 18.6s Sem parallel
[ ] 12 0 0 12 / 32 19.7s Sem parallel
[ ] 13 0 0 13 / 32 20.9s Sem parallel
[ ] 14 0 0 14 / 32 21.6s Sem parallel
[ ] 15 0 0 15 / 32 22.6s Sem parallel
[ ] 16 0 0 16 / 32 23.7s Sem parallel
[ ] 17 0 0 17 / 32 24.7s Sem parallel
[ ] 18 0 0 18 / 32 25.6s Sem parallel
[ ] 19 0 0 19 / 32 26.3s Sem parallel
[ ] 20 0 0 20 / 32 27.9s Sem parallel
[ ] 21 0 0 21 / 32 28.9s Sem parallel
[ ] 22 0 0 22 / 32 43.5s Sem parallel
[ ] 23 0 0 23 / 32 49.4s Sem parallel
[ ] 24 0 0 24 / 32 51.9s Sem parallel
[ ] 25 0 0 25 / 32 57.7s Sem parallel
[ ] 26 0 0 26 / 32 58.4s Sem parallel
[ ] 27 0 0 27 / 32 59.2s Sem parallel
[ ] 28 0 0 28 / 32 60.0s Sem parallel
[ ] 29 0 0 29 / 32 60.7s Sem parallel
[ ] 30 0 0 30 / 32 61.2s Sem parallel
[ ] 31 0 0 31 / 32 61.8s Sem parallel
[ ] 32 0 0 32 / 32 62.4s Sem parallel
[✓] 32 0 0 32 / 32 62.4s Sem parallel
================================================================================
success (ran 2 tests)
(cd _build/default/bench && ./main.exe -brief 'Ref with Picos_std_sync')
Ref with Picos_std_sync:
ops over time/cas int with Lock:
1.60 M/s
ops over time/cas int with Rwlock:
1.48 M/s
ops over time/cas int with Sem:
1.46 M/s
ops over time/get with Lock:
1.97 M/s
ops over time/get with Rwlock:
1.93 M/s
ops over time/get with Sem:
1.66 M/s
ops over time/incr with Lock:
1.81 M/s
ops over time/incr with Rwlock:
1.81 M/s
ops over time/incr with Sem:
1.57 M/s
ops over time/push & pop with Lock:
1.70 M/s
ops over time/push & pop with Rwlock:
1.70 M/s
ops over time/push & pop with Sem:
1.50 M/s
ops over time/swap with Lock:
1.70 M/s
ops over time/swap with Rwlock:
1.67 M/s
ops over time/swap with Sem:
1.53 M/s
ops over time/xchg int with Lock:
1.59 M/s
ops over time/xchg int with Rwlock:
1.60 M/s
ops over time/xchg int with Sem:
1.41 M/s
time per op/cas int with Lock:
623.37 ns
time per op/cas int with Rwlock:
676.30 ns
time per op/cas int with Sem:
684.54 ns
time per op/get with Lock:
507.33 ns
time per op/get with Rwlock:
518.86 ns
time per op/get with Sem:
602.75 ns
time per op/incr with Lock:
553.76 ns
time per op/incr with Rwlock:
552.60 ns
time per op/incr with Sem:
635.56 ns
time per op/push & pop with Lock:
588.99 ns
time per op/push & pop with Rwlock:
587.67 ns
time per op/push & pop with Sem:
666.59 ns
time per op/swap with Lock:
586.72 ns
time per op/swap with Rwlock:
597.89 ns
time per op/swap with Sem:
653.58 ns
time per op/xchg int with Lock:
629.89 ns
time per op/xchg int with Rwlock:
623.19 ns
time per op/xchg int with Sem:
707.98 ns
(cd _build/default/test && ./test_rwlock.exe)
random seed: 869862095
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Rwlock sequential
[ ] 0 0 0 0 / 32 0.0s Rwlock sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Rwlock sequential
[ ] 0 0 0 0 / 32 0.0s Rwlock parallel
[ ] 1 0 0 1 / 32 1.1s Rwlock parallel
[ ] 2 0 0 2 / 32 5.5s Rwlock parallel
[ ] 3 0 0 3 / 32 6.9s Rwlock parallel
[ ] 4 0 0 4 / 32 7.9s Rwlock parallel
[ ] 5 0 0 5 / 32 9.1s Rwlock parallel
[ ] 6 0 0 6 / 32 10.5s Rwlock parallel
[ ] 7 0 0 7 / 32 11.7s Rwlock parallel
[ ] 8 0 0 8 / 32 12.8s Rwlock parallel
[ ] 9 0 0 9 / 32 13.8s Rwlock parallel
[ ] 10 0 0 10 / 32 14.9s Rwlock parallel
[ ] 11 0 0 11 / 32 16.0s Rwlock parallel
[ ] 12 0 0 12 / 32 16.9s Rwlock parallel
[ ] 13 0 0 13 / 32 17.9s Rwlock parallel
[ ] 14 0 0 14 / 32 18.9s Rwlock parallel
[ ] 15 0 0 15 / 32 21.9s Rwlock parallel
[ ] 16 0 0 16 / 32 23.5s Rwlock parallel
[ ] 17 0 0 17 / 32 24.6s Rwlock parallel
[ ] 18 0 0 18 / 32 25.9s Rwlock parallel
[ ] 19 0 0 19 / 32 26.9s Rwlock parallel
[ ] 20 0 0 20 / 32 27.8s Rwlock parallel
[ ] 21 0 0 21 / 32 43.3s Rwlock parallel
[ ] 22 0 0 22 / 32 44.8s Rwlock parallel
[ ] 23 0 0 23 / 32 46.1s Rwlock parallel
[ ] 24 0 0 24 / 32 47.6s Rwlock parallel
[ ] 25 0 0 25 / 32 48.6s Rwlock parallel
[ ] 26 0 0 26 / 32 49.5s Rwlock parallel
[ ] 27 0 0 27 / 32 50.5s Rwlock parallel
[ ] 28 0 0 28 / 32 54.4s Rwlock parallel
[ ] 29 0 0 29 / 32 55.3s Rwlock parallel
[ ] 30 0 0 30 / 32 56.4s Rwlock parallel
[ ] 31 0 0 31 / 32 63.8s Rwlock parallel
[ ] 32 0 0 32 / 32 64.2s Rwlock parallel
[✓] 32 0 0 32 / 32 64.2s Rwlock parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_picos.exe)
Testing `Picos'.
This run has ID `XOIBMK01'.
[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 60.146s. 7 tests run.
(cd _build/default/bench && ./main.exe -brief Picos_mpmcq)
Picos_mpmcq:
messages over time/1 nb adder, 1 nb taker:
1.43 M/s
messages over time/1 nb adder, 2 nb takers:
1.40 M/s
messages over time/1 nb adder, 4 nb takers:
1.51 M/s
messages over time/2 nb adders, 1 nb taker:
1.44 M/s
messages over time/2 nb adders, 2 nb takers:
1.51 M/s
messages over time/2 nb adders, 4 nb takers:
0.23 M/s
messages over time/4 nb adders, 1 nb taker:
1.23 M/s
messages over time/4 nb adders, 2 nb takers:
1.38 M/s
messages over time/4 nb adders, 4 nb takers:
0.11 M/s
messages over time/one domain:
0.76 M/s
time per message/1 nb adder, 1 nb taker:
1400.70 ns
time per message/1 nb adder, 2 nb takers:
2144.17 ns
time per message/1 nb adder, 4 nb takers:
3307.58 ns
time per message/2 nb adders, 1 nb taker:
2079.70 ns
time per message/2 nb adders, 2 nb takers:
2641.40 ns
time per message/2 nb adders, 4 nb takers:
26384.86 ns
time per message/4 nb adders, 1 nb taker:
4056.53 ns
time per message/4 nb adders, 2 nb takers:
4341.05 ns
time per message/4 nb adders, 4 nb takers:
75060.57 ns
time per message/one domain:
1316.90 ns
(cd _build/default/test && ./test_htbl.exe)
random seed: 745178407
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.1s Htbl parallel
[ ] 3 0 0 3 / 32 13.1s Htbl parallel
[ ] 4 0 0 4 / 32 14.7s Htbl parallel
[ ] 5 0 0 5 / 32 15.9s Htbl parallel
[ ] 6 0 0 6 / 32 20.4s Htbl parallel
[ ] 7 0 0 7 / 32 21.6s Htbl parallel
[ ] 8 0 0 8 / 32 22.4s Htbl parallel
[ ] 9 0 0 9 / 32 25.8s Htbl parallel
[ ] 10 0 0 10 / 32 26.7s Htbl parallel
[ ] 11 0 0 11 / 32 27.8s Htbl parallel
[ ] 12 0 0 12 / 32 28.7s Htbl parallel
[ ] 13 0 0 13 / 32 29.6s Htbl parallel
[ ] 14 0 0 14 / 32 30.6s Htbl parallel
[ ] 15 0 0 15 / 32 32.1s Htbl parallel
[ ] 16 0 0 16 / 32 33.2s Htbl parallel
[ ] 17 0 0 17 / 32 48.4s Htbl parallel
[ ] 18 0 0 18 / 32 49.2s Htbl parallel
[ ] 19 0 0 19 / 32 50.3s Htbl parallel
[ ] 20 0 0 20 / 32 55.7s Htbl parallel
[ ] 21 0 0 21 / 32 56.3s Htbl parallel
[ ] 22 0 0 22 / 32 57.0s Htbl parallel
[ ] 23 0 0 23 / 32 57.8s Htbl parallel
[ ] 24 0 0 24 / 32 61.9s Htbl parallel
[ ] 25 0 0 25 / 32 62.4s Htbl parallel
[ ] 26 0 0 26 / 32 67.9s Htbl parallel
[ ] 27 0 0 27 / 32 68.3s Htbl parallel
[ ] 28 0 0 28 / 32 69.5s Htbl parallel
[ ] 29 0 0 29 / 32 70.2s Htbl parallel
[ ] 30 0 0 30 / 32 70.7s Htbl parallel
[ ] 31 0 0 31 / 32 71.2s Htbl parallel
[ ] 32 0 0 32 / 32 72.0s Htbl parallel
[✓] 32 0 0 32 / 32 72.0s Htbl parallel
================================================================================
success (ran 2 tests)
(cd _build/default/bench && ./main.exe -brief Picos_mpscq)
Picos_mpscq:
messages over time/1 nb adder, 1 nb taker:
2.46 M/s
messages over time/2 nb adders, 1 nb taker:
2.78 M/s
messages over time/4 nb adders, 1 nb taker:
2.46 M/s
messages over time/one domain:
0.97 M/s
time per message/1 nb adder, 1 nb taker:
813.81 ns
time per message/2 nb adders, 1 nb taker:
1078.57 ns
time per message/4 nb adders, 1 nb taker:
2034.07 ns
time per message/one domain:
1034.84 ns
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 1)
Testing `Picos_sync'.
This run has ID `88PGP0NA'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[OK] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 54.317s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 2)
Testing `Picos_sync'.
This run has ID `1Q3R7KZX'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[OK] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.023s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Lock and Lock.Condition$' 3)
Testing `Picos_sync'.
This run has ID `SLBCA1OV'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[OK] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.014s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 0)
Testing `Picos_sync'.
This run has ID `KX6OWSWF'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[OK] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.086s. 1 test run.
(cd _build/default/test && ./test_mpmcq.exe)
random seed: 835188384
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 1.3s Mpmcq parallel
[ ] 2 0 0 2 / 32 2.4s Mpmcq parallel
[ ] 3 0 0 3 / 32 3.6s Mpmcq parallel
[ ] 4 0 0 4 / 32 5.3s Mpmcq parallel
[ ] 5 0 0 5 / 32 8.2s Mpmcq parallel
[ ] 6 0 0 6 / 32 11.8s Mpmcq parallel
[ ] 7 0 0 7 / 32 13.1s Mpmcq parallel
[ ] 8 0 0 8 / 32 14.5s Mpmcq parallel
[ ] 9 0 0 9 / 32 15.5s Mpmcq parallel
[ ] 10 0 0 10 / 32 19.2s Mpmcq parallel
[ ] 11 0 0 11 / 32 20.4s Mpmcq parallel
[ ] 12 0 0 12 / 32 21.4s Mpmcq parallel
[ ] 13 0 0 13 / 32 22.5s Mpmcq parallel
[ ] 14 0 0 14 / 32 23.3s Mpmcq parallel
[ ] 15 0 0 15 / 32 24.3s Mpmcq parallel
[ ] 16 0 0 16 / 32 27.8s Mpmcq parallel
[ ] 17 0 0 17 / 32 28.9s Mpmcq parallel
[ ] 18 0 0 18 / 32 30.0s Mpmcq parallel
[ ] 19 0 0 19 / 32 30.7s Mpmcq parallel
[ ] 20 0 0 20 / 32 31.8s Mpmcq parallel
[ ] 21 0 0 21 / 32 32.8s Mpmcq parallel
[ ] 22 0 0 22 / 32 34.1s Mpmcq parallel
[ ] 23 0 0 23 / 32 34.9s Mpmcq parallel
[ ] 24 0 0 24 / 32 36.1s Mpmcq parallel
[ ] 25 0 0 25 / 32 37.4s Mpmcq parallel
[ ] 26 0 0 26 / 32 38.6s Mpmcq parallel
[ ] 27 0 0 27 / 32 39.6s Mpmcq parallel
[ ] 28 0 0 28 / 32 40.7s Mpmcq parallel
[ ] 29 0 0 29 / 32 41.7s Mpmcq parallel
[ ] 30 0 0 30 / 32 42.8s Mpmcq parallel
[ ] 31 0 0 31 / 32 45.1s Mpmcq parallel
[ ] 32 0 0 32 / 32 46.3s Mpmcq parallel
[✓] 32 0 0 32 / 32 46.3s Mpmcq parallel
================================================================================
success (ran 2 tests)
random seed: 1063061157
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 1.0s Mpmcq parallel
[ ] 2 0 0 2 / 32 2.0s Mpmcq parallel
[ ] 3 0 0 3 / 32 3.3s Mpmcq parallel
[ ] 4 0 0 4 / 32 4.2s Mpmcq parallel
[ ] 5 0 0 5 / 32 4.9s Mpmcq parallel
[ ] 6 0 0 6 / 32 7.2s Mpmcq parallel
[ ] 7 0 0 7 / 32 8.2s Mpmcq parallel
[ ] 8 0 0 8 / 32 9.2s Mpmcq parallel
[ ] 9 0 0 9 / 32 10.3s Mpmcq parallel
[ ] 10 0 0 10 / 32 11.4s Mpmcq parallel
[ ] 11 0 0 11 / 32 12.3s Mpmcq parallel
[ ] 12 0 0 12 / 32 13.1s Mpmcq parallel
[ ] 13 0 0 13 / 32 13.9s Mpmcq parallel
[ ] 14 0 0 14 / 32 16.8s Mpmcq parallel
[ ] 15 0 0 15 / 32 17.6s Mpmcq parallel
[ ] 16 0 0 16 / 32 19.8s Mpmcq parallel
[ ] 17 0 0 17 / 32 20.3s Mpmcq parallel
[ ] 18 0 0 18 / 32 22.0s Mpmcq parallel
[ ] 19 0 0 19 / 32 22.5s Mpmcq parallel
[ ] 20 0 0 20 / 32 23.1s Mpmcq parallel
[ ] 21 0 0 21 / 32 26.7s Mpmcq parallel
[ ] 22 0 0 22 / 32 27.1s Mpmcq parallel
[ ] 23 0 0 23 / 32 28.1s Mpmcq parallel
[ ] 24 0 0 24 / 32 28.4s Mpmcq parallel
[ ] 25 0 0 25 / 32 28.5s Mpmcq parallel
[ ] 27 0 0 27 / 32 28.8s Mpmcq parallel
[ ] 28 0 0 28 / 32 29.2s Mpmcq parallel
[ ] 29 0 0 29 / 32 30.0s Mpmcq parallel
[ ] 30 0 0 30 / 32 30.7s Mpmcq parallel
[ ] 31 0 0 31 / 32 31.0s Mpmcq parallel
[ ] 32 0 0 32 / 32 31.2s Mpmcq parallel
[✓] 32 0 0 32 / 32 31.2s Mpmcq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_lock.exe)
random seed: 559277714
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Lock sequential
[ ] 0 0 0 0 / 32 0.0s Lock sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Lock sequential
[ ] 0 0 0 0 / 32 0.0s Lock parallel
[ ] 1 0 0 1 / 32 1.1s Lock parallel
[ ] 2 0 0 2 / 32 2.4s Lock parallel
[ ] 3 0 0 3 / 32 4.2s Lock parallel
[ ] 4 0 0 4 / 32 5.2s Lock parallel
[ ] 5 0 0 5 / 32 6.3s Lock parallel
[ ] 6 0 0 6 / 32 12.9s Lock parallel
[ ] 7 0 0 7 / 32 14.1s Lock parallel
[ ] 8 0 0 8 / 32 29.1s Lock parallel
[ ] 9 0 0 9 / 32 30.1s Lock parallel
[ ] 10 0 0 10 / 32 33.1s Lock parallel
[ ] 11 0 0 11 / 32 33.7s Lock parallel
[ ] 12 0 0 12 / 32 46.8s Lock parallel
[ ] 13 0 0 13 / 32 47.8s Lock parallel
[ ] 14 0 0 14 / 32 60.2s Lock parallel
[ ] 15 0 0 15 / 32 62.2s Lock parallel
[ ] 16 0 0 16 / 32 62.9s Lock parallel
[ ] 17 0 0 17 / 32 63.6s Lock parallel
[ ] 18 0 0 18 / 32 64.2s Lock parallel
[ ] 19 0 0 19 / 32 64.9s Lock parallel
[ ] 20 0 0 20 / 32 67.8s Lock parallel
[ ] 21 0 0 21 / 32 68.3s Lock parallel
[ ] 22 0 0 22 / 32 68.8s Lock parallel
[ ] 23 0 0 23 / 32 69.4s Lock parallel
[ ] 24 0 0 24 / 32 69.9s Lock parallel
[ ] 25 0 0 25 / 32 74.8s Lock parallel
[ ] 26 0 0 26 / 32 75.1s Lock parallel
[ ] 27 0 0 27 / 32 75.4s Lock parallel
[ ] 28 0 0 28 / 32 75.8s Lock parallel
[ ] 29 0 0 29 / 32 76.1s Lock parallel
[ ] 30 0 0 30 / 32 76.3s Lock parallel
[ ] 31 0 0 31 / 32 76.7s Lock parallel
[ ] 32 0 0 32 / 32 77.0s Lock parallel
[✓] 32 0 0 32 / 32 77.0s Lock parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 1)
Testing `Picos_sync'.
This run has ID `CAB0XLDH'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[OK] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 4.083s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 2)
Testing `Picos_sync'.
This run has ID `DQG4B72C'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[OK] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.007s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 3)
Testing `Picos_sync'.
This run has ID `PCZ2JQCG'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[OK] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.022s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 4)
Testing `Picos_sync'.
This run has ID `6IW7BSY5'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
3m[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[OK] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.023s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 5)
Testing `Picos_sync'.
This run has ID `BZYS8SBS'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[OK] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.021s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Rwlock and Rwlock.Condition$' 6)
Testing `Picos_sync'.
This run has ID `FBAWX4PP'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[OK] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.011s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Semaphore$ 0)
Testing `Picos_sync'.
This run has ID `2HS1IEE8'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[OK] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.017s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_htbl)
Picos_htbl:
operations over time/1 worker, 10% reads:
0.14 M/s
operations over time/1 worker, 50% reads:
0.17 M/s
operations over time/1 worker, 90% reads:
0.20 M/s
operations over time/2 workers, 10% reads:
0.28 M/s
operations over time/2 workers, 50% reads:
0.34 M/s
operations over time/2 workers, 90% reads:
0.40 M/s
operations over time/4 workers, 10% reads:
0.45 M/s
operations over time/4 workers, 50% reads:
0.66 M/s
operations over time/4 workers, 90% reads:
0.77 M/s
operations over time/8 workers, 10% reads:
0.78 M/s
operations over time/8 workers, 50% reads:
1.26 M/s
operations over time/8 workers, 90% reads:
1.66 M/s
time per operation/1 worker, 10% reads:
7043.95 ns
time per operation/1 worker, 50% reads:
5815.05 ns
time per operation/1 worker, 90% reads:
4978.13 ns
time per operation/2 workers, 10% reads:
7033.45 ns
time per operation/2 workers, 50% reads:
5802.11 ns
time per operation/2 workers, 90% reads:
4986.60 ns
time per operation/4 workers, 10% reads:
8972.82 ns
time per operation/4 workers, 50% reads:
6050.73 ns
time per operation/4 workers, 90% reads:
5213.98 ns
time per operation/8 workers, 10% reads:
10310.25 ns
time per operation/8 workers, 50% reads:
6364.39 ns
time per operation/8 workers, 90% reads:
4826.86 ns
(cd _build/default/test && ./test_schedulers.exe)
Testing with scheduler: fifos ~quota:20
Fairness of 100 fibers performing at least 10000 yields:
sd: 0.000141 -- ideally 0
mean: 1.000200 -- ideally 1
median: 1.000200 -- ideally 1
Testing `Picos schedulers'.
This run has ID `GN8QM1VL'.
[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 60.326s. 8 tests run.
(cd _build/default/test && ./test_mpmcq_dscheck.exe)
Testing `Picos_mpmcq DSCheck'.
This run has ID `EFFNFEP2'.
[OK] Multiple pushes and pops 0
Full test results in `/src/_build/default/test/_build/_tests/Picos_mpmcq DSCheck'.
Test Successful in 74.274s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Semaphore$ 1)
Testing `Picos_sync'.
This run has ID `RNHOFX9Y'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[OK] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 2.396s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 0)
Testing `Picos_sync'.
This run has ID `UJ1NMGR4'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[OK] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.011s. 1 test run.
(cd _build/default/bench && ./main.exe -brief 'Hashtbl with Picos_std_sync')
Hashtbl with Picos_std_sync:
operations over time/1 worker, 10% reads with Lock:
0.65 M/s
operations over time/1 worker, 10% reads with Rwlock:
0.64 M/s
operations over time/1 worker, 10% reads with Sem:
0.61 M/s
operations over time/1 worker, 100% reads with Lock:
0.75 M/s
operations over time/1 worker, 100% reads with Rwlock:
0.75 M/s
operations over time/1 worker, 100% reads with Sem:
0.70 M/s
operations over time/1 worker, 50% reads with Lock:
0.70 M/s
operations over time/1 worker, 50% reads with Rwlock:
0.67 M/s
operations over time/1 worker, 50% reads with Sem:
0.65 M/s
operations over time/1 worker, 90% reads with Lock:
0.75 M/s
operations over time/1 worker, 90% reads with Rwlock:
0.72 M/s
operations over time/1 worker, 90% reads with Sem:
0.69 M/s
operations over time/1 worker, 95% reads with Lock:
0.75 M/s
operations over time/1 worker, 95% reads with Rwlock:
0.73 M/s
operations over time/1 worker, 95% reads with Sem:
0.69 M/s
operations over time/2 workers, 10% reads with Lock:
0.59 M/s
operations over time/2 workers, 10% reads with Rwlock:
0.63 M/s
operations over time/2 workers, 10% reads with Sem:
0.54 M/s
operations over time/2 workers, 100% reads with Lock:
0.82 M/s
operations over time/2 workers, 100% reads with Rwlock:
1.46 M/s
operations over time/2 workers, 100% reads with Sem:
0.70 M/s
operations over time/2 workers, 50% reads with Lock:
0.63 M/s
operations over time/2 workers, 50% reads with Rwlock:
0.60 M/s
operations over time/2 workers, 50% reads with Sem:
0.60 M/s
operations over time/2 workers, 90% reads with Lock:
0.76 M/s
operations over time/2 workers, 90% reads with Rwlock:
1.03 M/s
operations over time/2 workers, 90% reads with Sem:
0.68 M/s
operations over time/2 workers, 95% reads with Lock:
0.81 M/s
operations over time/2 workers, 95% reads with Rwlock:
1.09 M/s
operations over time/2 workers, 95% reads with Sem:
0.70 M/s
operations over time/4 workers, 10% reads with Lock:
0.36 M/s
operations over time/4 workers, 10% reads with Rwlock:
0.33 M/s
operations over time/4 workers, 10% reads with Sem:
0.43 M/s
operations over time/4 workers, 100% reads with Lock:
0.45 M/s
operations over time/4 workers, 100% reads with Rwlock:
2.94 M/s
operations over time/4 workers, 100% reads with Sem:
0.54 M/s
operations over time/4 workers, 50% reads with Lock:
0.41 M/s
operations over time/4 workers, 50% reads with Rwlock:
0.41 M/s
operations over time/4 workers, 50% reads with Sem:
0.46 M/s
operations over time/4 workers, 90% reads with Lock:
0.45 M/s
operations over time/4 workers, 90% reads with Rwlock:
0.87 M/s
operations over time/4 workers, 90% reads with Sem:
0.51 M/s
operations over time/4 workers, 95% reads with Lock:
0.45 M/s
operations over time/4 workers, 95% reads with Rwlock:
1.07 M/s
operations over time/4 workers, 95% reads with Sem:
0.47 M/s
operations over time/8 workers, 10% reads with Lock:
0.30 M/s
operations over time/8 workers, 10% reads with Rwlock:
0.36 M/s
operations over time/8 workers, 10% reads with Sem:
0.33 M/s
operations over time/8 workers, 100% reads with Lock:
0.44 M/s
operations over time/8 workers, 100% reads with Rwlock:
5.23 M/s
operations over time/8 workers, 100% reads with Sem:
0.41 M/s
operations over time/8 workers, 50% reads with Lock:
0.36 M/s
operations over time/8 workers, 50% reads with Rwlock:
0.44 M/s
operations over time/8 workers, 50% reads with Sem:
0.35 M/s
operations over time/8 workers, 90% reads with Lock:
0.38 M/s
operations over time/8 workers, 90% reads with Rwlock:
0.95 M/s
operations over time/8 workers, 90% reads with Sem:
0.45 M/s
operations over time/8 workers, 95% reads with Lock:
0.37 M/s
operations over time/8 workers, 95% reads with Rwlock:
1.38 M/s
operations over time/8 workers, 95% reads with Sem:
0.41 M/s
time per operation/1 worker, 10% reads with Lock:
1536.99 ns
time per operation/1 worker, 10% reads with Rwlock:
1557.09 ns
time per operation/1 worker, 10% reads with Sem:
1642.91 ns
time per operation/1 worker, 100% reads with Lock:
1338.18 ns
time per operation/1 worker, 100% reads with Rwlock:
1341.41 ns
time per operation/1 worker, 100% reads with Sem:
1426.88 ns
time per operation/1 worker, 50% reads with Lock:
1435.73 ns
time per operation/1 worker, 50% reads with Rwlock:
1487.79 ns
time per operation/1 worker, 50% reads with Sem:
1536.18 ns
time per operation/1 worker, 90% reads with Lock:
1329.96 ns
time per operation/1 worker, 90% reads with Rwlock:
1385.38 ns
time per operation/1 worker, 90% reads with Sem:
1446.30 ns
time per operation/1 worker, 95% reads with Lock:
1327.49 ns
time per operation/1 worker, 95% reads with Rwlock:
1361.14 ns
time per operation/1 worker, 95% reads with Sem:
1441.48 ns
time per operation/2 workers, 10% reads with Lock:
3395.33 ns
time per operation/2 workers, 10% reads with Rwlock:
3153.61 ns
time per operation/2 workers, 10% reads with Sem:
3689.28 ns
time per operation/2 workers, 100% reads with Lock:
2452.27 ns
time per operation/2 workers, 100% reads with Rwlock:
1367.68 ns
time per operation/2 workers, 100% reads with Sem:
2855.99 ns
time per operation/2 workers, 50% reads with Lock:
3165.64 ns
time per operation/2 workers, 50% reads with Rwlock:
3336.06 ns
time per operation/2 workers, 50% reads with Sem:
3330.02 ns
time per operation/2 workers, 90% reads with Lock:
2639.50 ns
time per operation/2 workers, 90% reads with Rwlock:
1941.55 ns
time per operation/2 workers, 90% reads with Sem:
2945.17 ns
time per operation/2 workers, 95% reads with Lock:
2476.27 ns
time per operation/2 workers, 95% reads with Rwlock:
1837.55 ns
time per operation/2 workers, 95% reads with Sem:
2876.71 ns
time per operation/4 workers, 10% reads with Lock:
11141.00 ns
time per operation/4 workers, 10% reads with Rwlock:
11997.45 ns
time per operation/4 workers, 10% reads with Sem:
9367.91 ns
time per operation/4 workers, 100% reads with Lock:
8846.72 ns
time per operation/4 workers, 100% reads with Rwlock:
1359.36 ns
time per operation/4 workers, 100% reads with Sem:
7355.03 ns
time per operation/4 workers, 50% reads with Lock:
9840.62 ns
time per operation/4 workers, 50% reads with Rwlock:
9718.87 ns
time per operation/4 workers, 50% reads with Sem:
8703.56 ns
time per operation/4 workers, 90% reads with Lock:
8964.77 ns
time per operation/4 workers, 90% reads with Rwlock:
4621.89 ns
time per operation/4 workers, 90% reads with Sem:
7877.79 ns
time per operation/4 workers, 95% reads with Lock:
8943.78 ns
time per operation/4 workers, 95% reads with Rwlock:
3723.88 ns
time per operation/4 workers, 95% reads with Sem:
8527.74 ns
time per operation/8 workers, 10% reads with Lock:
26982.16 ns
time per operation/8 workers, 10% reads with Rwlock:
22442.19 ns
time per operation/8 workers, 10% reads with Sem:
24226.47 ns
time per operation/8 workers, 100% reads with Lock:
18125.84 ns
time per operation/8 workers, 100% reads with Rwlock:
1528.28 ns
time per operation/8 workers, 100% reads with Sem:
19294.71 ns
time per operation/8 workers, 50% reads with Lock:
22394.11 ns
time per operation/8 workers, 50% reads with Rwlock:
18273.01 ns
time per operation/8 workers, 50% reads with Sem:
22937.76 ns
time per operation/8 workers, 90% reads with Lock:
21111.83 ns
time per operation/8 workers, 90% reads with Rwlock:
8390.16 ns
time per operation/8 workers, 90% reads with Sem:
17950.85 ns
time per operation/8 workers, 95% reads with Lock:
21462.27 ns
time per operation/8 workers, 95% reads with Rwlock:
5778.47 ns
time per operation/8 workers, 95% reads with Sem:
19553.47 ns
(cd _build/default/test && ./test_mutex.exe)
random seed: 531050068
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex sequential (generating)
[✓] 32 0 0 32 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex parallel
[ ] 1 0 0 1 / 32 1.3s Mutex parallel
[ ] 2 0 0 2 / 32 2.5s Mutex parallel
[ ] 3 0 0 3 / 32 3.8s Mutex parallel
[ ] 4 0 0 4 / 32 5.2s Mutex parallel
[ ] 5 0 0 5 / 32 6.4s Mutex parallel
[ ] 6 0 0 6 / 32 7.4s Mutex parallel
[ ] 7 0 0 7 / 32 8.6s Mutex parallel
[ ] 8 0 0 8 / 32 10.8s Mutex parallel
[ ] 9 0 0 9 / 32 12.1s Mutex parallel
[ ] 10 0 0 10 / 32 17.6s Mutex parallel
[ ] 11 0 0 11 / 32 19.1s Mutex parallel
[ ] 12 0 0 12 / 32 20.0s Mutex parallel
[ ] 13 0 0 13 / 32 21.1s Mutex parallel
[ ] 14 0 0 14 / 32 26.1s Mutex parallel
[ ] 15 0 0 15 / 32 27.1s Mutex parallel
[ ] 16 0 0 16 / 32 28.0s Mutex parallel
[ ] 17 0 0 17 / 32 28.9s Mutex parallel
[ ] 18 0 0 18 / 32 29.9s Mutex parallel
[ ] 19 0 0 19 / 32 30.9s Mutex parallel
[ ] 20 0 0 20 / 32 32.5s Mutex parallel
[ ] 21 0 0 21 / 32 33.6s Mutex parallel
[ ] 22 0 0 22 / 32 41.9s Mutex parallel
[ ] 23 0 0 23 / 32 42.9s Mutex parallel
[ ] 24 0 0 24 / 32 43.7s Mutex parallel
[ ] 25 0 0 25 / 32 45.0s Mutex parallel
[ ] 26 0 0 26 / 32 45.9s Mutex parallel
[ ] 27 0 0 27 / 32 47.4s Mutex parallel
[ ] 28 0 0 28 / 32 48.3s Mutex parallel
[ ] 29 0 0 29 / 32 49.4s Mutex parallel
[ ] 30 0 0 30 / 32 50.6s Mutex parallel
[ ] 31 0 0 31 / 32 51.4s Mutex parallel
[ ] 32 0 0 32 / 32 52.4s Mutex parallel
[✓] 32 0 0 32 / 32 52.4s Mutex parallel
================================================================================
success (ran 2 tests)
random seed: 309777054
generated error fail pass / total time test name
[ ] 0 0 0 0 / 32 0.0s Mutex sequential
[✓] 32 0 0 32 / 32 0.0s Mutex sequential
[ ] 0 0 0 0 / 32 0.0s Mutex parallel
[ ] 1 0 0 1 / 32 1.0s Mutex parallel
[ ] 2 0 0 2 / 32 2.0s Mutex parallel
[ ] 3 0 0 3 / 32 2.7s Mutex parallel
[ ] 4 0 0 4 / 32 7.5s Mutex parallel
[ ] 5 0 0 5 / 32 8.9s Mutex parallel
[ ] 6 0 0 6 / 32 10.3s Mutex parallel
[ ] 7 0 0 7 / 32 10.9s Mutex parallel
[ ] 8 0 0 8 / 32 11.4s Mutex parallel
[ ] 9 0 0 9 / 32 12.1s Mutex parallel
[ ] 10 0 0 10 / 32 12.5s Mutex parallel
[ ] 11 0 0 11 / 32 13.0s Mutex parallel
[ ] 12 0 0 12 / 32 14.4s Mutex parallel
[ ] 13 0 0 13 / 32 15.2s Mutex parallel
[ ] 14 0 0 14 / 32 15.7s Mutex parallel
[ ] 15 0 0 15 / 32 20.3s Mutex parallel
[ ] 16 0 0 16 / 32 20.5s Mutex parallel
[ ] 17 0 0 17 / 32 22.0s Mutex parallel
[ ] 18 0 0 18 / 32 22.3s Mutex parallel
[ ] 19 0 0 19 / 32 22.9s Mutex parallel
[ ] 20 0 0 20 / 32 25.1s Mutex parallel
[ ] 21 0 0 21 / 32 25.4s Mutex parallel
[ ] 22 0 0 22 / 32 25.8s Mutex parallel
[ ] 23 0 0 23 / 32 27.6s Mutex parallel
[ ] 24 0 0 24 / 32 27.7s Mutex parallel
[ ] 25 0 0 25 / 32 27.9s Mutex parallel
[ ] 27 0 0 27 / 32 31.3s Mutex parallel
[ ] 29 0 0 29 / 32 31.5s Mutex parallel
[ ] 31 0 0 31 / 32 31.8s Mutex parallel
[✓] 32 0 0 32 / 32 31.8s Mutex parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_mpscq.exe)
random seed: 622659374
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 1.9s Mpscq parallel
[ ] 2 0 0 2 / 32 3.5s Mpscq parallel
[ ] 3 0 0 3 / 32 14.1s Mpscq parallel
[ ] 4 0 0 4 / 32 16.0s Mpscq parallel
[ ] 5 0 0 5 / 32 17.8s Mpscq parallel
[ ] 6 0 0 6 / 32 23.3s Mpscq parallel
[ ] 7 0 0 7 / 32 25.0s Mpscq parallel
[ ] 8 0 0 8 / 32 26.9s Mpscq parallel
[ ] 9 0 0 9 / 32 28.6s Mpscq parallel
[ ] 10 0 0 10 / 32 30.4s Mpscq parallel
[ ] 11 0 0 11 / 32 32.4s Mpscq parallel
[ ] 12 0 0 12 / 32 34.0s Mpscq parallel
[ ] 13 0 0 13 / 32 36.3s Mpscq parallel
[ ] 14 0 0 14 / 32 38.2s Mpscq parallel
[ ] 15 0 0 15 / 32 39.7s Mpscq parallel
[ ] 16 0 0 16 / 32 62.3s Mpscq parallel
[ ] 17 0 0 17 / 32 63.1s Mpscq parallel
[ ] 18 0 0 18 / 32 64.0s Mpscq parallel
[ ] 19 0 0 19 / 32 64.9s Mpscq parallel
[ ] 20 0 0 20 / 32 65.4s Mpscq parallel
[ ] 21 0 0 21 / 32 67.7s Mpscq parallel
[ ] 22 0 0 22 / 32 79.5s Mpscq parallel
[ ] 23 0 0 23 / 32 84.7s Mpscq parallel
[ ] 27 0 0 27 / 32 85.4s Mpscq parallel
[✓] 32 0 0 32 / 32 85.4s Mpscq parallel
================================================================================
success (ran 2 tests)
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 1)
Testing `Picos_sync'.
This run has ID `TPH9QVXH'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[OK] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 7.255s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 2)
Testing `Picos_sync'.
This run has ID `ZVT8U7SN'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[OK] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Sem$ 3)
Testing `Picos_sync'.
This run has ID `Z97KCBG4'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[OK] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Lazy$ 0)
Testing `Picos_sync'.
This run has ID `ODXLPB4G'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[OK] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Lazy$ 1)
Testing `Picos_sync'.
This run has ID `CR6U36HS'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[OK] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.006s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Event$ 0)
Testing `Picos_sync'.
This run has ID `QH7ZBBQK'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[OK] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.106s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Barrier$ 0)
Testing `Picos_sync'.
This run has ID `O04I107L'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[OK] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.007s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- ^Barrier$ 1)
Testing `Picos_sync'.
This run has ID `2A8CDHG2'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[OK] Barrier 1 poisoning.
[SKIP] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.008s. 1 test run.
(cd _build/default/test && ./test_sync.exe -- '^Non-cancelable ops$' 0)
Testing `Picos_sync'.
This run has ID `3WNQS69O'.
[SKIP] Mutex and Condition 0 basics.
[SKIP] Mutex and Condition 1 errors.
[SKIP] Mutex and Condition 2 cancelation.
[SKIP] Lock and Lock.Condition 0 basics.
[SKIP] Lock and Lock.Condition 1 cancelation.
[SKIP] Lock and Lock.Condition 2 poisoning.
[SKIP] Lock and Lock.Condition 3 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 0 basics.
[SKIP] Rwlock and Rwlock.Condition 1 cancelation.
[SKIP] Rwlock and Rwlock.Condition 2 poisoning.
[SKIP] Rwlock and Rwlock.Condition 3 freezing.
[SKIP] Rwlock and Rwlock.Condition 4 try_acquire.
[SKIP] Rwlock and Rwlock.Condition 5 try_acquire_shared.
[SKIP] Rwlock and Rwlock.Condition 6 sharing.
[SKIP] Semaphore 0 basics.
[SKIP] Semaphore 1 stress.
[SKIP] Sem 0 basics.
[SKIP] Sem 1 stress.
[SKIP] Sem 2 poisoning.
[SKIP] Sem 3 try_acquire.
[SKIP] Lazy 0 basics.
[SKIP] Lazy 1 cancelation.
[SKIP] Event 0 basics.
[SKIP] Barrier 0 basics.
[SKIP] Barrier 1 poisoning.
[OK] Non-cancelable ops 0 are not canceled.
Full test results in `/src/_build/default/test/_build/_tests/Picos_sync'.
Test Successful in 0.005s. 1 test run.
(cd _build/default/bench && ./main.exe -brief Picos_stdio)
Picos_stdio:
blocking reads over time/1 worker:
0.00 M/s
blocking reads over time/2 workers:
0.00 M/s
blocking reads over time/4 workers:
0.01 M/s
non-blocking reads over time/1 worker:
0.45 M/s
non-blocking reads over time/2 workers:
0.86 M/s
non-blocking reads over time/4 workers:
1.26 M/s
time per blocking read/1 worker:
1132445.34 ns
time per blocking read/2 workers:
2121817.72 ns
time per blocking read/4 workers:
500995.03 ns
time per non-blocking read/1 worker:
2245.21 ns
time per non-blocking read/2 workers:
2313.79 ns
time per non-blocking read/4 workers:
3181.23 ns
(cd _build/default/bench && ./main.exe -brief 'Picos_sync Stream')
Picos_sync Stream:
messages over time/1 nb pusher, 1 nb reader:
0.95 M/s
messages over time/2 nb pushers, 1 nb reader:
1.00 M/s
messages over time/4 nb pushers, 1 nb reader:
1.56 M/s
messages over time/one domain:
0.69 M/s
time per message/1 nb pusher, 1 nb reader:
2096.71 ns
time per message/2 nb pushers, 1 nb reader:
2996.80 ns
time per message/4 nb pushers, 1 nb reader:
3197.75 ns
time per message/one domain:
1449.39 ns
(cd _build/default/bench && ./main.exe -brief Fib)
Fib:
(cd _build/default/bench && ./main.exe -brief 'Picos binaries')
Picos binaries:
(cd _build/default/bench && ./main.exe -brief 'Bounded_q with Picos_std_sync')
Bounded_q with Picos_std_sync:
messages over time/1 adder, 1 taker with Lock:
0.46 M/s
messages over time/1 adder, 2 takers with Lock:
0.09 M/s
messages over time/1 adder, 4 takers with Lock:
0.04 M/s
messages over time/2 adders, 1 taker with Lock:
0.33 M/s
messages over time/2 adders, 2 takers with Lock:
0.21 M/s
messages over time/2 adders, 4 takers with Lock:
0.15 M/s
messages over time/4 adders, 1 taker with Lock:
0.35 M/s
messages over time/4 adders, 2 takers with Lock:
0.29 M/s
messages over time/4 adders, 4 takers with Lock:
0.19 M/s
messages over time/one domain with Lock:
0.47 M/s
time per message/1 adder, 1 taker with Lock:
4319.60 ns
time per message/1 adder, 2 takers with Lock:
34220.14 ns
time per message/1 adder, 4 takers with Lock:
126569.34 ns
time per message/2 adders, 1 taker with Lock:
9002.18 ns
time per message/2 adders, 2 takers with Lock:
18841.73 ns
time per message/2 adders, 4 takers with Lock:
39174.96 ns
time per message/4 adders, 1 taker with Lock:
14125.87 ns
time per message/4 adders, 2 takers with Lock:
20996.04 ns
time per message/4 adders, 4 takers with Lock:
41490.06 ns
time per message/one domain with Lock:
2140.41 ns
(cd _build/default/bench && ./main.exe -brief 'Memory usage')
Memory usage:
stack and heap used/Fun.protect:
100.00 B
stack and heap used/fiber in a bundle:
116.00 B
stack and heap used/fiber in a flock:
124.00 B
stack and heap used/fiber with shared computation & latch:
104.00 B
stack and heap used/finally:
80.00 B
stack and heap used/instantiate:
112.00 B
stack and heap used/join_after bundle:
192.00 B
stack and heap used/join_after flock:
192.00 B
stack and heap used/lastly:
76.00 B
stack and heap used/promise in a bundle:
176.00 B
stack and heap used/promise in a flock:
184.00 B
(cd _build/default/bench && ./main.exe -brief Stack)
Stack:
messages over time/1 nb adder, 1 nb taker:
1.02 M/s
messages over time/1 nb adder, 2 nb takers:
1.03 M/s
messages over time/1 nb adder, 4 nb takers:
0.72 M/s
messages over time/2 nb adders, 1 nb taker:
1.22 M/s
messages over time/2 nb adders, 2 nb takers:
1.08 M/s
messages over time/2 nb adders, 4 nb takers:
0.88 M/s
messages over time/4 nb adders, 1 nb taker:
1.15 M/s
messages over time/4 nb adders, 2 nb takers:
1.10 M/s
messages over time/4 nb adders, 4 nb takers:
0.95 M/s
messages over time/one domain:
1.10 M/s
time per message/1 nb adder, 1 nb taker:
1969.39 ns
time per message/1 nb adder, 2 nb takers:
2922.08 ns
time per message/1 nb adder, 4 nb takers:
6975.71 ns
time per message/2 nb adders, 1 nb taker:
2456.13 ns
time per message/2 nb adders, 2 nb takers:
3698.43 ns
time per message/2 nb adders, 4 nb takers:
6809.68 ns
time per message/4 nb adders, 1 nb taker:
4337.72 ns
time per message/4 nb adders, 2 nb takers:
5432.95 ns
time per message/4 nb adders, 4 nb takers:
8417.11 ns
time per message/one domain:
906.01 ns
2025-05-01 18:04.51 ---> saved as "451e24132b13c8c501ccc727b68836a68650643dcbae9daf31111bf092ce4a98"
Job succeeded
2025-05-01 18:04.51: Job succeeded