From 8aa2ed067dcf23aceafa8e92ade50351323cbf28 Mon Sep 17 00:00:00 2001 From: Sutou Kouhei Date: Wed, 25 Sep 2024 16:17:24 +0900 Subject: [PATCH] GH-44158: [Archery][Integration] Add more explanation how --target-implementations works (#44177) ### Rationale for this change We can't explain `--target-implementations` in one-line document. ### What changes are included in this PR? We can use not only `click.command(help)` but also docstring to show long command description for "archery integration --help". This uses docstring not `click.command(help)`. ### Are these changes tested? Yes. ### Are there any user-facing changes? No. * GitHub Issue: #44158 Authored-by: Sutou Kouhei Signed-off-by: Sutou Kouhei --- dev/archery/archery/cli.py | 58 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) diff --git a/dev/archery/archery/cli.py b/dev/archery/archery/cli.py index 4f090657a590a..6dfc3a56a73c7 100644 --- a/dev/archery/archery/cli.py +++ b/dev/archery/archery/cli.py @@ -772,6 +772,64 @@ def _set_default(opt, default): help=("Substring for test names to include in run, " "e.g. -k primitive")) def integration(with_all=False, random_seed=12345, **args): + """If you don't specify the "--target-implementations" option nor + the "ARCHERY_INTEGRATION_TARGET_IMPLEMENTATIONS" environment + variable, test patterns are product of all specified + implementations and all specified implementations. + + If "--with-cpp", "--with-java" and "--with-rust" are specified, + the following patterns are tested: + + \b + | Producer | Consumer | + |----------|----------| + | C++ | C++ | + | C++ | Java | + | C++ | Rust | + | Java | C++ | + | Java | Java | + | Java | Rust | + | Rust | C++ | + | Rust | Java | + | Rust | Rust | + + If "--target-implementations=cpp,java" or + "ARCHERY_INTEGRATION_TARGET_IMPLEMENTATIONS=cpp,java" is + specified, test patterns are: + + \b + * product of {C++,Java} and {C++,Java} + * product of {C++,Java} and {Rust} + * product of {Rust} and {C++,Java} + + \b + | Producer | Consumer | + |----------|----------| + | C++ | C++ | + | C++ | Java | + | Java | C++ | + | Java | Java | + | C++ | Rust | + | Java | Rust | + | Rust | C++ | + | Rust | Java | + + In general, we can reduce test time by specifying only + implementations in our repository. For example, we can use + "ARCHERY_INTEGRATION_TARGET_IMPLEMENTATIONS=rust" for + apache/arrow-rs. It uses only the following test patterns: + + \b + | Producer | Consumer | + |----------|----------| + | Rust | Rust | + | Rust | C++ | + | Rust | Java | + | C++ | Rust | + | Java | Rust | + + """ + from .integration.runner import write_js_test_json, run_all_tests import numpy as np