- github
- ocaml
- opam-repository
- 4b172f
- extras,opam-2.0-ocaml-5.4,curses.1.0.12,tests
(not at the head of any monitored branch or PR)
2026-04-02 22:05.53: New job: test curses.1.0.12, using opam 2.0
from https://github.com/ocaml/opam-repository.git#refs/pull/29634/head (4b172f8fb04e73775fb03ade1369a3fe5802d19c)
on debian-13-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/29634/head" && git reset --hard 4b172f8f
git fetch origin master
git merge --no-edit c0deda526f99d43a05c065e9218404492897c64b
cat > ../Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-13-ocaml-5.4@sha256:13f453bea920b1b323f4a04f2b81ee06601f2feba7e1f1aa31e088bc65526b6e
USER 1000:1000
WORKDIR /home/opam
RUN sudo ln -f /usr/bin/opam-2.0 /usr/bin/opam
RUN opam init --reinit -ni
RUN 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 depext -u || true
RUN opam pin add -k version -yn curses.1.0.12 1.0.12
RUN opam depext curses.1.0.12 && opam reinstall curses.1.0.12; \
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-13\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'curses.1.0.12' && partial_fails="$partial_fails $pkg"; \
done; \
test "${partial_fails}" != "" && echo "opam-repo-ci detected dependencies failing: ${partial_fails}"; \
exit 1
RUN (opam depext --with-test curses.1.0.12 && opam reinstall --with-test curses.1.0.12) || true
RUN opam depext --with-test curses.1.0.12 && opam reinstall --with-test --verbose curses.1.0.12; \
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-13\""; then \
echo "A package failed and has been disabled for CI using the 'x-ci-accept-failures' field."; \
fi; \
test "$pkg" != 'curses.1.0.12' && 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-02 22:05.53: Using cache hint "ocaml/opam:debian-13-ocaml-5.4@sha256:13f453bea920b1b323f4a04f2b81ee06601f2feba7e1f1aa31e088bc65526b6e-curses.1.0.12-4b172f8fb04e73775fb03ade1369a3fe5802d19c"
2026-04-02 22:05.53: Using OBuilder spec:
((from ocaml/opam:debian-13-ocaml-5.4@sha256:13f453bea920b1b323f4a04f2b81ee06601f2feba7e1f1aa31e088bc65526b6e)
(user (uid 1000) (gid 1000))
(workdir /home/opam)
(run (shell "sudo ln -f /usr/bin/opam-2.0 /usr/bin/opam"))
(run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
(run (shell "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 depext -u || true"))
(run (shell "opam pin add -k version -yn curses.1.0.12 1.0.12"))
(run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam depext curses.1.0.12 && opam reinstall curses.1.0.12;\
\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-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'curses.1.0.12' && 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 depext --with-test curses.1.0.12 && opam reinstall --with-test curses.1.0.12) || true"))
(run (shell "opam depext --with-test curses.1.0.12 && opam reinstall --with-test --verbose curses.1.0.12;\
\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-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'curses.1.0.12' && 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-02 22:05.53: Waiting for resource in pool OCluster
2026-04-02 22:05.54: Waiting for worker…
2026-04-02 22:05.54: Got resource from pool OCluster
Building on odawa.caelum.ci.dev
All commits already cached
HEAD is now at c0deda526f Merge pull request #29625 from xvw/release-lunar-v1.0.0
Merge made by the 'ort' strategy.
packages/curses/curses.1.0.12/opam | 40 ++++++++++++++++++++++++++++++++++++++
1 file changed, 40 insertions(+)
create mode 100644 packages/curses/curses.1.0.12/opam
(from ocaml/opam:debian-13-ocaml-5.4@sha256:13f453bea920b1b323f4a04f2b81ee06601f2feba7e1f1aa31e088bc65526b6e)
2026-04-02 22:06.30 ---> using "04accec92e2bf0fc058f8f78760257a004a3abe580d28a2e712fdd6bd38bbb3e" from cache
/: (user (uid 1000) (gid 1000))
/: (workdir /home/opam)
/home/opam: (run (shell "sudo ln -f /usr/bin/opam-2.0 /usr/bin/opam"))
2026-04-02 22:06.30 ---> using "b4233c605d2ca4c2bbeb36f7073378442d9c3bddae7e41cc67d848a7216c0362" from cache
/home/opam: (run (network host)
(shell "opam init --reinit --config .opamrc-sandbox -ni"))
[NOTE] Will configure 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.
[WARNING] Recommended dependencies -- most packages rely on these:
- m4
<><> Updating repositories ><><><><><><><><><><><><><><><><><><><><><><><><><><>
[default] Initialised
default (at git+file:///home/opam/opam-repository):
[INFO] opam 2.1 and 2.2 include many performance and security improvements over 2.0; please consider upgrading (https://opam.ocaml.org/doc/Install.html)
2026-04-02 22:06.30 ---> using "60d663209f35770b27c438a7325f9def1ac47c3d4aacf8c625c6b5b2f545430c" from cache
/home/opam: (run (shell "opam config report"))
# opam config report
# opam-version 2.0.10 (adc1e1829a2bef5b240746df80341b508290fe3b)
# self-upgrade no
# system arch=x86_64 os=linux os-distribution=debian os-version=13
# solver builtin-mccs+glpk
# install-criteria -removed,-count[version-lag,request],-count[version-lag,changed],-changed
# upgrade-criteria -removed,-count[version-lag,solution],-new
# jobs 71
# repositories 1 (version-controlled)
# pinned 1 (version)
# current-switch 5.4
2026-04-02 22:06.30 ---> using "24cc3f45b5a55fbba558b726240de02a8fff39a9e33cff6afbbe5966760c3329" 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-02 22:06.30 ---> using "05cd1ef05b43d5eed63bfb39ef7cb0a6e9a794db163e7fd053721489ec01ba49" from cache
/home/opam: (copy (src .) (dst opam-repository/))
2026-04-02 22:06.32 ---> saved as "e79c3fe886a3fbd271a56d3b3a842cf8ab765d54e6f42e76f7d8d3604c2e1e12"
/home/opam: (run (shell "opam repository set-url --strict default opam-repository/"))
[default] Initialised
default (at file:///home/opam/opam-repository):
[INFO] opam 2.1 and 2.2 include many performance and security improvements over 2.0; please consider upgrading (https://opam.ocaml.org/doc/Install.html)
2026-04-02 22:06.43 ---> saved as "01fc139cd4800d8da3b115387a1b8111d5fe648f046b4f17b32dc4c2dfe5137f"
/home/opam: (run (network host)
(shell "opam depext -u || true"))
# Detecting depexts using vars: arch=x86_64, os=linux, os-distribution=debian, os-family=debian
# No extra OS packages requirements found.
# All required OS packages found.
The following command needs to be run through "sudo":
apt-get update
Hit:1 http://deb.debian.org/debian trixie InRelease
Get:2 http://deb.debian.org/debian trixie-updates InRelease [47.3 kB]
Get:3 http://deb.debian.org/debian-security trixie-security InRelease [43.4 kB]
Get:4 http://deb.debian.org/debian-security trixie-security/main amd64 Packages [119 kB]
Fetched 210 kB in 0s (2128 kB/s)
Reading package lists...
# OS package update successful
2026-04-02 22:06.44 ---> saved as "c492363168ffe1cbdc9238fd50fa740ac5fb15e8bc7dc77a74f4022126a6a02e"
/home/opam: (run (shell "opam pin add -k version -yn curses.1.0.12 1.0.12"))
curses is now pinned to version 1.0.12
2026-04-02 22:06.44 ---> saved as "c6e6bb3bec4c1344891644c57de8cc879a5e3d99e7475a59665a60540051c65b"
/home/opam: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "opam depext curses.1.0.12 && opam reinstall curses.1.0.12;\
\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-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'curses.1.0.12' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
# Detecting depexts using vars: arch=x86_64, os=linux, os-distribution=debian, os-family=debian
# The following system packages are needed:
ncurses-dev
pkg-config
The following command needs to be run through "sudo":
apt-get install -qq -yy ncurses-dev pkg-config
Selecting previously unselected package libncurses6:amd64.
(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 ... 20654 files and directories currently installed.)
Preparing to unpack .../0-libncurses6_6.5+20250216-2_amd64.deb ...
Unpacking libncurses6:amd64 (6.5+20250216-2) ...
Selecting previously unselected package libncurses-dev:amd64.
Preparing to unpack .../1-libncurses-dev_6.5+20250216-2_amd64.deb ...
Unpacking libncurses-dev:amd64 (6.5+20250216-2) ...
Selecting previously unselected package libpkgconf3:amd64.
Preparing to unpack .../2-libpkgconf3_1.8.1-4_amd64.deb ...
Unpacking libpkgconf3:amd64 (1.8.1-4) ...
Selecting previously unselected package pkgconf-bin.
Preparing to unpack .../3-pkgconf-bin_1.8.1-4_amd64.deb ...
Unpacking pkgconf-bin (1.8.1-4) ...
Selecting previously unselected package pkgconf:amd64.
Preparing to unpack .../4-pkgconf_1.8.1-4_amd64.deb ...
Unpacking pkgconf:amd64 (1.8.1-4) ...
Selecting previously unselected package pkg-config:amd64.
Preparing to unpack .../5-pkg-config_1.8.1-4_amd64.deb ...
Unpacking pkg-config:amd64 (1.8.1-4) ...
Setting up libpkgconf3:amd64 (1.8.1-4) ...
Setting up libncurses6:amd64 (6.5+20250216-2) ...
Setting up pkgconf-bin (1.8.1-4) ...
Setting up libncurses-dev:amd64 (6.5+20250216-2) ...
Setting up pkgconf:amd64 (1.8.1-4) ...
Setting up pkg-config:amd64 (1.8.1-4) ...
Processing triggers for libc-bin (2.41-12+deb13u2) ...
# OS packages installation successful
curses.1.0.12 is not installed. Install it? [Y/n] y
The following actions will be performed:
- install dune 3.22.0 [required by curses]
- install conf-pkg-config 4 [required by curses]
- install csexp 1.5.2 [required by dune-configurator]
- install conf-ncurses 1 [required by curses]
- install dune-configurator 3.22.0 [required by curses]
- install curses 1.0.12*
===== 6 to install =====
<><> Gathering sources ><><><><><><><><><><><><><><><><><><><><><><><><><><><><>
[csexp.1.5.2] found in cache
[curses.1.0.12] found in cache
[dune.3.22.0] found in cache
[dune-configurator.3.22.0] found in cache
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> installed conf-pkg-config.4
-> installed conf-ncurses.1
-> installed dune.3.22.0
-> installed csexp.1.5.2
-> installed dune-configurator.3.22.0
-> installed curses.1.0.12
Done.
# Run eval $(opam env) to update the current shell environment
2026-04-02 22:07.18 ---> saved as "e8f0a3eaf31a750d2f32aca68bf509284d8cf05df71c3288a573eec5f2ee966e"
/home/opam: (run (network host)
(shell "(opam depext --with-test curses.1.0.12 && opam reinstall --with-test curses.1.0.12) || true"))
# Detecting depexts using vars: arch=x86_64, os=linux, os-distribution=debian, os-family=debian
# The following system packages are needed:
ncurses-dev
pkg-config
# All required OS packages found.
The following actions will be performed:
- recompile curses 1.0.12*
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> removed curses.1.0.12
-> installed curses.1.0.12
Done.
# Run eval $(opam env) to update the current shell environment
2026-04-02 22:07.27 ---> saved as "3322101e0600105835f847cd00f3bccbe2c1afdd957f6368750b003b8c8d37fa"
/home/opam: (run (shell "opam depext --with-test curses.1.0.12 && opam reinstall --with-test --verbose curses.1.0.12;\
\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-13\\\"\"; then\
\n echo \"A package failed and has been disabled for CI using the 'x-ci-accept-failures' field.\";\
\n fi;\
\n test \"$pkg\" != 'curses.1.0.12' && partial_fails=\"$partial_fails $pkg\";\
\n done;\
\n test \"${partial_fails}\" != \"\" && echo \"opam-repo-ci detected dependencies failing: ${partial_fails}\";\
\n exit 1"))
# Detecting depexts using vars: arch=x86_64, os=linux, os-distribution=debian, os-family=debian
ncurses-dev
pkg-config
# The following system packages are needed:
# All required OS packages found.
The following actions will be performed:
- recompile curses 1.0.12*
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
Processing 1/3: [curses: dune build]
+ /home/opam/.opam/opam-init/hooks/sandbox.sh "build" "dune" "build" "-p" "curses" "-j" "71" "@install" "@runtest" (CWD=/home/opam/.opam/5.4/.opam-switch/build/curses.1.0.12)
-> compiled curses.1.0.12
-> removed curses.1.0.12
-> installed curses.1.0.12
Done.
# Run eval $(opam env) to update the current shell environment
2026-04-02 22:07.36 ---> saved as "c7d3f7045166c504bd9ed9b1021c16bd3ef9c62b29000313668008e1ebea8a45"
Job succeeded
2026-04-02 22:07.43: Job succeeded