2024-12-06 15:30.22: New job: test ocaml-ppx/ppxlib https://github.com/ocaml-ppx/ppxlib.git#refs/pull/541/head (b51d33ead7a82ebb25064cf8282adbb1a7cab68c) (linux-x86_64:debian-12-4.12_opam-2.3)
Base: ocaml/opam:debian-12-ocaml-4.12@sha256:10b66a8693974996afed0f5c8eca1bc3970f04ea9258bc4863d00ca719321b36
Opam project build
To reproduce locally:
git clone --recursive "https://github.com/ocaml-ppx/ppxlib.git" && cd "ppxlib" && git fetch origin "refs/pull/541/head" && git reset --hard b51d33ea
cat > Dockerfile <<'END-OF-DOCKERFILE'
FROM ocaml/opam:debian-12-ocaml-4.12@sha256:10b66a8693974996afed0f5c8eca1bc3970f04ea9258bc4863d00ca719321b36
# debian-12-4.12_opam-2.3
USER 1000:1000
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 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 || git fetch origin master) && git reset -q --hard 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 && git log --no-decorate -n1 --oneline && opam update -u
RUN mkdir -p 'bench/vendored/ppx_sexp_conv.v0.15.1/'
COPY --chown=1000:1000 ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam ./
COPY --chown=1000:1000 bench/vendored/ppx_sexp_conv.v0.15.1/ppx_sexp_conv.opam bench/vendored/ppx_sexp_conv.v0.15.1/
RUN opam pin add -yn ppxlib.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
opam pin add -yn ppxlib-tools.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
opam pin add -yn ppxlib-bench.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
opam pin add -yn ppx_sexp_conv 'bench/vendored/ppx_sexp_conv.v0.15.1/' && echo '(lang dune 3.0)' > 'bench/vendored/ppx_sexp_conv.v0.15.1/dune-project'
ENV DEPS="base.v0.15.1 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 ocaml.4.12.1 ocaml-base-compiler.4.12.1 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocamlfind.1.9.6 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.15.1 stdlib-shims.0.3.0 yojson.2.2.2"
ENV CI="true"
ENV OCAMLCI="true"
RUN opam update --depexts && opam install --cli=2.3 --depext-only -y ppxlib.dev ppxlib-tools.dev ppxlib-bench.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
2024-12-06 15:30.22: Using cache hint "ocaml-ppx/ppxlib-ocaml/opam:debian-12-ocaml-4.12@sha256:10b66a8693974996afed0f5c8eca1bc3970f04ea9258bc4863d00ca719321b36-debian-12-4.12_opam-2.3-5691fb74b56830df9ed87088e6ee01ca"
2024-12-06 15:30.22: Using OBuilder spec:
((from ocaml/opam:debian-12-ocaml-4.12@sha256:10b66a8693974996afed0f5c8eca1bc3970f04ea9258bc4863d00ca719321b36)
(comment debian-12-4.12_opam-2.3)
(user (uid 1000) (gid 1000))
(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 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 || git fetch origin master) && git reset -q --hard 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 && git log --no-decorate -n1 --oneline && opam update -u"))
(run (shell "mkdir -p 'bench/vendored/ppx_sexp_conv.v0.15.1/'"))
(copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam) (dst ./))
(copy (src bench/vendored/ppx_sexp_conv.v0.15.1/ppx_sexp_conv.opam)
(dst bench/vendored/ppx_sexp_conv.v0.15.1/))
(run (network host)
(shell "opam pin add -yn ppxlib.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppxlib-tools.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppxlib-bench.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppx_sexp_conv 'bench/vendored/ppx_sexp_conv.v0.15.1/' && echo '(lang dune 3.0)' > 'bench/vendored/ppx_sexp_conv.v0.15.1/dune-project'"))
(env DEPS "base.v0.15.1 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 ocaml.4.12.1 ocaml-base-compiler.4.12.1 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocamlfind.1.9.6 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.15.1 stdlib-shims.0.3.0 yojson.2.2.2")
(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 ppxlib.dev ppxlib-tools.dev ppxlib-bench.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"))
)
2024-12-06 15:30.22: Waiting for resource in pool OCluster
2024-12-06 15:30.22: Waiting for worker…
2024-12-06 15:51.29: Got resource from pool OCluster
Building on x86-bm-c14.sw.ocaml.org
All commits already cached
HEAD is now at b51d33ea TMP: Implement -no-corrections
(from ocaml/opam:debian-12-ocaml-4.12@sha256:10b66a8693974996afed0f5c8eca1bc3970f04ea9258bc4863d00ca719321b36)
2024-12-06 15:52.12 ---> saved as "bf59acebf8623b21e3bbce0805e99df2487555e26af47809db7fa900bebee58e"
/: (comment debian-12-4.12_opam-2.3)
/: (user (uid 1000) (gid 1000))
/: (env CLICOLOR_FORCE 1)
/: (env OPAMCOLOR always)
/: (workdir /src)
/src: (run (shell "sudo ln -f /usr/bin/opam-2.3 /usr/bin/opam"))
2024-12-06 15:52.12 ---> saved as "4d4440047a5619a3f197a0a551b94badc66d5a0850b3f55e77cfcedb9c380038"
/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 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] synchronised from file:///home/opam/opam-repository
2024-12-06 15:53.41 ---> saved as "1088eb868cade9f7391e670981169ab9130beb382d210a0b70c51237ca505d72"
/src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version"))
Linux 5.15.0-126-generic
The OCaml toplevel, version 4.12.1
2.3.0
2024-12-06 15:53.41 ---> saved as "1635b09c899a05963280917f19bb1a55a46a98a1543da06c03d0f78b1ba6de29"
/src: (workdir /src)
/src: (run (shell "sudo chown opam /src"))
2024-12-06 15:53.41 ---> saved as "5bb4ed3a8d493b98c848a9f6cf111a76417e2af6e0a95d0df71d40497cf847a3"
/src: (run (cache (opam-archives (target /home/opam/.opam/download-cache)))
(network host)
(shell "cd ~/opam-repository && (git cat-file -e 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 || git fetch origin master) && git reset -q --hard 1b58d8c4dd40d1b4a0893c7b9182b698c1b34c44 && git log --no-decorate -n1 --oneline && opam update -u"))
From https://github.com/ocaml/opam-repository
* branch master -> FETCH_HEAD
11bdbee611..99a6939e6c master -> origin/master
1b58d8c4dd Merge pull request #26975 from maiste/release-dune-3.17.0
<><> Updating package repositories ><><><><><><><><><><><><><><><><><><><><><><>
[default] synchronised from 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)
2024-12-06 15:55.01 ---> saved as "936548ce8ae60509c16cc4439d4b21cc387e48d1f3f70cc8711f512201b350a7"
/src: (run (shell "mkdir -p 'bench/vendored/ppx_sexp_conv.v0.15.1/'"))
2024-12-06 15:55.01 ---> saved as "1da9c2452f8861167c8b7075c6d8d11f6ab8d1942311ad3503aabfa0ace865d8"
/src: (copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam) (dst ./))
2024-12-06 15:55.01 ---> saved as "7e706c37d3fe0858a70b225ad8b0351ad9cef26960ad3226c579d8820f97b685"
/src: (copy (src bench/vendored/ppx_sexp_conv.v0.15.1/ppx_sexp_conv.opam)
(dst bench/vendored/ppx_sexp_conv.v0.15.1/))
2024-12-06 15:55.01 ---> saved as "b2223f0cfe48b9a5921148f60e17c0dd8e2a73852e370e3a7499f86b22a2d866"
/src: (run (network host)
(shell "opam pin add -yn ppxlib.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppxlib-tools.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppxlib-bench.dev './' && echo '(lang dune 3.0)' > './dune-project' && \
\nopam pin add -yn ppx_sexp_conv 'bench/vendored/ppx_sexp_conv.v0.15.1/' && echo '(lang dune 3.0)' > 'bench/vendored/ppx_sexp_conv.v0.15.1/dune-project'"))
[ppxlib.dev] synchronised (file:///src)
ppxlib is now pinned to file:///src (version dev)
Package ppxlib-tools does not exist, create as a NEW package? [y/n] y
[ppxlib-tools.dev] synchronised (file:///src)
ppxlib-tools is now pinned to file:///src (version dev)
Package ppxlib-bench does not exist, create as a NEW package? [y/n] y
[ppxlib-bench.dev] synchronised (file:///src)
ppxlib-bench is now pinned to file:///src (version dev)
[ppx_sexp_conv.v0.17.0] synchronised (file:///src/bench/vendored/ppx_sexp_conv.v0.15.1)
ppx_sexp_conv is now pinned to file:///src/bench/vendored/ppx_sexp_conv.v0.15.1 (version v0.15.0)
2024-12-06 15:55.10 ---> saved as "5482a4c406fca415aecbe7f3a4d164e921fe9b0d72db72981fdfa874093f7e0a"
/src: (env DEPS "base.v0.15.1 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 ocaml.4.12.1 ocaml-base-compiler.4.12.1 ocaml-compiler-libs.v0.12.4 ocaml-config.2 ocaml-options-vanilla.1 ocamlfind.1.9.6 ppx_derivers.1.2.1 re.1.12.0 seq.base sexplib0.v0.15.1 stdlib-shims.0.3.0 yojson.2.2.2")
/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 ppxlib.dev ppxlib-tools.dev ppxlib-bench.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 bookworm-updates/main amd64 Packages.diff/Index [12.8 kB]
- Get:5 http://deb.debian.org/debian bookworm-updates/main amd64 Packages T-2024-11-27-1405.46-F-2024-11-27-1405.46.pdiff [435 B]
- Get:5 http://deb.debian.org/debian bookworm-updates/main amd64 Packages T-2024-11-27-1405.46-F-2024-11-27-1405.46.pdiff [435 B]
- Get:6 http://deb.debian.org/debian-security bookworm-security/main amd64 Packages [206 kB]
- Fetched 322 kB in 0s (1205 kB/s)
- Reading package lists...
<><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><>
[ppxlib.dev] synchronised (file:///src)
[ppxlib-bench.dev] synchronised (file:///src)
[ppxlib-tools.dev] synchronised (file:///src)
[NOTE] Package ocaml-options-vanilla is already installed (current version is 1).
[NOTE] Package ocaml-config is already installed (current version is 2).
[NOTE] Package ocaml-base-compiler is already installed (current version is 4.12.1).
[NOTE] Package ocaml is already installed (current version is 4.12.1).
[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-bigarray is already installed (current version is base).
2024-12-06 15:55.35 ---> saved as "b79a6dfcf8c6853526a2283cd7f4c2e6ad6b04c5312d3f8e43eb7419d08fa4a0"
/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-config is already installed (current version is 2).
[NOTE] Package ocaml-base-compiler is already installed (current version is 4.12.1).
[NOTE] Package ocaml is already installed (current version is 4.12.1).
[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-bigarray is already installed (current version is base).
The following actions will be performed:
=== install 14 packages
- install base v0.15.1
- install cinaps v0.15.1
- install cmdliner 1.3.0
- install csexp 1.5.2
- install dune 3.17.0
- install dune-configurator 3.17.0
- install ocaml-compiler-libs v0.12.4
- install ocamlfind 1.9.6
- install ppx_derivers 1.2.1
- install re 1.12.0
- install seq base
- install sexplib0 v0.15.1
- install stdlib-shims 0.3.0
- install yojson 2.2.2
<><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><>
-> retrieved cinaps.v0.15.1 (cached)
-> retrieved csexp.1.5.2 (cached)
-> retrieved base.v0.15.1 (cached)
-> retrieved cmdliner.1.3.0 (cached)
-> retrieved ocaml-compiler-libs.v0.12.4 (cached)
-> retrieved ppx_derivers.1.2.1 (cached)
-> retrieved ocamlfind.1.9.6 (cached)
-> retrieved seq.base (cached)
-> installed seq.base
-> retrieved re.1.12.0 (cached)
-> retrieved sexplib0.v0.15.1 (cached)
-> retrieved stdlib-shims.0.3.0 (cached)
-> retrieved yojson.2.2.2 (cached)
-> retrieved dune.3.17.0, dune-configurator.3.17.0 (cached)
-> installed cmdliner.1.3.0
-> installed ocamlfind.1.9.6
-> installed dune.3.17.0
-> installed ppx_derivers.1.2.1
-> installed csexp.1.5.2
-> installed ocaml-compiler-libs.v0.12.4
-> installed sexplib0.v0.15.1
-> installed stdlib-shims.0.3.0
-> installed re.1.12.0
-> installed yojson.2.2.2
-> installed cinaps.v0.15.1
-> installed dune-configurator.3.17.0
-> installed base.v0.15.1
Done.
# To update the current shell environment, run: eval $(opam env)
2024-12-06 15:56.39 ---> saved as "431a3f2b6fef551ac5fb80ae3339ca0f90c966732ecf5b2de9b6bec9ac27a2c5"
/src: (copy (src .) (dst /src))
2024-12-06 15:56.39 ---> saved as "f7b2c570d6e385aa8fdb99a9323d642a0637e1a1fbcedeb7c5958e60e2b4f225"
/src: (run (shell "opam exec -- dune build @install @check @runtest && rm -rf _build"))
File "bench/drivers/ppx_sexp_conv/dune", line 7, characters 19-32:
7 | (libraries ppxlib ppx_sexp_conv))
^^^^^^^^^^^^^
Error: Library "ppx_sexp_conv" not found.
-> required by
_build/default/bench/drivers/ppx_sexp_conv/.driver.eobjs/byte/dune__exe__Driver.cmi
-> required by alias bench/drivers/ppx_sexp_conv/check
File "test/driver/no-corrections/run.t", line 1, characters 0-0:
/usr/bin/git --no-pager diff --no-index --color=always -u _build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t _build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t.corrected
diff --git a/_build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t b/_build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t.corrected
index 359719e..974dfc5 100644
--- a/_build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t
+++ b/_build/.sandbox/c74f314fd93f3a0eb84d94ade99e2da6/default/test/driver/no-corrections/run.t.corrected
@@ -79,6 +79,7 @@ has no knowledge of it but we consider this to be an okay limitation, especially
since the unused attributes check is disabled by default.
$ ./driver_deriving_x.exe -impl test.ml -check -no-corrections -diff-cmd diff
+ [%%ocaml.error "Attribute `deriving.end' was not used"]
[%%ocaml.error "Attribute `gen_stuff' was not used"]
[%%ocaml.error "Attribute `deriving.end' was not used"]
type t[@@deriving x]
@@ -89,11 +90,6 @@ since the unused attributes check is disabled by default.
[@@@deriving.end ]
type t3[@@gen_stuff ]
[@@@deriving.end ]
- 3a4,6
- > let _ = fun (_ : t2) -> ()
- > [%%ocaml.error
- > "Ppxlib.Deriving: 'y' is not a supported type deriving generator"]
- [1]
Now if we run our driver with the whole set of ppx-es, everything should go as
expected and all corrections will be correctly generated
@@ -121,6 +117,8 @@ no attribute warnings since this time, it knows about the [@@gen_stuff] attribut
and explicitly skips it.
$ ./driver_all.exe -impl test.ml -check -no-corrections -diff-cmd diff
+ [%%ocaml.error "Attribute `deriving.end' was not used"]
+ [%%ocaml.error "Attribute `deriving.end' was not used"]
type t[@@deriving x]
include struct let _ = fun (_ : t) -> ()
let x = 2
@@ -129,10 +127,3 @@ and explicitly skips it.
[@@@deriving.end ]
type t3[@@gen_stuff ]
[@@@deriving.end ]
- 3a4,6
- > let _ = fun (_ : t2) -> ()
- > let y = 3
- > let _ = y
- 5a9
- > let stuff = 4
- [1]
"/usr/bin/env" "bash" "-c" "opam exec -- dune build @install @check @runtest && rm -rf _build" failed with exit status 1
2024-12-06 15:57.10: Job failed: Failed: Build failed