(for PR #29350)

2026-02-07 08:26.58: New job: build testcontainers-redis.0.1.0, using opam dev
                              from https://github.com/ocaml/opam-repository.git#refs/pull/29350/head (3fd8eac38fb2e07d304ff0ea935622799c447089)
                              on debian-unstable-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/29350/head" && git reset --hard 3fd8eac3
git fetch origin master
git merge --no-edit 340ee6fd1ff10d0fce25e21ba1caca9ed1cfec68
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-unstable-ocaml-5.4@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d
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 testcontainers-redis.0.1.0 0.1.0
RUN opam reinstall testcontainers-redis.0.1.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-unstable\""; then \
    echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
    fi; \
    test "$pkg" != 'testcontainers-redis.0.1.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 .

2026-02-07 08:26.58: Using cache hint "ocaml/opam:debian-unstable-ocaml-5.4@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d-testcontainers-redis.0.1.0-3fd8eac38fb2e07d304ff0ea935622799c447089"
2026-02-07 08:26.58: Using OBuilder spec:
((from ocaml/opam:debian-unstable-ocaml-5.4@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d)
 (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 testcontainers-redis.0.1.0 0.1.0"))
 (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
      (network host)
      (shell  "opam reinstall testcontainers-redis.0.1.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-unstable\\\"\"; then\
             \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
             \n          fi;\
             \n          test \"$pkg\" != 'testcontainers-redis.0.1.0' && partial_fails=\"$partial_fails $pkg\";\
             \n        done;\
             \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
             \n        exit 1"))
)

2026-02-07 08:26.58: Waiting for resource in pool OCluster
2026-02-07 08:29.03: Waiting for worker…
2026-02-07 08:32.00: Got resource from pool OCluster
Building on eumache
All commits already cached
HEAD is now at 340ee6fd1f Merge pull request #29341 from Halbaroth/release-alt-ergo-free-2.4.3
Updating 340ee6fd1f..3fd8eac38f
Fast-forward
 .../testcontainers-elasticsearch.0.1.0/opam        | 39 ++++++++++++++++
 .../testcontainers-kafka.0.1.0/opam                | 39 ++++++++++++++++
 .../testcontainers-localstack.0.1.0/opam           | 40 +++++++++++++++++
 .../testcontainers-memcached.0.1.0/opam            | 39 ++++++++++++++++
 .../testcontainers-mockserver.0.1.0/opam           | 40 +++++++++++++++++
 .../testcontainers-mongo.0.1.0/opam                | 39 ++++++++++++++++
 .../testcontainers-mysql.0.1.0/opam                | 39 ++++++++++++++++
 .../testcontainers-postgres.0.1.0/opam             | 39 ++++++++++++++++
 .../testcontainers-rabbitmq.0.1.0/opam             | 39 ++++++++++++++++
 .../testcontainers-redis.0.1.0/opam                | 39 ++++++++++++++++
 packages/testcontainers/testcontainers.0.1.0/opam  | 52 ++++++++++++++++++++++
 11 files changed, 444 insertions(+)
 create mode 100644 packages/testcontainers-elasticsearch/testcontainers-elasticsearch.0.1.0/opam
 create mode 100644 packages/testcontainers-kafka/testcontainers-kafka.0.1.0/opam
 create mode 100644 packages/testcontainers-localstack/testcontainers-localstack.0.1.0/opam
 create mode 100644 packages/testcontainers-memcached/testcontainers-memcached.0.1.0/opam
 create mode 100644 packages/testcontainers-mockserver/testcontainers-mockserver.0.1.0/opam
 create mode 100644 packages/testcontainers-mongo/testcontainers-mongo.0.1.0/opam
 create mode 100644 packages/testcontainers-mysql/testcontainers-mysql.0.1.0/opam
 create mode 100644 packages/testcontainers-postgres/testcontainers-postgres.0.1.0/opam
 create mode 100644 packages/testcontainers-rabbitmq/testcontainers-rabbitmq.0.1.0/opam
 create mode 100644 packages/testcontainers-redis/testcontainers-redis.0.1.0/opam
 create mode 100644 packages/testcontainers/testcontainers.0.1.0/opam

(from ocaml/opam:debian-unstable-ocaml-5.4@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d)
Unable to find image 'ocaml/opam:debian-unstable-ocaml-5.4@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d' locally
docker.io/ocaml/opam@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d: Pulling from ocaml/opam
8e36c1fbb8f9: Already exists
497d281dff8f: Already exists
1336f5ee1864: Already exists
18928a5bcc82: Already exists
7378e61c2409: Already exists
2839b2c47c5d: Already exists
4646204f5187: Already exists
a1ca9a1247f2: Already exists
3eb69a19fdca: Already exists
36b63b0f34ad: Already exists
206bac06281b: Already exists
9b55ac1f8d06: Already exists
b7ed43a82e6d: Already exists
71c2e07c5bdb: Already exists
ddf67ac6de6e: Already exists
c46ae1fc9026: Already exists
6ff56b737f83: Already exists
e7b100c4a5e6: Already exists
6ce8488bc607: Already exists
a5e8881b2f62: Already exists
b703d3920198: Already exists
e15fa12414c6: Already exists
4f4fb700ef54: Already exists
04dfb9d1939a: Already exists
d35acb3c5bac: Already exists
8554de9fa684: Already exists
6e5d09b42c5b: Already exists
d6ac3d1ef8cd: Already exists
eb19663ed618: Already exists
ceab74aa55c4: Already exists
1ca4c81d84df: Already exists
9cc63b1bba75: Already exists
838fc72dbf2d: Already exists
aa1acc2a2958: Already exists
7c77beb87bdb: Already exists
eac597a4deb1: Already exists
5fc6b8467d53: Already exists
08d6647ea74d: Already exists
72e3a65bb925: Already exists
6ece34357086: Already exists
a7981cc1c280: Already exists
a4f14625f22a: Already exists
d1b50968b488: Already exists
c8b772c77950: Already exists
eb7363913317: Already exists
68bf0e609f91: Already exists
65fc5feae137: Already exists
c5ab0af19145: Already exists
Digest: sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d
Status: Downloaded newer image for ocaml/opam@sha256:a054bb49759d0a15992de4aa713c810ad1264146dab8e0f9ed4110c98d0cf14d
2026-02-07 08:32.44 ---> saved as "790b77bc05849535ca33c2857dbe0bd41e30b44b97b3b49c4a407c00a7289d5c"

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

/: (workdir /home/opam)

/home/opam: (run (shell "sudo ln -f /usr/bin/opam-dev /usr/bin/opam"))
2026-02-07 08:32.44 ---> saved as "13ab3de6f863aaa479b567e0f2d05564a98208ade134c30b8c4e7a002a617684"

/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 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 255 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=255 --global
Format upgrade done.

<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
2026-02-07 08:33.12 ---> saved as "37ef3a8be886da5d54674b2777cb13f3bbc79214d61aa3f70d1b8a1da7c7e118"

/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=linux os-distribution=debian os-version=unknown
# solver               builtin-0install
# install-criteria     -changed,-count[avoid-version,solution]
# upgrade-criteria     -count[avoid-version,solution]
# jobs                 71
# repositories         1 (version-controlled)
# pinned               1 (version)
# current-switch       5.4
# invariant            ["ocaml-base-compiler" {>= "5.4.0"}]
# compiler-packages    ocaml-base-compiler.5.4.0, ocaml-compiler.5.4.0, ocaml-options-vanilla.1
# ocaml:native         true
# ocaml:native-tools   true
# ocaml:native-dynlink true
# ocaml:stubsdir       /home/opam/.opam/5.4/lib/ocaml/stublibs:/home/opam/.opam/5.4/lib/ocaml
# ocaml:preinstalled   false
# ocaml:compiler       5.4.0
2026-02-07 08:33.13 ---> saved as "25f445326f7acb6a9aa73819f5048f78093af92329391579a2900cbd3620289d"

/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-02-07 08:33.20 ---> saved as "06a63412b7158541a556dc29a166c7e086b25983c8b8621091a4b46a4e56d096"

/home/opam: (copy (src .) (dst opam-repository/))
2026-02-07 08:33.28 ---> saved as "e6b9039a81dee0c8576aed11d12ef5c29a9bddf6ce6b9f031ed7332b08c0511f"

/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
2026-02-07 08:33.48 ---> saved as "0927e6672f5557ec5e27f6b82607172f180af4453677a2e171dc52b502dd8527"

/home/opam: (run (network host)
                 (shell "opam update --depexts || true"))
+ /usr/bin/sudo "apt-get" "update"
- Get:1 http://deb.debian.org/debian unstable InRelease [187 kB]
- Get:2 http://deb.debian.org/debian unstable/main amd64 Packages.diff/Index [63.6 kB]
- Get:3 http://deb.debian.org/debian unstable/main amd64 Packages T-2026-02-07-0159.57-F-2026-01-30-2002.22.pdiff [504 kB]
- Get:3 http://deb.debian.org/debian unstable/main amd64 Packages T-2026-02-07-0159.57-F-2026-01-30-2002.22.pdiff [504 kB]
- Fetched 754 kB in 3s (245 kB/s)
- Reading package lists...
- 
2026-02-07 08:33.52 ---> saved as "53874b479317e9752543d95f9bb6db56d81960b6a1e09469e0d73e423089b118"

/home/opam: (run (shell "opam pin add -k version -yn testcontainers-redis.0.1.0 0.1.0"))
testcontainers-redis is now pinned to version 0.1.0
2026-02-07 08:33.54 ---> saved as "f8832297b94687114e28e1a81b37fa29bac43ca5227d38e64dbd78550783b774"

/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
                 (network host)
                 (shell  "opam reinstall testcontainers-redis.0.1.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-unstable\\\"\"; then\
                        \n            echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
                        \n          fi;\
                        \n          test \"$pkg\" != 'testcontainers-redis.0.1.0' && partial_fails=\"$partial_fails $pkg\";\
                        \n        done;\
                        \n        test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
                        \n        exit 1"))
testcontainers-redis.0.1.0 is not installed. Install it? [Y/n] y
The following actions will be performed:
=== install 27 packages
  - install angstrom             0.16.1         [required by uri]
  - install base-bytes           base           [required by ocplib-endian]
  - install bigstringaf          0.10.0         [required by angstrom]
  - install cppo                 1.8.0          [required by lwt]
  - install csexp                1.5.2          [required by dune-configurator]
  - install dune                 3.21.0         [required by testcontainers-redis]
  - install dune-configurator    3.21.0         [required by lwt]
  - install fmt                  0.11.0         [required by testcontainers]
  - install logs                 0.10.0         [required by testcontainers]
  - install lwt                  6.1.0          [required by lwt_ppx, testcontainers]
  - install lwt_ppx              6.1.0          [required by testcontainers-redis]
  - install ocaml-compiler-libs  v0.17.0        [required by ppxlib]
  - install ocaml-syntax-shims   1.0.0          [required by angstrom]
  - install ocamlbuild           0.16.1         [required by fmt, logs]
  - install ocamlfind            1.9.8          [required by fmt, logs]
  - install ocplib-endian        1.2            [required by lwt]
  - install ppx_derivers         1.2.1          [required by ppxlib]
  - install ppxlib               0.37.0         [required by lwt_ppx]
  - install re                   1.14.0         [required by testcontainers]
  - install sexplib0             v0.17.0        [required by ppxlib]
  - install stdlib-shims         0.3.0          [required by ppxlib]
  - install stringext            1.6.0          [required by uri]
  - install testcontainers       0.1.0          [required by testcontainers-redis]
  - install testcontainers-redis 0.1.0 (pinned)
  - install topkg                1.1.1          [required by fmt, logs]
  - install uri                  4.4.0          [required by testcontainers]
  - install yojson               3.0.0          [required by testcontainers]

<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved angstrom.0.16.1  (cached)
-> retrieved bigstringaf.0.10.0  (cached)
-> retrieved cppo.1.8.0  (cached)
-> retrieved csexp.1.5.2  (cached)
-> retrieved dune.3.21.0, dune-configurator.3.21.0  (cached)
-> retrieved fmt.0.11.0  (cached)
-> retrieved logs.0.10.0  (cached)
-> retrieved lwt.6.1.0, lwt_ppx.6.1.0  (cached)
-> retrieved ocaml-compiler-libs.v0.17.0  (cached)
-> retrieved ocaml-syntax-shims.1.0.0  (cached)
-> retrieved ocamlbuild.0.16.1  (cached)
-> retrieved ocamlfind.1.9.8  (cached)
-> retrieved ocplib-endian.1.2  (cached)
-> retrieved ppx_derivers.1.2.1  (cached)
-> retrieved ppxlib.0.37.0  (cached)
-> retrieved re.1.14.0  (cached)
-> retrieved sexplib0.v0.17.0  (cached)
-> retrieved stdlib-shims.0.3.0  (cached)
-> retrieved stringext.1.6.0  (cached)
-> retrieved testcontainers.0.1.0, testcontainers-redis.0.1.0  (cached)
-> retrieved topkg.1.1.1  (cached)
-> retrieved uri.4.4.0  (cached)
-> retrieved yojson.3.0.0  (cached)
-> installed ocamlfind.1.9.8
-> installed base-bytes.base
-> installed ocamlbuild.0.16.1
-> installed topkg.1.1.1
-> installed fmt.0.11.0
-> installed dune.3.21.0
-> installed ppx_derivers.1.2.1
-> installed csexp.1.5.2
-> installed ocaml-compiler-libs.v0.17.0
-> installed cppo.1.8.0
-> installed ocaml-syntax-shims.1.0.0
-> installed re.1.14.0
-> installed sexplib0.v0.17.0
-> installed stdlib-shims.0.3.0
-> installed stringext.1.6.0
-> installed yojson.3.0.0
-> installed ocplib-endian.1.2
-> installed dune-configurator.3.21.0
-> installed bigstringaf.0.10.0
-> installed angstrom.0.16.1
-> installed lwt.6.1.0
-> installed uri.4.4.0
-> installed logs.0.10.0
-> installed ppxlib.0.37.0
-> installed lwt_ppx.6.1.0
-> installed testcontainers.0.1.0
-> installed testcontainers-redis.0.1.0
Done.
# To update the current shell environment, run: eval $(opam env)
2026-02-07 08:35.20 ---> saved as "dd3215d58976a2df6a1e9449f207f4008d97696adce346882a55fb1dbb58b3ca"
Job succeeded
2026-02-07 08:35.27: Job succeeded