diff --git a/doc/changes/10931.md b/doc/changes/10931.md new file mode 100644 index 000000000000..292be487383a --- /dev/null +++ b/doc/changes/10931.md @@ -0,0 +1,3 @@ +- Fix promotion of directory targets when the promoted directory has + sub-directories with only other sub-directories inside; regression + in b1c339b / #9407 (@ejgallego, closes #10609) diff --git a/src/dune_targets/dune_targets.ml b/src/dune_targets/dune_targets.ml index 4fd1cf81fbc3..fed0eb61f492 100644 --- a/src/dune_targets/dune_targets.ml +++ b/src/dune_targets/dune_targets.ml @@ -243,9 +243,7 @@ module Produced = struct acc_filenames, Path.Local.Map.union_exn acc_dirs dir | _ -> Error (Unsupported_file (Path.Build.relative dir filename, kind))) in - if not (Filename.Map.is_empty filenames) - then Path.Local.Map.add_exn dirs local filenames - else dirs + Path.Local.Map.add_exn dirs local filenames in let directory root dirname = let open Result.O in diff --git a/test/blackbox-tests/test-cases/directory-targets/github10609/run.t b/test/blackbox-tests/test-cases/directory-targets/github10609/run.t new file mode 100644 index 000000000000..05996f6183a8 --- /dev/null +++ b/test/blackbox-tests/test-cases/directory-targets/github10609/run.t @@ -0,0 +1,28 @@ +We test that a directory target with only other subdirs can be +properly promoted. + + $ cat > dune-project < (lang dune 3.16) + > (using directory-targets 0.1) + > EOF + + $ cat > dune < (rule + > (targets (dir node_modules)) + > (mode (promote (until-clean))) + > (action (system "mkdir -p node_modules/@clusterws/cws && mkdir -p node_modules/@clusterws/cws/build && mkdir -p node_modules/@clusterws/cws/dist && mkdir -p node_modules/@clusterws/cws/src && touch node_modules/@clusterws/cws/foo.txt && touch node_modules/@clusterws/cws/bar.txt"))) + > EOF + + $ dune build node_modules + $ ls _build/default/node_modules/@clusterws/cws + bar.txt + build + dist + foo.txt + src + $ ls node_modules/@clusterws/cws + bar.txt + build + dist + foo.txt + src diff --git a/test/blackbox-tests/test-cases/directory-targets/main.t b/test/blackbox-tests/test-cases/directory-targets/main.t index 0492c3564d91..b721b5a1c54e 100644 --- a/test/blackbox-tests/test-cases/directory-targets/main.t +++ b/test/blackbox-tests/test-cases/directory-targets/main.t @@ -57,8 +57,8 @@ Error message when the matching directory target is empty. 2 | (deps (sandbox always)) 3 | (targets (dir output)) 4 | (action (bash "mkdir output"))) - Error: Rule produced directory "output" that contains no files nor non-empty - subdirectories + Error: This rule defines a directory target "output" that matches the + requested path "output/x" but the rule's action didn't produce it [1] Error message when the matching directory target doesn't contain a requested path.