(not at the head of any monitored branch or PR)
2026-04-13 15:16.28: New job: test html_of_jsx.0.0.9, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/29716/head (94b6f2129677425e807f31dac2f6b81eb1cb6783)
                              on freebsd-14.3-ocaml-5.4/amd64

To reproduce locally:

cd $(mktemp -d)
git clone --recursive "https://github.com/ocaml/opam-repository.git" && cd "opam-repository" && git fetch origin "refs/pull/29716/head" && git reset --hard 94b6f212
git fetch origin master
git merge --no-edit ba4685aeec7b28fde6af30c7b83004704c68c86a
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM freebsd-14.3-ocaml-5.4
USER 1000:1000
WORKDIR /home/opam
RUN sudo ln -f /usr/local/bin/opam-dev /usr/local/bin/opam
RUN opam init --reinit -ni
RUN opam option solver=builtin-0install && opam config report
ENV OPAMDOWNLOADJOBS="1"
ENV OPAMERRLOGLEN="0"
ENV OPAMPRECISETRACKING="1"
ENV CI="true"
ENV OPAM_REPO_CI="true"
RUN rm -rf opam-repository/
COPY --chown=1000:1000 . opam-repository/
RUN opam repository set-url --strict default opam-repository/
RUN opam update --depexts || true
RUN opam pin add -k version -yn html_of_jsx.0.0.9 0.0.9
RUN opam reinstall html_of_jsx.0.0.9; \
    res=$?; \
    test "$res" != 31 && exit "$res"; \
    export OPAMCLI=2.0; \
    build_dir=$(opam var prefix)/.opam-switch/build; \
    failed=$(ls "$build_dir"); \
    partial_fails=""; \
    for pkg in $failed; do \
    if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"freebsd-14.3\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'html_of_jsx.0.0.9' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
RUN (opam reinstall --with-test html_of_jsx.0.0.9) || true
RUN opam reinstall --with-test --verbose html_of_jsx.0.0.9; \
    res=$?; \
    test "$res" != 31 && exit "$res"; \
    export OPAMCLI=2.0; \
    build_dir=$(opam var prefix)/.opam-switch/build; \
    failed=$(ls "$build_dir"); \
    partial_fails=""; \
    for pkg in $failed; do \
    if opam show -f x-ci-accept-failures: "$pkg" | grep -qF "\"freebsd-14.3\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'html_of_jsx.0.0.9' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1

END-OF-DOCKERFILE
docker build -f ../Dockerfile .

2026-04-13 15:16.28: Using cache hint "freebsd-14.3-ocaml-5.4-html_of_jsx.0.0.9-94b6f2129677425e807f31dac2f6b81eb1cb6783"
2026-04-13 15:16.28: Using OBuilder spec:
((from freebsd-14.3-ocaml-5.4)
 (user (uid 1000) (gid 1000))
 (workdir /home/opam)
 (run (shell "sudo ln -f /usr/local/bin/opam-dev /usr/local/bin/opam"))
 (run (network host)
      (shell "opam init --reinit -ni"))
 (run (shell "opam option solver=builtin-0install && opam config report"))
 (env OPAMDOWNLOADJOBS 1)
 (env OPAMERRLOGLEN 0)
 (env OPAMPRECISETRACKING 1)
 (env CI true)
 (env OPAM_REPO_CI true)
 (run (shell "rm -rf opam-repository/"))
 (copy (src .) (dst opam-repository/))
 (run (shell "opam repository set-url --strict default opam-repository/"))
 (run (network host)
      (shell "opam update --depexts || true"))
 (run (shell "opam pin add -k version -yn html_of_jsx.0.0.9 0.0.9"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall html_of_jsx.0.0.9;\
             \n        res=$?;\
             \n        test \"$res\" != 31 && exit \"$res\";\
             \n        export OPAMCLI=2.0;\
             \n        build_dir=$(opam var prefix)/.opam-switch/build;\
             \n        failed=$(ls \"$build_dir\");\
             \n        partial_fails=\"\";\
             \n        for pkg in $failed; do\
             \n          if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"freebsd-14.3\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'html_of_jsx.0.0.9' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
 (run (network host)
      (shell "(opam reinstall --with-test html_of_jsx.0.0.9) || true"))
 (run (shell  "opam reinstall --with-test --verbose html_of_jsx.0.0.9;\
             \n        res=$?;\
             \n        test \"$res\" != 31 && exit \"$res\";\
             \n        export OPAMCLI=2.0;\
             \n        build_dir=$(opam var prefix)/.opam-switch/build;\
             \n        failed=$(ls \"$build_dir\");\
             \n        partial_fails=\"\";\
             \n        for pkg in $failed; do\
             \n          if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"freebsd-14.3\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'html_of_jsx.0.0.9' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
)

2026-04-13 15:16.28: Waiting for resource in pool OCluster
2026-04-13 15:16.28: Waiting for worker…
2026-04-13 15:17.05: Got resource from pool OCluster
Building on rosemary
All commits already cached
Updating files: 100% (18704/18704), done.
HEAD is now at ba4685aeec Merge pull request #29653 from yakobowski/camlidl
Updating ba4685aeec..94b6f21296
Fast-forward
 packages/html_of_jsx/html_of_jsx.0.0.9/opam | 54 +++++++++++++++++++++++++++++
 1 file changed, 54 insertions(+)
 create mode 100644 packages/html_of_jsx/html_of_jsx.0.0.9/opam

(from freebsd-14.3-ocaml-5.4)
2026-04-13 15:13.31 ---> using "463e9b939b79b2568bf98b05cff00f85b3ec5717170cf88773a44ae3b08f11e7" from cache

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

/: (workdir /home/opam)

/home/opam: (run (shell "sudo ln -f /usr/local/bin/opam-dev /usr/local/bin/opam"))
2026-04-13 15:13.31 ---> using "0f4f38cca0f09ffdac905c0015fdbe56f9214c89e28a28ae3325cd6eed47fd99" from cache

/home/opam: (run (network host)
                 (shell "opam init --reinit -ni"))
No configuration file found, using built-in defaults.
Checking for available remotes: rsync and local, git.
  - you won't be able to use mercurial repositories unless you install the hg command on your system.
  - you won't be able to use darcs repositories unless you install the darcs command on your system.

This version of opam requires an update to the layout of /home/opam/.opam from version 2.1 to version 2.2, which can't be reverted.
You may want to back it up before going further.

Continue? [Y/n] y
[NOTE] The 'jobs' option was reset, its value was 1 and its new value will vary according to the current number of cores on your machine. You can restore the fixed value using:
           opam option jobs=1 --global
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] no changes from git+file:///home/opam/opam-repository
2026-04-13 15:13.31 ---> using "430d75e95f6be08ef0776e6e6bb864bc698709d5f7d071fd7fbbf37d0a8617d5" from cache

/home/opam: (run (shell "opam option solver=builtin-0install && opam config report"))
Set to 'builtin-0install' the field solver in global configuration
# opam config report
# opam-version         2.5.0
# self-upgrade         no
# system               arch=x86_64 os=freebsd os-distribution=freebsd os-version=1403000
# solver               builtin-0install
# install-criteria     -changed,-count[avoid-version,solution]
# upgrade-criteria     -count[avoid-version,solution]
# jobs                 39
# repositories         1 (version-controlled)
# pinned               0
# current-switch       5.4.1
# invariant            ["ocaml-base-compiler" {= "5.4.1"} | "ocaml-system" {= "5.4.1"}]
# compiler-packages    ocaml-base-compiler.5.4.1, ocaml-compiler.5.4.1, ocaml-options-vanilla.1
# ocaml:native         true
# ocaml:native-tools   true
# ocaml:native-dynlink true
# ocaml:stubsdir       /home/opam/.opam/5.4.1/lib/ocaml/stublibs:/home/opam/.opam/5.4.1/lib/ocaml
# ocaml:preinstalled   false
# ocaml:compiler       5.4.1
2026-04-13 15:13.31 ---> using "8a5a57fecc1d42886ddc4a5b75b36583eef8196838ccdc1bf870bc7798f6f185" from cache

/home/opam: (env OPAMDOWNLOADJOBS 1)

/home/opam: (env OPAMERRLOGLEN 0)

/home/opam: (env OPAMPRECISETRACKING 1)

/home/opam: (env CI true)

/home/opam: (env OPAM_REPO_CI true)

/home/opam: (run (shell "rm -rf opam-repository/"))
2026-04-13 15:13.32 ---> using "5d57b5e6a2b42d2aa72fb2cc8558fd5735263edde7f2032c7588b729f1b1565f" from cache

/home/opam: (copy (src .) (dst opam-repository/))
2026-04-13 15:13.33 ---> using "b9590315ee8fa7e6d2f49c76a96b4307e77fad30521d163586147be4987d9a14" from cache

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-04-13 15:13.43 ---> saved as "852a1d0ef242b2ea3f2419c10c98fac80449d2c89a7a9cb34248e7b6bb7c8d9f"

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
[WARNING] Unknown update command for bsd, skipping system update
2026-04-13 15:13.44 ---> saved as "8ea10c7eeb4de72799ec79e53199ba51b576081522c87fde572f4c8623c77da1"

/home/opam: (run (shell "opam pin add -k version -yn html_of_jsx.0.0.9 0.0.9"))
html_of_jsx is now pinned to version 0.0.9
2026-04-13 15:13.44 ---> saved as "8b77fb67fc98efb4b9bc826b2bdb9b248f497d907272e4336bbace728f1f7aaf"

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall html_of_jsx.0.0.9;\
                        \n        res=$?;\
                        \n        test \"$res\" != 31 && exit \"$res\";\
                        \n        export OPAMCLI=2.0;\
                        \n        build_dir=$(opam var prefix)/.opam-switch/build;\
                        \n        failed=$(ls \"$build_dir\");\
                        \n        partial_fails=\"\";\
                        \n        for pkg in $failed; do\
                        \n          if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"freebsd-14.3\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'html_of_jsx.0.0.9' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
html_of_jsx.0.0.9 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 8 packages
  ∗ dune                3.22.1         [required by html_of_jsx]
  ∗ html_of_jsx         0.0.9 (pinned)
  ∗ ocaml-compiler-libs v0.17.0        [required by ppxlib]
  ∗ ppx_derivers        1.2.1          [required by ppxlib]
  ∗ ppxlib              0.38.0         [required by html_of_jsx]
  ∗ pretty_expressive   0.5            [required by html_of_jsx]
  ∗ sexplib0            v0.17.0        [required by ppxlib]
  ∗ stdlib-shims        0.3.0          [required by ppxlib]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
⬇ retrieved dune.3.22.1  (cached)
⬇ retrieved html_of_jsx.0.0.9  (https://github.com/davesnx/html_of_jsx/releases/download/0.0.9/html_of_jsx-0.0.9.tbz)
⬇ retrieved ocaml-compiler-libs.v0.17.0  (cached)
⬇ retrieved ppx_derivers.1.2.1  (cached)
⬇ retrieved ppxlib.0.38.0  (cached)
⬇ retrieved pretty_expressive.0.5  (https://github.com/sorawee/pretty-expressive-ocaml/releases/download/0.5/pretty_expressive-0.5.tbz)
⬇ retrieved sexplib0.v0.17.0  (cached)
⬇ retrieved stdlib-shims.0.3.0  (cached)
∗ installed dune.3.22.1
∗ installed ppx_derivers.1.2.1
∗ installed stdlib-shims.0.3.0
∗ installed pretty_expressive.0.5
∗ installed sexplib0.v0.17.0
∗ installed ocaml-compiler-libs.v0.17.0
∗ installed ppxlib.0.38.0
∗ installed html_of_jsx.0.0.9
Done.
2026-04-13 15:14.39 ---> saved as "9764ad901c2b208cfff49845de7ee52000826673aaeb80dbe61a3eaa514fc5cb"

/home/opam: (run (network host)
                 (shell "(opam reinstall --with-test html_of_jsx.0.0.9) || true"))
The following actions will be performed:
=== recompile 1 package
  ↻ html_of_jsx             0.0.9 (pinned)
=== install 38 packages
  ∗ alcotest                1.9.1          [required by html_of_jsx]
  ∗ astring                 0.8.5          [required by alcotest]
  ∗ base                    v0.17.3        [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ benchmark               1.7            [required by html_of_jsx]
  ∗ camlp-streams           5.0.1          [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ cmdliner                2.1.0          [required by ocamlformat-mlx, alcotest, ocamlformat, reason]
  ∗ cppo                    1.8.0          [required by reason]
  ∗ csexp                   1.5.2          [required by ocamlformat, ocamlformat-mlx]
  ∗ dune-build-info         3.22.1         [required by reason]
  ∗ dune-configurator       3.22.1         [required by base]
  ∗ either                  1.0.0          [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ fix                     20250919       [required by reason]
  ∗ fmt                     0.11.0         [required by alcotest]
  ∗ fpath                   0.7.3          [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ menhir                  20260209       [required by reason]
  ∗ menhirCST               20260209       [required by menhir]
  ∗ menhirGLR               20260209       [required by menhir]
  ∗ menhirLib               20260209       [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ menhirSdk               20260209       [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ merlin-extend           0.6.2          [required by reason]
  ∗ mlx                     0.11           [required by html_of_jsx]
  ∗ ocaml-syntax-shims      1.0.0          [required by alcotest]
  ∗ ocaml-version           4.0.4          [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ ocaml_intrinsics_kernel v0.17.1        [required by base]
  ∗ ocamlbuild              0.16.1         [required by fmt, astring, uutf]
  ∗ ocamlfind               1.9.8          [required by reason]
  ∗ ocamlformat             0.29.0         [required by html_of_jsx]
  ∗ ocamlformat-lib         0.29.0         [required by ocamlformat]
  ∗ ocamlformat-mlx         0.28.1.2       [required by html_of_jsx]
  ∗ ocamlformat-mlx-lib     0.28.1.2       [required by ocamlformat-mlx]
  ∗ ocp-indent              1.9.0          [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ re                      1.14.0         [required by ocamlformat, alcotest, ocamlformat-mlx]
  ∗ reason                  3.17.3         [required by html_of_jsx]
  ∗ stdio                   v0.17.0        [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ topkg                   1.1.1          [required by fmt, astring, uutf]
  ∗ uucp                    17.0.0         [required by uuseg]
  ∗ uuseg                   17.0.0         [required by ocamlformat-lib, ocamlformat-mlx-lib]
  ∗ uutf                    1.0.4          [required by alcotest]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
⬇ retrieved alcotest.1.9.1  (https://github.com/mirage/alcotest/releases/download/1.9.1/alcotest-1.9.1.tbz)
⬇ retrieved astring.0.8.5  (https://erratique.ch/software/astring/releases/astring-0.8.5.tbz)
⬇ retrieved base.v0.17.3  (https://github.com/janestreet/base/archive/refs/tags/v0.17.3.tar.gz)
⬇ retrieved benchmark.1.7  (https://github.com/Chris00/ocaml-benchmark/releases/download/v1.7/benchmark-1.7.tbz)
∗ installed benchmark.1.7
⬇ retrieved camlp-streams.5.0.1  (https://github.com/ocaml/camlp-streams/archive/v5.0.1.tar.gz)
∗ installed camlp-streams.5.0.1
⬇ retrieved cmdliner.2.1.0  (https://erratique.ch/software/cmdliner/releases/cmdliner-2.1.0.tbz)
⬇ retrieved cppo.1.8.0  (https://github.com/ocaml-community/cppo/archive/v1.8.0.tar.gz)
⬇ retrieved csexp.1.5.2  (https://github.com/ocaml-dune/csexp/releases/download/1.5.2/csexp-1.5.2.tbz)
∗ installed csexp.1.5.2
∗ installed cppo.1.8.0
∗ installed cmdliner.2.1.0
⬇ retrieved dune-build-info.3.22.1, dune-configurator.3.22.1  (https://github.com/ocaml/dune/releases/download/3.22.1/dune-3.22.1.tbz)
∗ installed dune-build-info.3.22.1
⬇ retrieved either.1.0.0  (https://github.com/mirage/either/releases/download/1.0.0/either-1.0.0.tbz)
∗ installed either.1.0.0
∗ installed dune-configurator.3.22.1
⬇ retrieved fix.20250919  (https://gitlab.inria.fr/fpottier/fix/-/archive/20250919/archive.tar.gz)
∗ installed fix.20250919
⬇ retrieved fmt.0.11.0  (https://erratique.ch/software/fmt/releases/fmt-0.11.0.tbz)
⬇ retrieved fpath.0.7.3  (https://erratique.ch/software/fpath/releases/fpath-0.7.3.tbz)
⬇ retrieved menhir.20260209, menhirCST.20260209, menhirGLR.20260209, menhirLib.20260209, menhirSdk.20260209  (https://gitlab.inria.fr/fpottier/menhir/-/archive/20260209/archive.tar.gz)
∗ installed menhirCST.20260209
∗ installed menhirGLR.20260209
∗ installed menhirLib.20260209
⬇ retrieved merlin-extend.0.6.2  (https://github.com/let-def/merlin-extend/releases/download/v0.6.2/merlin-extend-0.6.2.tbz)
∗ installed menhirSdk.20260209
∗ installed merlin-extend.0.6.2
⬇ retrieved mlx.0.11  (https://github.com/ocaml-mlx/mlx/releases/download/0.11/mlx-0.11.tbz)
⬇ retrieved ocaml-syntax-shims.1.0.0  (https://github.com/ocaml-ppx/ocaml-syntax-shims/releases/download/1.0.0/ocaml-syntax-shims-1.0.0.tbz)
∗ installed ocaml-syntax-shims.1.0.0
∗ installed mlx.0.11
∗ installed menhir.20260209
⬇ retrieved ocaml-version.4.0.4  (https://github.com/ocurrent/ocaml-version/releases/download/v4.0.4/ocaml-version-4.0.4.tbz)
∗ installed ocaml-version.4.0.4
⬇ retrieved ocaml_intrinsics_kernel.v0.17.1  (https://github.com/janestreet/ocaml_intrinsics_kernel/archive/refs/tags/v0.17.1.tar.gz)
∗ installed ocaml_intrinsics_kernel.v0.17.1
⬇ retrieved ocamlbuild.0.16.1  (https://github.com/ocaml/ocamlbuild/archive/refs/tags/0.16.1.tar.gz)
⬇ retrieved ocamlfind.1.9.8  (https://github.com/ocaml/ocamlfind/archive/refs/tags/findlib-1.9.8.tar.gz)
∗ installed ocamlfind.1.9.8
∗ installed base.v0.17.3
∗ installed ocamlbuild.0.16.1
⬇ retrieved ocamlformat.0.29.0, ocamlformat-lib.0.29.0  (https://github.com/ocaml-ppx/ocamlformat/releases/download/0.29.0/ocamlformat-0.29.0.tbz)
⬇ retrieved ocamlformat-mlx.0.28.1.2, ocamlformat-mlx-lib.0.28.1.2  (https://github.com/ocaml-mlx/ocamlformat-mlx/releases/download/0.28.1.2/ocamlformat-mlx-0.28.1.2.tbz)
⬇ retrieved ocp-indent.1.9.0  (https://github.com/OCamlPro/ocp-indent/releases/download/1.9.0/ocp-indent-1.9.0.tbz)
⬇ retrieved re.1.14.0  (https://github.com/ocaml/ocaml-re/archive/refs/tags/1.14.0.tar.gz)
∗ installed ocp-indent.1.9.0
⊘ removed   html_of_jsx.0.0.9
∗ installed re.1.14.0
⬇ retrieved reason.3.17.3  (https://github.com/reasonml/reason/releases/download/3.17.3/reason-3.17.3.tbz)
⬇ retrieved stdio.v0.17.0  (https://github.com/janestreet/stdio/archive/refs/tags/v0.17.0.tar.gz)
∗ installed stdio.v0.17.0
⬇ retrieved topkg.1.1.1  (https://erratique.ch/software/topkg/releases/topkg-1.1.1.tbz)
∗ installed topkg.1.1.1
∗ installed fmt.0.11.0
∗ installed astring.0.8.5
∗ installed fpath.0.7.3
⬇ retrieved uucp.17.0.0  (https://erratique.ch/software/uucp/releases/uucp-17.0.0.tbz)
⬇ retrieved uuseg.17.0.0  (https://erratique.ch/software/uuseg/releases/uuseg-17.0.0.tbz)
⬇ retrieved uutf.1.0.4  (https://erratique.ch/software/uutf/releases/uutf-1.0.4.tbz)
∗ installed reason.3.17.3
∗ installed uutf.1.0.4
∗ installed alcotest.1.9.1
∗ installed uucp.17.0.0
∗ installed uuseg.17.0.0
∗ installed ocamlformat-lib.0.29.0
∗ installed ocamlformat-mlx-lib.0.28.1.2
∗ installed ocamlformat.0.29.0
∗ installed ocamlformat-mlx.0.28.1.2
∗ installed html_of_jsx.0.0.9
Done.

<><> ocp-indent.1.9.0 installed successfully ><><><><><><><><><><><><><><><><><>
=> This package requires additional configuration for use in editors. Install package 'user-setup', or manually:

   * for Emacs, add these lines to ~/.emacs:
     (add-to-list 'load-path "/home/opam/.opam/5.4.1/share/emacs/site-lisp")
     (require 'ocp-indent)

   * for Vim, add this line to ~/.vimrc:
     set rtp^="/home/opam/.opam/5.4.1/share/ocp-indent/vim"
2026-04-13 15:18.00 ---> saved as "2902ab281a18c41a188b13cd003b7a7397b8b3992e2a4a94842bdfa35a931100"

/home/opam: (run (shell  "opam reinstall --with-test --verbose html_of_jsx.0.0.9;\
                        \n        res=$?;\
                        \n        test \"$res\" != 31 && exit \"$res\";\
                        \n        export OPAMCLI=2.0;\
                        \n        build_dir=$(opam var prefix)/.opam-switch/build;\
                        \n        failed=$(ls \"$build_dir\");\
                        \n        partial_fails=\"\";\
                        \n        for pkg in $failed; do\
                        \n          if opam show -f x-ci-accept-failures: \"$pkg\" | grep -qF \"\\\"freebsd-14.3\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'html_of_jsx.0.0.9' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
The following actions will be performed:
=== recompile 1 package
  ↻ html_of_jsx 0.0.9 (pinned)

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing  2/4: [html_of_jsx: dune build]
+ /home/opam/.opam/5.4.1/bin/dune "build" "-p" "html_of_jsx" "-j" "39" "@install" "@runtest" (CWD=/home/opam/.opam/5.4.1/.opam-switch/build/html_of_jsx.0.0.9)
- (cd _build/default/test && ./main.exe)
- Testing `html_of_jsx'.
- This run has ID `B4O86KLE'.
- 
-   [OK]          render                   0   single_empty_tag.
-   [OK]          render                   1   empty_string_attribute.
-   [OK]          render                   2   string_attributes.
-   [OK]          render                   3   bool_attributes.
-   [OK]          render                   4   truthy_attributes.
-   [OK]          render                   5   self_closing_tag.
-   [OK]          render                   6   dom_element_innerHtml.
-   [OK]          render                   7   children.
-   [OK]          render                   8   no_ignore_unkwnown_attributes_on...
-   [OK]          render                   9   ignore_nulls.
-   [OK]          render                  10   inline_styles.
-   [OK]          render                  11   list.
-   [OK]          render                  12   list_and_texts.
-   [OK]          render                  13   encode_attributes.
-   [OK]          render                  14   event.
-   [OK]          render                  15   className.
-   [OK]          render                  16   className_2.
-   [OK]          render                  17   render_svg.
-   [OK]          render                  18   render_svg.
-   [OK]          render                  19   jsx_unsafe.
-   [OK]          render                  20   stringf_text.
-   [OK]          Reason with JSX          0   tag.
-   [OK]          Reason with JSX          1   empty_attribute.
-   [OK]          Reason with JSX          2   bool_attribute.
-   [OK]          Reason with JSX          3   bool_attributes.
-   [OK]          Reason with JSX          4   innerhtml.
-   [OK]          Reason with JSX          5   int_attribute.
-   [OK]          Reason with JSX          6   svg.
-   [OK]          Reason with JSX          7   style_attribute.
-   [OK]          Reason with JSX          8   link_as_attribute.
-   [OK]          Reason with JSX          9   int_opt_attribute_some.
-   [OK]          Reason with JSX         10   int_opt_attribute_none.
-   [OK]          Reason with JSX         11   string_opt_attribute_some.
-   [OK]          Reason with JSX         12   string_opt_attribute_none.
-   [OK]          Reason with JSX         13   bool_opt_attribute_some.
-   [OK]          Reason with JSX         14   bool_opt_attribute_none.
-   [OK]          Reason with JSX         15   style_opt_attribute_some.
-   [OK]          Reason with JSX         16   style_opt_attribute_none.
-   [OK]          Reason with JSX         17   lists_as_children.
-   [OK]          Reason with JSX         18   children_uppercase.
-   [OK]          Reason with JSX         19   children_lowercase.
-   [OK]          Reason with JSX         20   onclick_inline_string.
-   [OK]          Reason with JSX         21   children_one_element.
-   [OK]          Reason with JSX         22   children_multiple_elements.
-   [OK]          Reason with JSX         23   create_element_variadic.
-   [OK]          Reason with JSX         24   aria_props.
-   [OK]          Reason with JSX         25   lowercase_component.
-   [OK]          Htmx                     0   simple_hx_boost.
-   [OK]          Htmx                     1   sse_connect.
-   [OK]          Htmx                     2   sse_swap.
-   [OK]          Htmx                     3   sse_close.
-   [OK]          Htmx                     4   sse_complete.
-   [OK]          Htmx                     5   ws_connect.
-   [OK]          Htmx                     6   ws_send.
-   [OK]          Htmx                     7   ws_complete.
-   [OK]          Htmx                     8   classes.
-   [OK]          Htmx                     9   preload.
-   [OK]          Htmx                    10   path_deps.
-   [OK]          Htmx                    11   loading_states_basic.
-   [OK]          Htmx                    12   loading_states_class.
-   [OK]          Htmx                    13   loading_states_disable.
-   [OK]          Htmx                    14   loading_states_delay.
-   [OK]          Htmx                    15   loading_states_target.
-   [OK]          Htmx                    16   hx_swap_polyvariant.
-   [OK]          Htmx                    17   hx_swap_polyvariant_dynamic.
-   [OK]          Htmx                    18   hx_swap_polyvariant_opt_some.
-   [OK]          Htmx                    19   hx_swap_polyvariant_opt_none.
-   [OK]          Test with mlx            0   tag.
-   [OK]          Test with mlx            1   empty_attribute.
-   [OK]          Test with mlx            2   bool_attribute.
-   [OK]          Test with mlx            3   bool_attributes.
-   [OK]          Test with mlx            4   innerhtml.
-   [OK]          Test with mlx            5   int_attribute.
-   [OK]          Test with mlx            6   svg.
-   [OK]          Test with mlx            7   style_attribute.
-   [OK]          Test with mlx            8   link_as_attribute.
-   [OK]          Test with mlx            9   int_opt_attribute_some.
-   [OK]          Test with mlx           10   int_opt_attribute_none.
-   [OK]          Test with mlx           11   string_opt_attribute_some.
-   [OK]          Test with mlx           12   string_opt_attribute_none.
-   [OK]          Test with mlx           13   bool_opt_attribute_some.
-   [OK]          Test with mlx           14   bool_opt_attribute_none.
-   [OK]          Test with mlx           15   style_opt_attribute_some.
-   [OK]          Test with mlx           16   style_opt_attribute_none.
-   [OK]          Test with mlx           17   children_uppercase.
-   [OK]          Test with mlx           18   children_lowercase.
-   [OK]          Test with mlx           19   onclick_inline_string.
-   [OK]          Test with mlx           20   children_one_element.
-   [OK]          Test with mlx           21   create_element_variadic.
-   [OK]          Test with mlx           22   aria_props.
-   [OK]          Test with mlx           23   lowercase_component.
-   [OK]          Test with mlx           24   target_polyvariant.
-   [OK]          Test with mlx           25   target_polyvariant_dynamic.
-   [OK]          Test with mlx           26   target_polyvariant_opt_some.
-   [OK]          Test with mlx           27   target_polyvariant_opt_none.
-   [OK]          Test with mlx           28   data_attributes.
-   [OK]          pp                       0   null_element.
-   [OK]          pp                       1   string_element.
-   [OK]          pp                       2   int_element.
-   [OK]          pp                       3   float_element.
-   [OK]          pp                       4   unsafe_element.
-   [OK]          pp                       5   self_closing_no_attrs.
-   [OK]          pp                       6   self_closing_with_attrs.
-   [OK]          pp                       7   empty_tag.
-   [OK]          pp                       8   empty_tag_with_attrs.
-   [OK]          pp                       9   tag_with_text.
-   [OK]          pp                      10   tag_with_int_child.
-   [OK]          pp                      11   tag_with_float_child.
-   [OK]          pp                      12   bool_true_attr.
-   [OK]          pp                      13   bool_false_attr.
-   [OK]          pp                      14   int_attr.
-   [OK]          pp                      15   float_attr.
-   [OK]          pp                      16   mixed_attr_types.
-   [OK]          pp                      17   multiple_text_children.
-   [OK]          pp                      18   mixed_inline_children.
-   [OK]          pp                      19   single_node_child.
-   [OK]          pp                      20   multiple_node_children.
-   [OK]          pp                      21   mixed_text_and_nodes.
-   [OK]          pp                      22   fragment_children.
-   [OK]          pp                      23   array_children.
-   [OK]          pp                      24   null_children_filtered.
-   [OK]          pp                      25   empty_list_child.
-   [OK]          pp                      26   nested_fragments.
-   [OK]          pp                      27   two_levels_break.
-   [OK]          pp                      28   three_levels_break.
-   [OK]          pp                      29   four_levels_deep.
-   [OK]          pp                      30   siblings_at_same_depth.
-   [OK]          pp                      31   single_child_chain_fits.
-   [OK]          pp                      32   single_child_chain_breaks.
-   [OK]          pp                      33   doctype_html.
-   [OK]          pp                      34   full_page.
-   [OK]          pp                      35   self_closing_tags_in_context.
-   [OK]          pp                      36   wide_width_single_line.
-   [OK]          pp                      37   narrow_width_forces_break.
-   [OK]          pp                      38   very_narrow_deep_break.
-   [OK]          pp                      39   width_boundary_fits.
-   [OK]          pp                      40   width_boundary_breaks.
-   [OK]          pp                      41   default_width_is_80.
-   [OK]          pp                      42   long_text_stays_inline.
-   [OK]          pp                      43   long_attribute_value.
-   [OK]          pp                      44   many_attributes.
-   [OK]          pp                      45   many_children.
-   [OK]          pp                      46   long_tag_with_many_attrs_and_chi...
-   [OK]          pp                      47   wide_table_row.
-   [OK]          pp                      48   escaping_text_content.
-   [OK]          pp                      49   escaping_attribute_values.
-   [OK]          pp                      50   escaping_ampersand_sequences.
-   [OK]          pp                      51   unsafe_with_newlines.
-   [OK]          pp                      52   unsafe_multiline_style.
-   [OK]          pp                      53   deeply_nested_single_child.
-   [OK]          pp                      54   deeply_nested_single_child_breaks.
-   [OK]          pp                      55   only_null_children.
-   [OK]          pp                      56   pp_matches_render_semantics.
-   [OK]          pp                      57   fragment_at_top_level.
-   [OK]          pp                      58   empty_fragment.
-   [OK]          pp                      59   empty_array.
-   [OK]          pp                      60   node_with_unsafe_child.
-   [OK]          pp                      61   complex_real_world.
-   [OK]          pp                      62   svg_rendering.
- 
- Full test results in `~/.opam/5.4.1/.opam-switch/build/html_of_jsx.0.0.9/_build/default/test/_build/_tests/html_of_jsx'.
- Test Successful in 0.015s. 159 tests run.
λ compiled  html_of_jsx.0.0.9
⊘ removed   html_of_jsx.0.0.9
∗ installed html_of_jsx.0.0.9
Done.
2026-04-13 15:18.07 ---> saved as "c0ac15ba189022e74c880bdda3f4fa863701871c1681176ef161b8b17e6f2e6b"
Job succeeded
2026-04-13 15:22.07: Job succeeded