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:alpine-3.20-4.14_opam-2.3) Base: ocaml/opam:alpine-3.20-ocaml-4.14@sha256:ebf15d5caec90eae50336736fbd8a2fc99ae01dbe5ee3030d0ac51d47f5f6554 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:alpine-3.20-ocaml-4.14@sha256:ebf15d5caec90eae50336736fbd8a2fc99ae01dbe5ee3030d0ac51d47f5f6554 # alpine-3.20-4.14_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.16.3 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-bash.1 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 host-arch-x86_64.1 host-system-other.1 ocaml.4.14.2 ocaml-base-compiler.4.14.2 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.16.0 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:alpine-3.20-ocaml-4.14@sha256:ebf15d5caec90eae50336736fbd8a2fc99ae01dbe5ee3030d0ac51d47f5f6554-alpine-3.20-4.14_opam-2.3-02b70755c860bb8c01a9f04d009eaca3" 2024-12-06 15:30.22: Using OBuilder spec: ((from ocaml/opam:alpine-3.20-ocaml-4.14@sha256:ebf15d5caec90eae50336736fbd8a2fc99ae01dbe5ee3030d0ac51d47f5f6554) (comment alpine-3.20-4.14_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.16.3 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-bash.1 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 host-arch-x86_64.1 host-system-other.1 ocaml.4.14.2 ocaml-base-compiler.4.14.2 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.16.0 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:31.14: Waiting for worker… 2024-12-06 15:53.09: Got resource from pool OCluster Building on x86-bm-c18.sw.ocaml.org All commits already cached HEAD is now at b51d33ea TMP: Implement -no-corrections (from ocaml/opam:alpine-3.20-ocaml-4.14@sha256:ebf15d5caec90eae50336736fbd8a2fc99ae01dbe5ee3030d0ac51d47f5f6554) 2024-12-06 15:53.42 ---> saved as "46649d2bbe6f00c86a5d5fe022ab7bfe3de0143ddf6170e61af97324592363ef" /: (comment alpine-3.20-4.14_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:53.43 ---> saved as "aaec08dc1cc376136cf44220786214e8a0ebbe9a942ef1f5ed5212343f398c1b" /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 [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] synchronised from file:///home/opam/opam-repository 2024-12-06 15:55.31 ---> saved as "c20b52836025e3513a9894fe231f6646b695a305ff639278a94bee27807f1565" /src: (run (shell "uname -rs && opam exec -- ocaml -version && opam --version")) Linux 5.15.0-126-generic The OCaml toplevel, version 4.14.2 2.3.0 2024-12-06 15:55.31 ---> saved as "88c93c6148c30c716bb68a57e0cac30b94145a807330da422304977daf743137" /src: (workdir /src) /src: (run (shell "sudo chown opam /src")) 2024-12-06 15:55.31 ---> saved as "fcd84e0e139c435d1af7f7c9e919dda0cc52c09a9bf78199943fce6b0078735e" /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:57.02 ---> saved as "c830deba4aa14eaaf0359b0c17b6506402c187ffad4add9660b8feefbc9cbab0" /src: (run (shell "mkdir -p 'bench/vendored/ppx_sexp_conv.v0.15.1/'")) 2024-12-06 15:57.02 ---> saved as "6d5116c0a775f9d8648332529d07ac4ef865441bb9588537c0bbd5257498f63b" /src: (copy (src ppxlib.opam ppxlib-tools.opam ppxlib-bench.opam) (dst ./)) 2024-12-06 15:57.03 ---> saved as "b1886e5818bd2b4398195b5d4db0c06a8a14c0bc6764a9c6a9bc478de4ed9864" /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:57.03 ---> saved as "2678e420912c4d7969616af1bfdcfb92bc6b792c4e3026e30728c5f04177e7a7" /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:57.21 ---> saved as "46f8a6fdc00884db70555f445d5acc6134231249ce2ed12f4468a5d394c39fc3" /src: (env DEPS "base.v0.16.3 base-bigarray.base base-threads.base base-unix.base cinaps.v0.15.1 cmdliner.1.3.0 conf-bash.1 csexp.1.5.2 dune.3.17.0 dune-configurator.3.17.0 host-arch-x86_64.1 host-system-other.1 ocaml.4.14.2 ocaml-base-compiler.4.14.2 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.16.0 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 "apk" "update" - fetch https://dl-cdn.alpinelinux.org/alpine/v3.20/main/x86_64/APKINDEX.tar.gz - fetch https://dl-cdn.alpinelinux.org/alpine/v3.20/community/x86_64/APKINDEX.tar.gz - fetch https://dl-cdn.alpinelinux.org/alpine/edge/main/x86_64/APKINDEX.tar.gz - fetch https://dl-cdn.alpinelinux.org/alpine/edge/community/x86_64/APKINDEX.tar.gz - fetch https://dl-cdn.alpinelinux.org/alpine/edge/testing/x86_64/APKINDEX.tar.gz - v3.20.3-388-g068b58b02cb [https://dl-cdn.alpinelinux.org/alpine/v3.20/main] - v3.20.3-386-g5fa81045983 [https://dl-cdn.alpinelinux.org/alpine/v3.20/community] - v3.21.0-80-g967093f5ebd [https://dl-cdn.alpinelinux.org/alpine/edge/main] - v3.21.0-80-g967093f5ebd [https://dl-cdn.alpinelinux.org/alpine/edge/community] - v3.21.0-67-g866dc2f2679 [https://dl-cdn.alpinelinux.org/alpine/edge/testing] - OK: 56102 distinct packages available <><> Synchronising pinned packages ><><><><><><><><><><><><><><><><><><><><><><> [ppxlib.dev] synchronised (file:///src) [ppxlib-tools.dev] synchronised (file:///src) [ppxlib-bench.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.14.2). [NOTE] Package ocaml is already installed (current version is 4.14.2). [NOTE] Package host-system-other is already installed (current version is 1). [NOTE] Package host-arch-x86_64 is already installed (current version is 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:57.52 ---> saved as "4e2c0cc0b7adc1a9ab3da9fe2b07e69a25d11f469cb1c9ae4a853656f5fbf288" /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.14.2). [NOTE] Package ocaml is already installed (current version is 4.14.2). [NOTE] Package host-system-other is already installed (current version is 1). [NOTE] Package host-arch-x86_64 is already installed (current version is 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 15 packages - install base v0.16.3 - install cinaps v0.15.1 - install cmdliner 1.3.0 - install conf-bash 1 - 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.16.0 - install stdlib-shims 0.3.0 - install yojson 2.2.2 <><> Processing actions <><><><><><><><><><><><><><><><><><><><><><><><><><><><> -> retrieved cinaps.v0.15.1 (cached) -> installed conf-bash.1 -> retrieved csexp.1.5.2 (cached) -> retrieved base.v0.16.3 (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.16.0 (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 sexplib0.v0.16.0 -> installed stdlib-shims.0.3.0 -> installed ocaml-compiler-libs.v0.12.4 -> installed re.1.12.0 -> installed yojson.2.2.2 -> installed cinaps.v0.15.1 -> installed dune-configurator.3.17.0 -> installed base.v0.16.3 Done. # To update the current shell environment, run: eval $(opam env) 2024-12-06 15:59.30 ---> saved as "3c0c3bc6bef85a62ab2303f3c5db735c2431e913e670e0fe172b7a25544927e0" /src: (copy (src .) (dst /src)) 2024-12-06 15:59.30 ---> saved as "066dd6c6c497d0bf3411d6e7d268573cbd05ab743e7730c49593979fb01245f3" /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/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t _build/.sandbox/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t.corrected diff --git a/_build/.sandbox/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t b/_build/.sandbox/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t.corrected index 359719e..8d2ee5f 100644 --- a/_build/.sandbox/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t +++ b/_build/.sandbox/4735b2da53c00f78235ddad66fa0bf96/default/test/driver/no-corrections/run.t.corrected @@ -66,10 +66,18 @@ and the last [@@@deriving.end] that comes with it. [@@@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"] + --- test.ml + +++ test.ml.ppx-corrected + @@ -1,6 +1,9 @@ + type t [@@deriving x] + type t2 + [@@deriving_inline y] + +let _ = fun (_ : t2) -> () + +[%%ocaml.error + + "Ppxlib.Deriving: 'y' is not a supported type deriving generator"] + [@@@deriving.end] + type t3 [@@gen_stuff] + [@@@deriving.end] [1] Now if we run it with -no-corrections, there should be no .ppx-corrected file @@ -79,6 +87,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 +98,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 @@ -107,12 +111,19 @@ expected and all corrections will be correctly generated [@@@deriving.end ] type t3[@@gen_stuff ] [@@@deriving.end ] - 3a4,6 - > let _ = fun (_ : t2) -> () - > let y = 3 - > let _ = y - 5a9 - > let stuff = 4 + --- test.ml + +++ test.ml.ppx-corrected + @@ -1,6 +1,10 @@ + type t [@@deriving x] + type t2 + [@@deriving_inline y] + +let _ = fun (_ : t2) -> () + +let y = 3 + +let _ = y + [@@@deriving.end] + type t3 [@@gen_stuff] + +let stuff = 4 + [@@@deriving.end] [1] For reference and to document the behaviour of the -no-corrections flag in this @@ -121,6 +132,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 +142,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 16:00.22: Job failed: Failed: Build failed