(for PR #27179)

2025-02-26 14:59.54: New job: build junit_ounit.2.2.0, lower-bounds, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/27179/head (a3b5164831db81464b015f5a4c2eadaac5712852)
                              on debian-12-ocaml-4.04/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/27179/head" && git reset --hard a3b51648
git fetch origin master
git merge --no-edit 1d1ea2841b231665859c831a77400c2a4deca6f4
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-12-ocaml-4.04@sha256:2ffc059abfc29f1e6a2fd500936fc075f224e6b2080739bddb3aa33191f18d57
USER 1000:1000
WORKDIR /home/opam
RUN sudo ln -f /usr/bin/opam-dev /usr/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 junit_ounit.2.2.0 2.2.0
RUN opam reinstall junit_ounit.2.2.0; \
    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 "\"debian-12\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'junit_ounit.2.2.0' && partial_fails="$partial_fails $pkg"; \
    done; \
    test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
    exit 1
ENV OPAMCRITERIA="+removed,+count[version-lag,solution]"
ENV OPAMFIXUPCRITERIA="+removed,+count[version-lag,solution]"
ENV OPAMUPGRADECRITERIA="+removed,+count[version-lag,solution]"
RUN opam reinstall junit_ounit.2.2.0; \
    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 "\"debian-12\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'junit_ounit.2.2.0' && 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 .

2025-02-26 14:59.54: Using cache hint "ocaml/opam:debian-12-ocaml-4.04@sha256:2ffc059abfc29f1e6a2fd500936fc075f224e6b2080739bddb3aa33191f18d57-junit_ounit.2.2.0-a3b5164831db81464b015f5a4c2eadaac5712852"
2025-02-26 14:59.54: Using OBuilder spec:
((from ocaml/opam:debian-12-ocaml-4.04@sha256:2ffc059abfc29f1e6a2fd500936fc075f224e6b2080739bddb3aa33191f18d57)
 (user (uid 1000) (gid 1000))
 (workdir /home/opam)
 (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
 (run (network host)
      (shell "opam init --reinit --config .opamrc-sandbox -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 junit_ounit.2.2.0 2.2.0"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall junit_ounit.2.2.0;\
             \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 \"\\\"debian-12\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'junit_ounit.2.2.0' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
 (env OPAMCRITERIA +removed,+count[version-lag,solution])
 (env OPAMFIXUPCRITERIA +removed,+count[version-lag,solution])
 (env OPAMUPGRADECRITERIA +removed,+count[version-lag,solution])
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall junit_ounit.2.2.0;\
             \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 \"\\\"debian-12\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'junit_ounit.2.2.0' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
)

2025-02-26 14:59.54: Waiting for resource in pool OCluster
2025-02-26 14:59.59: Waiting for worker…
2025-02-26 15:01.10: Got resource from pool OCluster
Building on doris.caelum.ci.dev
All commits already cached
Updating files:  84% (19080/22477)
Updating files:  85% (19106/22477)
Updating files:  86% (19331/22477)
Updating files:  87% (19555/22477)
Updating files:  88% (19780/22477)
Updating files:  89% (20005/22477)
Updating files:  90% (20230/22477)
Updating files:  91% (20455/22477)
Updating files:  92% (20679/22477)
Updating files:  93% (20904/22477)
Updating files:  94% (21129/22477)
Updating files:  95% (21354/22477)
Updating files:  96% (21578/22477)
Updating files:  97% (21803/22477)
Updating files:  98% (22028/22477)
Updating files:  99% (22253/22477)
Updating files: 100% (22477/22477)
Updating files: 100% (22477/22477), done.
HEAD is now at 1d1ea2841b Merge pull request #27381 from zapashcanon/conf
Merge made by the 'ort' strategy.
 packages/junit/junit.2.2.0/opam                   | 42 +++++++++++++++++++++++
 packages/junit_alcotest/junit_alcotest.2.2.0/opam | 42 +++++++++++++++++++++++
 packages/junit_ounit/junit_ounit.2.2.0/opam       | 41 ++++++++++++++++++++++
 3 files changed, 125 insertions(+)
 create mode 100644 packages/junit/junit.2.2.0/opam
 create mode 100644 packages/junit_alcotest/junit_alcotest.2.2.0/opam
 create mode 100644 packages/junit_ounit/junit_ounit.2.2.0/opam

(from ocaml/opam:debian-12-ocaml-4.04@sha256:2ffc059abfc29f1e6a2fd500936fc075f224e6b2080739bddb3aa33191f18d57)
2025-02-26 15:01.57 ---> saved as "f8b24027592b869453e99b2e95a187435629331940fc16654e43e54c18a55c7c"

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

/: (workdir /home/opam)

/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2025-02-26 15:01.57 ---> saved as "9a99ed203890bf6ccb1f461a39816470b74163723ef7ff018c0f0a915d1de84e"

/home/opam: (run (network host)
                 (shell "opam init --reinit --config .opamrc-sandbox -ni"))
Configuring from /home/opam/.opamrc-sandbox, then /home/opam/.opamrc, and finally 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
[NOTE] The 'jobs' option was reset, its value was 39 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=39 --global
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[opam-repository-archive] synchronised from git+https://github.com/ocaml/opam-repository-archive
[default] synchronised from file:///home/opam/opam-repository
2025-02-26 15:03.00 ---> saved as "a5ccc944acfcfd533ebad0e12fdf9e7257178b905431ab4fedfd7662cdb4e7c5"

/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.4.0~alpha1~dev (34b7b4ec4af0ebd3c8fc4aee8088471be2ad48c7)
# self-upgrade         no
# system               arch=x86_64 os=linux os-distribution=debian os-version=12
# solver               builtin-0install
# install-criteria     -changed,-count[avoid-version,solution]
# upgrade-criteria     -count[avoid-version,solution]
# jobs                 255
# repositories         1 (local), 1 (version-controlled)
# pinned               1 (version)
# current-switch       4.04
# invariant            ["ocaml-base-compiler" {= "4.04.2"}]
# compiler-packages    ocaml-base-compiler.4.04.2
# ocaml:native         true
# ocaml:native-tools   true
# ocaml:native-dynlink true
# ocaml:stubsdir       /home/opam/.opam/4.04/lib/ocaml/stublibs:/home/opam/.opam/4.04/lib/ocaml
# ocaml:preinstalled   false
# ocaml:compiler       4.04.2
2025-02-26 15:03.02 ---> saved as "518b067402a6f3104680889c6a7704a93114326ce1a14b5186afcd57915989f9"

/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/"))
2025-02-26 15:03.14 ---> saved as "62ae22c40adbe7630a68c2ced0208443efd7e0a8d95d29623bece506b29b6286"

/home/opam: (copy (src .) (dst opam-repository/))
2025-02-26 15:03.24 ---> saved as "bb9ce7e919abb159e8ab93ef3ed3bad972d2b89c67943d4c206e5b10ddf83c24"

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2025-02-26 15:04.08 ---> saved as "8eeafe3bb57f53d42de7f2e8801651f6f8587c39f646b8c068d840e1cde246d8"

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
+ /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 amd64 Packages [246 kB]
- Fetched 349 kB in 0s (983 kB/s)
- Reading package lists...
2025-02-26 15:04.09 ---> saved as "b92447358664a35e17d18bb099c198cc9c3c6d2876d3e695e56acc2d108e16fb"

/home/opam: (run (shell "opam pin add -k version -yn junit_ounit.2.2.0 2.2.0"))
junit_ounit is now pinned to version 2.2.0
2025-02-26 15:04.10 ---> saved as "10e9e24d4e22dc17bdb8edd28add12a97dd722f068f9b49d4cc8de3a04f069b2"

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall junit_ounit.2.2.0;\
                        \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 \"\\\"debian-12\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'junit_ounit.2.2.0' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
junit_ounit.2.2.0 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 14 packages
  - install dune                3.17.2         [required by junit_ounit]
  - install junit               2.2.0          [required by junit_ounit]
  - install junit_ounit         2.2.0 (pinned)
  - install ocamlbuild          0.14.3         [required by ptime]
  - install ocamlfind           1.9.6          [required by ocamlfind-secondary, ptime]
  - install ocamlfind-secondary 1.9.6          [required by dune]
  - install ounit2              2.2.7          [required by junit_ounit]
  - install ptime               0.8.6          [required by junit]
  - install re                  1.11.0         [required by tyxml]
  - install seq                 0.3.1          [required by ounit2]
  - install stdlib-shims        0.3.0          [required by ounit2]
  - install topkg               1.0.4          [required by ptime]
  - install tyxml               4.6.0          [required by junit]
  - install uutf                1.0.3          [required by tyxml]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved dune.3.17.2  (cached)
-> retrieved junit.2.2.0, junit_ounit.2.2.0  (https://github.com/Khady/ocaml-junit/releases/download/2.2.0/junit-2.2.0.tbz)
-> retrieved ocamlbuild.0.14.3  (cached)
-> retrieved ocamlfind.1.9.6, ocamlfind-secondary.1.9.6  (cached)
-> retrieved ounit2.2.2.7  (cached)
-> retrieved ptime.0.8.6  (cached)
-> retrieved re.1.11.0  (cached)
-> retrieved seq.0.3.1  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved topkg.1.0.4  (cached)
-> retrieved tyxml.4.6.0  (cached)
-> retrieved uutf.1.0.3  (cached)
-> installed ocamlfind.1.9.6
-> installed ocamlbuild.0.14.3
-> installed ocamlfind-secondary.1.9.6
-> installed topkg.1.0.4
-> installed uutf.1.0.3
-> installed ptime.0.8.6
-> installed dune.3.17.2
-> installed seq.0.3.1
-> installed stdlib-shims.0.3.0
-> installed re.1.11.0
-> installed ounit2.2.2.7
-> installed tyxml.4.6.0
-> installed junit.2.2.0
-> installed junit_ounit.2.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2025-02-26 15:04.46 ---> saved as "55cc5239734abafe7cbd2cf03b83f7d177803ebd109d3268d1598cc6c72945bf"

/home/opam: (env OPAMCRITERIA +removed,+count[version-lag,solution])

/home/opam: (env OPAMFIXUPCRITERIA +removed,+count[version-lag,solution])

/home/opam: (env OPAMUPGRADECRITERIA +removed,+count[version-lag,solution])

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall junit_ounit.2.2.0;\
                        \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 \"\\\"debian-12\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'junit_ounit.2.2.0' && 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:
=== remove 2 packages
  - remove    seq                      0.3.1            [conflicts with dune]
  - remove    topkg                    1.0.4            [conflicts with ocamlfind]
=== downgrade 11 packages
  - downgrade dune                     3.17.2 to 3.0.2  [required by junit_ounit]
  - downgrade ocaml-secondary-compiler 4.14.2 to 4.08.1 [required by ocamlfind-secondary]
  - downgrade ocamlbuild               0.14.3 to 0.9.1  [upstream or system changes]
  - downgrade ocamlfind                1.9.6 to 1.8.1   [required by ocamlfind-secondary]
  - downgrade ocamlfind-secondary      1.9.6 to 1.8.1   [required by dune]
  - downgrade ounit2                   2.2.7 to 2.2.0   [required by junit_ounit]
  - downgrade ptime                    0.8.6 to 0.8.0   [uses ocamlfind]
  - downgrade re                       1.11.0 to 1.5.0  [uses ocamlfind]
  - downgrade stdlib-shims             0.3.0 to 0.1.0   [uses dune]
  - downgrade tyxml                    4.6.0 to 4.0.0   [uses ocamlfind]                  For tyxml's ppx, please install tyxml-ppx.
  - downgrade uutf                     1.0.3 to 0.9.1   [uses ocamlfind]
=== recompile 2 packages
  - recompile junit                    2.2.0            [uses dune]
  - recompile junit_ounit              2.2.0 (pinned)
=== install 3 packages
  - install   base-bytes               base             [required by tyxml]
  - install   conf-m4                  1                [required by ocamlfind]
  - install   result                   1.0              [required by ptime]

The following system packages will first need to be installed:
    m4

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

opam believes some required external dependencies are missing. opam can:
> 1. Run apt-get to install them (may need root/sudo access)
  2. Display the recommended apt-get command and wait while you run it manually (e.g. in another terminal)
  3. Continue anyway, and, upon success, permanently register that this external dependency is present, but not detectable
  4. Abort the installation

[1/2/3/4] 1

+ /usr/bin/sudo "apt-get" "install" "-qq" "-yy" "m4"
- debconf: delaying package configuration, since apt-utils is not installed
- Selecting previously unselected package m4.
- (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 ... 18745 files and directories currently installed.)
- Preparing to unpack .../archives/m4_1.4.19-3_amd64.deb ...
- Unpacking m4 (1.4.19-3) ...
- Setting up m4 (1.4.19-3) ...

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved dune.3.0.2  (cached)
-> installed conf-m4.1
-> retrieved junit.2.2.0, junit_ounit.2.2.0  (cached)
-> retrieved ocaml-secondary-compiler.4.08.1  (cached)
-> retrieved ocamlbuild.0.9.1  (cached)
-> retrieved ocamlfind.1.8.1, ocamlfind-secondary.1.8.1  (cached)
-> retrieved ounit2.2.2.0  (cached)
-> retrieved ptime.0.8.0  (http://erratique.ch/software/ptime/releases/ptime-0.8.0.tbz)
-> retrieved re.1.5.0  (cached)
-> retrieved result.1.0  (cached)
-> retrieved stdlib-shims.0.1.0  (cached)
-> installed result.1.0
-> retrieved tyxml.4.0.0  (https://github.com/ocsigen/tyxml/archive/4.0.0.tar.gz)
-> retrieved uutf.0.9.1  (http://erratique.ch/software/uutf/releases/uutf-0.9.1.tbz)
-> removed   junit_ounit.2.2.0
-> removed   junit.2.2.0
-> removed   ounit2.2.2.7
-> removed   ptime.0.8.6
-> removed   stdlib-shims.0.3.0
-> removed   tyxml.4.6.0
-> removed   re.1.11.0
-> removed   seq.0.3.1
-> removed   dune.3.17.2
-> removed   ocamlfind-secondary.1.9.6
-> removed   ocaml-secondary-compiler.4.14.2
-> removed   uutf.1.0.3
-> removed   topkg.1.0.4
-> removed   ocamlbuild.0.14.3
-> removed   ocamlfind.1.9.6
-> installed ocaml-secondary-compiler.4.08.1
-> installed ocamlbuild.0.9.1
-> installed ocamlfind.1.8.1
-> installed base-bytes.base
-> installed ptime.0.8.0
-> installed ocamlfind-secondary.1.8.1
-> installed uutf.0.9.1
-> installed re.1.5.0
-> installed dune.3.0.2
-> installed stdlib-shims.0.1.0
-> installed tyxml.4.0.0
-> installed ounit2.2.2.0
-> installed junit.2.2.0
-> installed junit_ounit.2.2.0
Done.
# To update the current shell environment, run: eval $(opam env)
2025-02-26 15:06.47 ---> saved as "af54871e6957f35bff89290c237e9b6700c665d58337a885f0bc131bb7d196ec"
Job succeeded
2025-02-26 15:07.02: Job succeeded