From dd6cd77990a792b42abe56c3b0c2f2bb35fe5247 Mon Sep 17 00:00:00 2001 From: Stephen Sherratt Date: Tue, 5 Nov 2024 15:29:49 +1100 Subject: [PATCH] Add repro for gh11058 Signed-off-by: Stephen Sherratt --- .../depopts/opam-package-with-many-depopts.t | 47 +++++++++++++++++++ 1 file changed, 47 insertions(+) create mode 100644 test/blackbox-tests/test-cases/pkg/depopts/opam-package-with-many-depopts.t diff --git a/test/blackbox-tests/test-cases/pkg/depopts/opam-package-with-many-depopts.t b/test/blackbox-tests/test-cases/pkg/depopts/opam-package-with-many-depopts.t new file mode 100644 index 00000000000..3b1b5e3e9d6 --- /dev/null +++ b/test/blackbox-tests/test-cases/pkg/depopts/opam-package-with-many-depopts.t @@ -0,0 +1,47 @@ +We test how opam files with many depopts dune.lock files: + + $ . ../helpers.sh + $ mkrepo + +Make a package with 3 depopts: + $ mkpkg with-depopts <<'EOF' + > depopts: [ "foo" "bar" "baz" ] + > EOF + $ mkpkg foo + + $ solve with-depopts + Internal error, please report upstream including the contents of _build/log. + Description: + ("invalid depopts", + { depopts = + Or + [ Or [ Atom ("foo", Empty); Atom ("bar", Empty) ] + ; Atom ("baz", Empty) + ] + }) + Raised at Stdune__Code_error.raise in file + "otherlibs/stdune/src/code_error.ml", line 10, characters 30-62 + Called from Dune_pkg__Opam_solver.resolve_depopts in file + "src/dune_pkg/opam_solver.ml", line 565, characters 3-21 + Called from Dune_pkg__Opam_solver.opam_package_to_lock_file_pkg in file + "src/dune_pkg/opam_solver.ml", line 645, characters 6-48 + Called from Stdlib__List.rev_map.rmap_f in file "list.ml", line 105, + characters 22-25 + Called from Stdune__List.map in file "otherlibs/stdune/src/list.ml", line 5, + characters 19-33 + Called from Dune_pkg__Opam_solver.solve_lock_dir.(fun) in file + "src/dune_pkg/opam_solver.ml", line 889, characters 8-277 + Called from Fiber__Scheduler.exec in file "vendor/fiber/src/scheduler.ml", + line 76, characters 8-11 + Re-raised at Stdune__Exn.raise_with_backtrace in file + "otherlibs/stdune/src/exn.ml", line 38, characters 27-56 + Called from Fiber__Scheduler.exec in file "vendor/fiber/src/scheduler.ml", + line 76, characters 8-11 + + I must not crash. Uncertainty is the mind-killer. Exceptions are the + little-death that brings total obliteration. I will fully express my cases. + Execution will pass over me and through me. And when it has gone past, I + will unwind the stack along its path. Where the cases are handled there will + be nothing. Only I will remain. + [1] +