]> git.ipfire.org Git - thirdparty/git.git/commitdiff
t/Makefile: make "check-meson" work with Dash
authorPatrick Steinhardt <ps@pks.im>
Fri, 27 Dec 2024 13:59:39 +0000 (14:59 +0100)
committerJunio C Hamano <gitster@pobox.com>
Fri, 27 Dec 2024 16:28:11 +0000 (08:28 -0800)
The "check-meson" target uses process substitution to check whether
extracted contents from "meson.build" match expected contents. Process
substitution is unportable though and thus the target will fail when
using for example Dash.

Fix this by writing data into a temporary directory.

Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/.gitignore
t/Makefile

index 91cf5772fe5643dbe075da98ed5166e1899b9a54..3e6b0f2cc57ffed0394d1cd2efc1e374f1c2169b 100644 (file)
@@ -2,4 +2,5 @@
 /test-results
 /.prove
 /chainlinttmp
+/mesontmp
 /out/
index 290fb03ff011d39c31c5073c796aa6f4dc966283..daa5fcae86f3480079b8c9743dd28e3fd304c27b 100644 (file)
@@ -103,6 +103,7 @@ clean-except-prove-cache: clean-chainlint
 
 clean: clean-except-prove-cache
        $(RM) -r '$(TEST_RESULTS_DIRECTORY_SQ)'
+       $(RM) -r mesontmp
        $(RM) .prove
 
 clean-chainlint:
@@ -116,16 +117,17 @@ check-chainlint:
 
 check-meson:
        @# awk acts up when trying to match single quotes, so we use \047 instead.
-       @printf "%s\n" \
+       @mkdir -p mesontmp && \
+       printf "%s\n" \
                "integration_tests t[0-9][0-9][0-9][0-9]-*.sh" \
                "unit_test_programs unit-tests/t-*.c" \
                "clar_test_suites unit-tests/u-*.c" | \
        while read -r variable pattern; do \
-               meson_tests=$$(awk "/^$$variable = \[\$$/ {flag=1 ; next } /^]$$/ { flag=0 } flag { gsub(/^  \047/, \"\"); gsub(/\047,\$$/, \"\"); print }" meson.build) && \
-               actual_tests=$$(ls $$pattern) && \
-               if test "$$meson_tests" != "$$actual_tests"; then \
+               awk "/^$$variable = \[\$$/ {flag=1 ; next } /^]$$/ { flag=0 } flag { gsub(/^  \047/, \"\"); gsub(/\047,\$$/, \"\"); print }" meson.build >mesontmp/meson.txt && \
+               ls $$pattern >mesontmp/actual.txt && \
+               if ! cmp mesontmp/meson.txt mesontmp/actual.txt; then \
                        echo "Meson tests differ from actual tests:"; \
-                       diff -u <(echo "$$meson_tests") <(echo "$$actual_tests"); \
+                       diff -u mesontmp/meson.txt mesontmp/actual.txt; \
                        exit 1; \
                fi; \
        done